百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「Django框架」-Pycharm搭建部署Django环境

ccwgpt 2024-09-17 12:42 53 浏览 0 评论

本文来源于公众号【Python野路子】


项目环境搭建


一、创建Django项目

1. 创建python虚拟环境

实际工作中是在Linux上进行开发,所以最好是在虚拟机上或者连接阿里云等各种云进行开发。我这里直接在阿里云上,使用Centos 7中进行开发。

我们前面已经学习过怎么样搭建python虚拟环境,详情参考Centos7中Flask部署之Python环境。

这里我们新创建个虚拟环境用于学习。

mkvirtualenv django_project   # 创建虚拟环境

workon django_project   # 激活虚拟环境


2. 安装django

Django框架目前最新版本3.x了,目前版本之前没什么太大差别,具体差异请自行查阅资料,我们这里选择2.x安装。

pip install django==2.1.8   # 安装django框架
# pip install django ~=2.x    ~=表示安装指定版本的最新版本,x表示2版本的最新版本

# 查看安装的模块
(django_project) [root@qmpython ~]# pip list
Package    Version
---------- -------
Django     2.1.8  
pip        20.0.2 
pytz       2019.3 
setuptools 46.0.0 
wheel      0.34.2 

3.创建项目

我们先创建一个存放项目的目录,比如我们这里存放到/root/src/www下。

cd /root/src
mkdir www   # 没有就创建

3.1 用命令行方式

3.1.1 创建项目

# 1、cd进入保存项目的目录下
cd /root/src/www

# 2、创建Django项目,django-admin startproject 项目名称
django-admin startproject django_project


(django_project) [root@qmpython www]# ls
demo_test  django_project  QmpythonBlog
(django_project) [root@qmpython www]# cd django_project/
(django_project) [root@qmpython django_project]# tree
.
├── django_project
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── manage.py

1 directory, 5 files

此时,成功创建一个名为django_projectDjango项目,我们可以通过上面查看目录结构。

3.1.2 创建应用

Django框架通过app应用的方式来管理整个网站项目,一个网站中包含多个子业务模块,比如用户模块、商品模块,新闻模块等,我们可以将这些子模块称作一个应用(app)。

# 进入项目根目录下
cd www/django_project

# 创建应用,python manage.py startapp 应用名称
(django_project) [root@qmpython django_project]# python manage.py startapp user
(django_project) [root@qmpython django_project]# tree
.
├── django_project
│   ├── __init__.py
│   ├── __pycache__
│   │   ├── __init__.cpython-37.pyc
│   │   └── settings.cpython-37.pyc
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
├── manage.py
└── user
    ├── admin.py
    ├── apps.py
    ├── __init__.py
    ├── migrations
    │   └── __init__.py
    ├── models.py
    ├── tests.py
    └── views.py

4 directories, 14 files

我们可以看到成功创建了user应用,其中包含文件含义如下:

  • __init__.py:空文件,指定当前目录可作为包使用。
  • tests.py:用于开发测试用例,在实际开发中,如果需要对模块进行测试,可在此文件中编写测试代码。
  • views.py:视图文件,编写视图相关代码。
  • models.py:模型文件,编写模型相关代码。
  • migrations.py:与模型移植相关。

注意,创建的应用需要在settings.py模块中进行配置才能够被项目识别。

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'user',   # 配置应用
]

3.1.3 启动项目

在开发阶段,为了能够快速预览到网站的显示和运行效果,Django提供了一个纯Python编写的轻量级Web服务器,仅在开发阶段使用。

# 进入项目根目录下,即manage.py文件所在路径下
cd /root/src/www/django_project

# 启动服务器,python manage.py runserver ip:port
python manage.py runserver 47.107.x.x:5003

报错:Error: That IP address can't be assigned to.

但是使用localhost、或者0.0.0.0 就可以成功启动,但只是进行无法外网访问。

字面理解这句话的意思就是:该IP地址不能被分配。

我们有几种解决方案:

1、查看settings.py文件的ALLOWED_HOSTS是否配置了该ip地址,如果没有的话就加上,开发时,建议把0.0.0.0 、127.0.0.1 、localhost这些都添加上去。

ALLOWED_HOSTS = ['0.0.0.0','127.0.0.1','localhost','47.107.x.x']

