如何在Linux上安全部署Django?

环境准备

  1. 更新系统

    sudo apt update && sudo apt upgrade -y  # Debian/Ubuntu
    sudo dnf update -y  # Fedora/CentOS
  2. 安装Python
    Django基于Python运行,推荐Python 3.8+:

    sudo apt install python3 python3-pip python3-venv -y
  3. 创建虚拟环境(隔离依赖)

    python3 -m venv myenv      # 创建虚拟环境目录
    source myenv/bin/activate  # 激活环境(提示符会变化)

安装与配置Django

  1. 安装Django
    在激活的虚拟环境中执行:

    pip install django
  2. 创建Django项目

    django-admin startproject myproject  # 生成项目目录
    cd myproject
  3. 配置数据库(默认SQLite无需额外安装)
    如需MySQL/PostgreSQL,需安装对应驱动:

    pip install mysqlclient    # MySQL
    pip install psycopg2-binary # PostgreSQL

    修改 myproject/settings.py 中的 DATABASES 配置。


运行开发服务器

  1. 启动服务

    python manage.py runserver 0.0.0.0:8000
    • 0.0.0 允许外部设备访问
    • 默认端口8000(可用 :8080 修改)
  2. 验证运行
    浏览器访问:
    http://<服务器IP>:8000
    出现 “The install worked successfully!” 即成功。


生产环境部署建议

开发服务器仅用于测试,生产环境需使用:

  1. WSGI服务器:Gunicorn或uWSGI
    pip install gunicorn
    gunicorn myproject.wsgi:application --bind 0.0.0.0:8000
  2. 反向代理:Nginx/Apache
    Nginx配置示例:

    server {
        listen 80;
        server_name yourdomain.com;
        location / {
            proxy_pass http://127.0.0.1:8000;
            proxy_set_header Host $host;
        }
    }
  3. 静态文件处理
    settings.py 中设置:

    STATIC_ROOT = BASE_DIR / "static"

    执行:

    python manage.py collectstatic

故障排查

  • 端口冲突
    使用 lsof -i:8000 查找占用进程,kill <PID> 终止或换端口。
  • 访问被拒绝
    检查防火墙:

    sudo ufw allow 8000  # 开放端口
  • 依赖缺失
    通过 pip freeze > requirements.txt 备份依赖,部署时用 pip install -r requirements.txt 恢复。

安全提示

  1. 生产环境务必设置 DEBUG = False
  2. 生成密钥:python -c 'from django.core.management.utils import get_random_secret_key; print(get_random_secret_key())'
  3. 定期更新依赖:pip list --outdated

扩展学习

  • 官方文档:Django Deployment Checklist
  • 虚拟环境管理:Python venv指南
  • 服务器配置:DigitalOcean Django教程

引用说明参考Django官方文档、Linux基金会安全指南及Python社区最佳实践,适用于Ubuntu 20.04+、CentOS 7+等主流发行版,操作前请备份数据,关键操作建议在测试环境验证。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/5522.html

(0)
酷番叔酷番叔
上一篇 2025年6月24日 14:59
下一篇 2025年6月24日 15:08

相关推荐

  • Linux vim如何保存退出?操作步骤是怎样的?

    在Linux系统中,vim(Vi IMproved)是一款功能强大的文本编辑器,广泛应用于服务器管理、代码编写等场景,掌握vim的保存退出操作是使用vim的基础,但不同场景下(如正常保存、强制退出、多文件处理等)对应的命令有所不同,本文将详细讲解vim保存退出的各类操作方法、适用场景及注意事项,帮助用户高效完成……

    2025年9月24日
    16600
  • linux下如何修改文件夹权限

    Linux下修改文件夹权限是系统管理中的基础操作,涉及用户、用户组对文件或目录的访问控制权限,包括读(r)、写(w)、执行(x)三种基本权限,正确设置权限既能保障系统安全,又能满足协作需求,下面从基础概念到实操方法详细说明,Linux权限基础概念Linux权限分为三组:文件所有者(User,u)、所属用户组(G……

    2025年8月22日
    15300
  • 防火墙安全吗?

    端口开启原理端口是网络通信的入口点,Linux通过防火墙(如firewalld、iptables、ufw)控制端口访问,开启端口需两个核心步骤:修改防火墙规则:允许外部流量通过目标端口,确保服务监听:相关应用需绑定到该端口(如Nginx监听80端口),操作步骤(根据防火墙工具选择)方法1:使用 firewall……

    2025年6月14日
    17800
  • linux如何开启系统日志功能

    Linux中,系统日志功能通常默认开启,可通过/etc/rsyslog.conf或`/etc/syslog.

    2025年8月14日
    14200
  • Linux如何安装decrypt工具?具体步骤是什么?

    Linux系统下,解密操作通常涉及文件、磁盘或特定协议的数据还原,常见工具包括GPG、VeraCrypt、OpenSSL等,不同工具适用于不同场景,安装方式因发行版而异,本文将详细介绍主流解密工具在Linux环境下的安装及基础使用方法,GPG(GNU Privacy Guard)安装与使用GPG广泛用于文件、邮……

    2025年9月17日
    11700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信