新手实战指南: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(命令入口)
  • 项目同名文件夹(核心配置)


相关文章
|
7天前
|
JSON API 数据格式
OpenCode入门使用教程
本教程介绍如何通过安装OpenCode并配置Canopy Wave API来使用开源模型。首先全局安装OpenCode,然后设置API密钥并创建配置文件,最后在控制台中连接模型并开始交互。
3157 7
|
13天前
|
人工智能 JavaScript Linux
【Claude Code 全攻略】终端AI编程助手从入门到进阶(2026最新版)
Claude Code是Anthropic推出的终端原生AI编程助手,支持40+语言、200k超长上下文,无需切换IDE即可实现代码生成、调试、项目导航与自动化任务。本文详解其安装配置、四大核心功能及进阶技巧,助你全面提升开发效率,搭配GitHub Copilot使用更佳。
|
3天前
|
人工智能 API 开发者
Claude Code 国内保姆级使用指南:实测 GLM-4.7 与 Claude Opus 4.5 全方案解
Claude Code是Anthropic推出的编程AI代理工具。2026年国内开发者可通过配置`ANTHROPIC_BASE_URL`实现本地化接入:①极速平替——用Qwen Code v0.5.0或GLM-4.7,毫秒响应,适合日常编码;②满血原版——经灵芽API中转调用Claude Opus 4.5,胜任复杂架构与深度推理。
|
15天前
|
存储 人工智能 自然语言处理
OpenSpec技术规范+实例应用
OpenSpec 是面向 AI 智能体的轻量级规范驱动开发框架,通过“提案-审查-实施-归档”工作流,解决 AI 编程中的需求偏移与不可预测性问题。它以机器可读的规范为“单一真相源”,将模糊提示转化为可落地的工程实践,助力开发者高效构建稳定、可审计的生产级系统,实现从“凭感觉聊天”到“按规范开发”的跃迁。
2236 18
|
7天前
|
人工智能 前端开发 Docker
Huobao Drama 开源短剧生成平台:从剧本到视频
Huobao Drama 是一个基于 Go + Vue3 的开源 AI 短剧自动化生成平台,支持剧本解析、角色与分镜生成、图生视频及剪辑合成,覆盖短剧生产全链路。内置角色管理、分镜设计、视频合成、任务追踪等功能,支持本地部署与多模型接入(如 OpenAI、Ollama、火山等),搭配 FFmpeg 实现高效视频处理,适用于短剧工作流验证与自建 AI 创作后台。
1116 5
|
6天前
|
人工智能 运维 前端开发
Claude Code 30k+ star官方插件,小白也能写专业级代码
Superpowers是Claude Code官方插件,由核心开发者Jesse打造,上线3个月获3万star。它集成brainstorming、TDD、系统化调试等专业开发流程,让AI写代码更规范高效。开源免费,安装简单,实测显著提升开发质量与效率,值得开发者尝试。
|
17天前
|
人工智能 测试技术 开发者
AI Coding后端开发实战:解锁AI辅助编程新范式
本文系统阐述了AI时代开发者如何高效协作AI Coding工具,强调破除认知误区、构建个人上下文管理体系,并精准判断AI输出质量。通过实战流程与案例,助力开发者实现从编码到架构思维的跃迁,成为人机协同的“超级开发者”。
1262 102
|
13天前
|
人工智能 JSON 自然语言处理
【2026最新最全】一篇文章带你学会Qoder编辑器
Qoder是一款面向程序员的AI编程助手,集智能补全、对话式编程、项目级理解、任务模式与规则驱动于一体,支持模型分级选择与CLI命令行操作,可自动生成文档、优化提示词,提升开发效率。
1000 10
【2026最新最全】一篇文章带你学会Qoder编辑器