新手实战指南:Django 项目结构与启动管理

简介: 初次接触Django,你是否被它庞大的项目结构劝退?这正是其工程化优势所在。本文将带你从项目创建到服务启停,完整拆解核心文件结构,帮你避开端口占用等常见坑位。学完这篇,你将对Django的整体架构有清晰认知。

在第一次接触 Django 时,很多同学都会被它的“重量感”劝退:

明明只是想写个接口,为什么要先创建一整套项目结构?

但这恰恰是 Django 的优势所在。 它不是一个“一个 .py 文件跑全场”的轻量框架,而是从第一天就把你拉进工程化开发的轨道

这篇文章,完整整理了课堂视频中的核心内容,带你从 项目创建 → 服务启动 → 关闭与排错 → 项目结构拆解 一步步走清楚。


阅读目录

  • 一、Django 项目是如何创建的
  • 二、Django 服务如何启动与验证
  • 三、Django 服务关闭的两种方式
  • 四、新手最常见问题:端口被占用
  • 五、Django 项目整体结构一览(配图)
  • 六、核心文件逐个讲清楚
  • 七、为什么说 runserver 只适合开发环境
  • 八、本节内容小结

一、Django 项目是如何创建的?

在 Linux 环境中安装好 Django 后,系统会自动提供一个命令行工具:

django-admin

它是 创建 Django 项目的唯一入口

创建项目的核心命令

django-admin startproject 项目名

例如:

django-admin startproject myset

执行完成后,会在当前目录下生成一个新的项目文件夹。

你可以通过:

ls

来确认项目是否创建成功。


二、Django 服务如何启动与验证?

项目创建完成后,第一件事一定是:把服务跑起来,确认环境没问题。

1、 启动开发测试服务

进入项目目录,执行:

python3 manage.py runserver

此时 Django 会:

  • 启动一个开发环境服务器
  • 默认监听 8000 端口
  • 仅用于本地开发与测试

终端中会看到类似输出:

Starting development server at http://127.0.0.1:8000/

2、 浏览器验证服务状态

在浏览器中访问:

http://127.0.0.1:8000

如果看到 Django 的欢迎页面(带动画的那个),说明:

  • 项目结构正确
  • Django 运行正常
  • 服务启动成功

3、 指定其他端口启动

如果 8000 端口不方便使用,也可以指定端口:

python3 manage.py runserver 5000

访问地址对应变为:

http://127.0.0.1:5000

三、Django 服务如何关闭?两种常见方式

方式一:最推荐(记得启动终端)

在运行 runserver 的终端中,直接按:

Ctrl + C

服务会立刻停止,端口释放。


方式二:端口被占 / 忘了在哪个终端启动

这是新手阶段非常高频的情况。

1、 查找端口占用进程

sudo lsof -i :8000

输出可能会有多行,重点找状态为 LISTEN 的那一行

2、杀掉对应进程

kill -9 进程ID

然后重新执行 runserver 即可。


四、新手最常见问题:端口被占用怎么办?

当你启动服务时看到:

Error: That port is already in use

不要慌,这个问题本质只有两种原因:

  • 上一次 Django 服务没有正常关闭
  • 该端口被其他程序占用

解决思路固定不变:

  1. lsof -i :端口号
  2. LISTEN 状态
  3. kill 掉进程
  4. 重新启动服务

五、Django 项目整体结构一览

image.png

创建完成后的 Django 项目,结构大致如下:

myset/
├── manage.py
├── db.sqlite3
└── myset/
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

六、Django 项目结构

graph LR
    A[Django 项目] --> B[manage.py]
    A --> C[db.sqlite3]
    A --> D[项目同名文件夹]
    D --> D1[__init__.py]
    D --> D2[settings.py]
    D --> D3[urls.py]
    D --> D4[wsgi.py]

七、核心文件逐个讲清楚(新手重点)


Django 项目文件结构拆解图

1、 manage.py —— Django 的命令总入口

  • 所有 Django 子命令都从这里触发
  • runservermigratecreatesuperuser 都依赖它

如果你忘了命令怎么写:

python3 manage.py

直接回车即可查看全部可用命令。


2、 db.sqlite3 —— 默认数据库文件

  • 新建项目时不存在
  • 第一次 runserver 时自动生成
  • Django 默认数据库

在实际项目中,后续通常会替换为 MySQL 或 PostgreSQL。


3、 项目同名文件夹(核心配置区)

  • __init__.py:Python 包标识
  • settings.py:项目配置核心文件
  • urls.py:主路由入口,所有请求先到这里
  • wsgi.py:正式上线时使用的 Web 网关配置

八、一个必须记住的结论

runserver 只适合开发和测试环境

  • 前台启动
  • 性能与安全性都不适合生产
  • 正式上线会采用更规范的启动方式

九、本节内容小结

  • Django 项目创建使用 django-admin startproject
  • 开发环境启动使用 python3 manage.py runserver
  • 服务关闭可通过 Ctrl + C 或 kill 进程
  • 项目结构中最重要的是:
  • manage.py(命令入口)
  • 项目同名文件夹(核心配置)


相关文章
|
前端开发 Java Maven
96.【SpringBoot接入支付宝-thymeleaf-springBoot】
96.【SpringBoot接入支付宝-thymeleaf-springBoot】
496 0
|
Kubernetes Cloud Native 开发工具
Argo与Flux在云原生GitOps实践上的能力对比与分析
随着云原生技术的普及和落地,越来越多的云原生应用被部署到生产环境中,由于云原生应用通常都是基于云的分布式部署模式,且每个应用可能是由多个功能组件互相调用来一起提供完整的服务的,每个组件都有自己独立的迭代流程和计划。在这种情况下,功能组件越多,意味着应用的发布管理越复杂,如果没有一个好的方案或者系统来管理复杂应用的发布上线的话,业务面临的风险也是非常大的。开源社区在复杂应用发布管理方面逐渐开始发力,
5555 1
Argo与Flux在云原生GitOps实践上的能力对比与分析
|
JavaScript
Syntax Error: Error: Cannot find module ‘node-sass‘
Syntax Error: Error: Cannot find module ‘node-sass‘
676 0
|
算法 Linux
【Linux笔记】压缩、解压文件的 4 种方式。tar、gzip、gunzip、zip、unzip、7z命令使用方法
【Linux笔记】压缩、解压文件的 4 种方式。tar、gzip、gunzip、zip、unzip、7z命令使用方法
|
11月前
|
Python
掌握Python装饰器:轻松统计函数执行时间
掌握Python装饰器:轻松统计函数执行时间
599 76
|
负载均衡 算法 网络虚拟化
ensp中链路聚合配置命令
链路聚合(Link Aggregation)是结合多条物理链路形成逻辑链路的技术,提升网络带宽、增强冗余性和优化负载均衡。在高带宽、高可靠性及负载均衡需求的场景如服务器集群、数据中心等中广泛应用。配置包括手动和自动模式,手动模式下,如LSW1和LSW2,通过`int eth-trunk`、`trunkport`等命令配置接口和成员链路。自动模式下,如SW3和LSW4,使用LACP协议动态聚合,通过`mode lacp-static`和`load-balance dst-mac`命令设置。配置后,使用`dis eth-trunk`检查聚合状态。
3107 1
ensp中链路聚合配置命令
|
前端开发 Java Go
选择适合微服务的编程语言
选择适合微服务的编程语言
|
开发者 容器
Flutter笔记:Widgets Easier组件库(3)使用按钮组件
Flutter笔记:Widgets Easier组件库(3)使用按钮组件
441 2
|
消息中间件 NoSQL 调度
Django后端架构开发:Django 与 Celery 的深度集成
Django后端架构开发:Django 与 Celery 的深度集成
1074 0
|
关系型数据库 MySQL 数据库连接
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
2097 11

热门文章

最新文章