2、如果使用的是服务器的话,请在服务器控制台的防火墙设置里,查看是否添加了这个端口。

3、如果上述方法均不可以,那么就:

python manage.py runserver 0:8004

直接把启动的ip设置为0,然后问题就解决了,配置好防火墙之后,就可以直接用域名或者是服务器ip访问了 。


此时,在浏览器中输入网址,看效果如下,表示启动服务器正常能够访问。


在以后的开发中,就可以使用该网址和端口查看当前项目的开发效果了。

如果在项目中执行了增删改查文件操作,服务器会自动重启,不需要手动启动(当然后期如果使用了nginx服务器,修改静态文件则需要重启),如果要停止,直接ctrl+c。

3.2 使用pycharm创建

3.2.1 创建项目



配置之前创建的虚拟环境Python解释器:



配置远程Django项目根目录:


Rmote project location,是python脚本上传到远程服务器Django项目的根目录,这个路径会自动同步到Tools中mapping里面;注意:这个路径需要在虚拟环境中存在,没有则新建!

3.2.2 创建应用

设置Application name,即app应用程序,否则需要用命令创建。后续其他app还是需要使用命令行方式创建。



注意:有的时候,可能某些原因导致pycharm看不到生成相关文件,这时不要以为没创建成功,可以先去远程服务器相关目录下有没有生成。如果有,就使用后面同步设置方法进行同步。


注意:使用pycharm相对于命令行方式生成了模板文件存放路径templates,如果使用命令行的方式创建,则只需要手工创建即可。

3.2.3 设置同步配置

设置同步配置,用于将本地代码同步到服务器,或者将服务器代码下载到本地中。







也可以打开远程项目目录窗口




也可以这里直接下载上传或者对比本地和远程服务器项目差异


3.2.4 配置项目远程拟环境

查看当前项目是否连接所需环境,如需修改配置当前工程的远程环境,则:



3.2.5 配置运行环境



0.0.0.0 或者 0, 代表任何IP都允许访问,8004: 代表我们对外的端口,默认端口为80。

settings.py修改配置,允许ip地址访问。

ALLOWED_HOSTS = ['*']    # 测试环境配置*,允许任何ip地址访问

应用配置,使用pycharm创建的第一个app,系统会默认配置好。

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'user.apps.UserConfig',   # 默认配置好,若是用命令方式,这里则需要配置应用名称即可。
]

3.2.6 启动项目


浏览器输入网址进行访问:


至此使用Pycharm创建Django项目成功。

二、项目结构介绍

我们来学习下,Django的项目结构,我们先看下目录结构:

[root@qmpython django_project]# tree
.
├── db.sqlite3
├── django_project
│   ├── __init__.py
│   ├── __pycache__
│   │   ├── __init__.cpython-37.pyc
│   │   ├── settings.cpython-37.pyc
│   │   ├── urls.cpython-37.pyc
│   │   └── wsgi.cpython-37.pyc
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
├── manage.py
├── templates
└── user
    ├── admin.py
    ├── apps.py
    ├── __init__.py
    ├── migrations
    │   ├── __init__.py
    │   └── __pycache__
    │       └── __init__.cpython-37.pyc
    ├── models.py
    ├── __pycache__
    │   ├── admin.cpython-37.pyc
    │   ├── apps.cpython-37.pyc
    │   ├── __init__.cpython-37.pyc
    │   └── models.cpython-37.pyc
    ├── tests.py
    └── views.py

7 directories, 22 files

其中:

  • manage.py:项目运行的入口文件,执行项目配置文件路径。以后和项目交互基本都是基于这个文件,一般在终端输入python manage.py 子命令,可以输入python manage.py help查看能执行哪些命令。
  • __init__.py:空文件,指定当前目录可作为包使用。
  • settings.py:整个项目的配置文件,例如配置应用、模板目录、静态文件目录、邮件发送等。
  • urls.py:是项目的总URL配置文件,在该文件中将用户请求的URL对应到某个视图函数。
  • wsgi.py:项目与支持WSGI协议的Web服务器对接的入口文件。


#Django#

相关推荐

一个基于.Net Core遵循Clean Architecture原则开源架构

今天给大家推荐一个遵循CleanArchitecture原则开源架构。项目简介这是基于Asp.netCore6开发的,遵循CleanArchitecture原则,可以高效、快速地构建基于Ra...

