「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_project的Django项目,我们可以通过上面查看目录结构。
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服务器对接的入口文件。
相关推荐
- 一个基于.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模型是一种强大的工具,可以...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- mfc框架 (52)
- abb框架断路器 (48)
- beego框架 (52)
- java框架spring (58)
- grpc框架 (65)
- tornado框架 (48)
- 前端框架bootstrap (54)
- orm框架有哪些 (51)
- 知识框架图 (52)
- ppt框架 (55)
- 框架图模板 (59)
- 内联框架 (52)
- cad怎么画框架 (58)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)