AI写代码翻车无数次,我发现只要提前做好这3步,bug立减80%

写十万行全是bug之后终于找到方法了开发"提示词管理助手"新版本那会儿,我差点被bug整崩溃。刚开始两周,全靠AI改代码架构,结果十万行程序漏洞百出。本来以为AI说没问题就稳了,结果...

OneCode低代码平台的事件驱动设计:架构解析与实践

引言:低代码平台的事件驱动范式在现代软件开发中,事件驱动架构(EDA)已成为构建灵活、松耦合系统的核心范式。OneCode低代码平台通过创新性的注解驱动设计,将事件驱动理念深度融入平台架构,实现了业务...

国内大厂AI插件评测:根据UI图生成Vue前端代码

在IDEA中安装大厂的AI插件,打开ruoyi增强项目:yudao-ui-admin-vue31.CodeBuddy插件登录腾讯的CodeBuddy后,大模型选择deepseek-v3,输入提示语:...

AI+低代码技术揭秘(二):核心架构

本文档介绍了为VTJ低代码平台提供支持的基本架构组件,包括Engine编排层、Provider服务系统、数据模型和代码生成管道。有关UI组件库和widget系统的信息,请参阅UI...

GitDiagram用AI把代码库变成可视化架构图

这是一个名为gitdiagram的开源工具,可将GitHub仓库实时转换为交互式架构图,帮助开发者快速理解代码结构。核心功能一键可视化:替换GitHubURL中的"hub...

30天自制操作系统:第六天:代码架构整理与中断处理

1.拆开bootpack.c文件。根据设计模式将对应的功能封装成独立的文件。2.初始化pic:pic(可编程中断控制器):在设计上,cpu单独只能处理一个中断。而pic是将8个中断信号集合成一个中断...

AI写代码越帮越忙?2025年研究揭露惊人真相

近年来,AI工具如雨后春笋般涌现,许多人开始幻想程序员的未来就是“对着AI说几句话”,就能轻松写出完美的代码。然而,2025年的一项最新研究却颠覆了这一期待,揭示了一个令人意外的结果。研究邀请了16位...

一键理解开源项目:两个自动生成GitHub代码架构图与说明书工具

一、GitDiagram可以一键生成github代码仓库的架构图如果想要可视化github开源项目:https://github.com/luler/reflex_ai_fast,也可以直接把域名替换...

5分钟掌握 c# 网络通讯架构及代码示例

以下是C#网络通讯架构的核心要点及代码示例,按协议类型分类整理:一、TCP协议(可靠连接)1.同步通信//服务器端usingSystem.Net.Sockets;usingTcpListene...

从复杂到优雅:用建造者和责任链重塑代码架构

引用设计模式是软件开发中的重要工具,它为解决常见问题提供了标准化的解决方案,提高了代码的可维护性和可扩展性,提升了开发效率,促进了团队协作,提高了软件质量,并帮助开发者更好地适应需求变化。通过学习和应...

低代码开发当道,我还需要学习LangChain这些框架吗?| IT杂谈

专注LLM深度应用,关注我不迷路前两天有位兄弟问了个问题:当然我很能理解这位朋友的担忧:期望效率最大化,时间用在刀刃上,“不要重新发明轮子”嘛。铺天盖地的AI信息轰炸与概念炒作,很容易让人浮躁与迷茫。...

框架设计并不是简单粗暴地写代码,而是要先弄清逻辑

3.框架设计3.框架设计本节我们要开发一个UI框架,底层以白鹭引擎为例。框架设计的第一步并不是直接撸代码,而是先想清楚设计思想,抽象。一个一个的UI窗口是独立的吗?不是的,...

大佬用 Avalonia 框架开发的 C# 代码 IDE

AvalonStudioAvalonStudio是一个开源的跨平台的开发编辑器(IDE),AvalonStudio的目标是成为一个功能齐全,并且可以让开发者快速使用的IDE,提高开发的生产力。A...

轻量级框架Lagent 仅需20行代码即可构建自己的智能代理

站长之家(ChinaZ.com)8月30日消息:Lagent是一个专注于基于LLM模型的代理开发的轻量级框架。它的设计旨在简化和提高这种模型下代理的开发效率。LLM模型是一种强大的工具,可以...

取消回复欢迎 发表评论: