Centos7.x快速配置Django+Nginx+Uwsgi服务

大家好,我是Mr数据杨。今天,将和大家分享如何构建一个完善的服务器环境。折磨了我2天,终于自己调试成功Django+nginx+uwsgi的服务,直接上流程按照这个流程100%能成功,就算你啥也不懂看配置过程和备注也能成功。

就像郭嘉在官渡之战前精心部署、策划那样,首先要建立一个良好的系统环境,保证所有的组件都可以在这个环境中无缝工作。接下来就如同周瑜在赤壁之战中熟练控制江面舰队那般要搭建Nginx,这是我们的战舰,为我们提供稳定的网络服务。

需要配置uwsgi。就像诸葛亮布置八阵图一样,uwsgi是我们的阵法,确保服务在面对用户请求时,能够根据规则稳定运行。接下来启动流程,这就像司马懿分析局势、发动攻势,掌控全局。

配置DNS服务器,这如同吕布在战场上舞动方天画戟,斩杀敌军,它是我们的强力武器,指引用户到达正确的网络目的地。最后如同三国各路诸侯各有特长,我们也需要掌握其他常用命令,以便在面对不同的情况时,能够灵活应对。

系统环境

先说明一下百度上能搜索到的内容我这里就不重复了,并吐槽一下超级繁琐的流程,这里简化到醉简单直接开始正题。

需要选择适当的操作系统和安装相应的编程环境。本教程以CentOS 7.x操作系统为例,使用Python 3.x和Django 3.x进行示范。

搭建Nginx

打开终端并执行执行命令yum install epel-release,添加Nginx官方存储库以确保获取最新版本的Nginx。

yum install epel-release

执行命令yum install nginx,安装Nginx。

yum install nginx

启动Nginx服务的常用命令。

  • systemctl start nginx:启动nginx服务
  • whereis nginx:找到nginx的安装路径
  • nginx:进入nginx目录
  • ./nginx -s reload:重新加载nginx服务,通常用于配置文件修改后的更新
  • systemctl status nginx:查看nginx服务当前的运行状态
  • systemctl start/stop/enable/disable nginx:这是一组命令,用于启动/停止/nginx服务,或设置其是否在开机时自动启动
# 直接启动
systemctl start nginx

# 查找目录并进入nginx目录启动
whereis nginx
nginx
# 重新加载
./nginx -s reload

# 查看nginx的状态
systemctl status nginx 
 
# 启动/关闭/设置开机启动/禁止开机启动
systemctl start/stop/enable/disable nginx 

安装完成后,可以通过浏览器打开服务器的IP地址(如xxx.xxx.xxx.xxx)来验证Nginx服务是否正常启动。

配置uwsgi

uWSGI是一个Web服务器,可以与Nginx配合使用来部署Python应用程序。默认已经安装好python3,执行命令pip3 install uwsgi安装uWSGI。

pip3 install uwsgi

执行命令ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi,建立软链接否则会报错 [uwsgi: command not found]

ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

接下来创建配置文件。对于每个项目可以创建一个独立的配置文件,也可以尝试将所有配置集中在一起。这里将为每个项目创建一个独立的配置文件夹。

  • 在项目目录中创建一个名为conf的文件夹。
  • conf文件夹中创建nginx.conf文件,用于配置Nginx服务器以将请求转发到uWSGI服务器。

在这里插入图片描述
把刚创建好的conf文件夹中创建nginx.conf,配置Nginx服务器以转发请求到uWSGI服务器。

  • listen 80; :监听80端口,这是HTTP的默认端口。
  • server_name :定义服务器的名称,也就是你购买的域名。
  • access_log :定义成功访问的日志存放位置。
  • error_log :定义访问失败日志的存放位置。
  • location / { ... } :定义主URL(“/”)的处理方式,这里使用了uwsgi进行处理,传递请求到uwsgi服务。
  • include uwsgi_params; :包含了uwsgi的参数设置。
  • uwsgi_pass 127.0.0.1:自定义端口号; :将请求转发到uwsgi服务,这里的端口号需要和Django运行时的端口一致。
  • location /static/ { ... } :处理静态文件URL(“/static/”)的请求,将其映射到项目目录下的static文件夹。
  • location /media/ { ... } :处理媒体文件URL(“/media/”)的请求,将其映射到项目目录下的media文件夹。
# nginx.conf 配置

server {
    listen       80; # 默认选80,为了是不希望浏览器中出现端口号
    server_name   你自定义的前缀.你购买的域名.你的域名后缀; # 这个地方是你访问这个网址进行项目浏览

    access_log /Django/你的项目/conf/access.log; # 存放访问成功日志
    error_log /Django/你的项目/conf/error.log; # 存放访问失败日志

    location / {
        include uwsgi_params;  # 这个默认不要动
        uwsgi_pass 127.0.0.1:自定义端口号;  # 这个端口号和runsever 0.0.0.0:端口号一样,这个要记住后面有用。
    }
    location /static/ {  # 配置各类文件比如static
        alias /你的项目目录/static/;
    }
    location /media/ {   # 配置各类文件比如media
        alias /你的项目目录/media/;
    }
}

把刚创建好的conf文件夹中创建uwsgi.ini用于设置uWSGI服务器。在uwsgi.ini文件中指定项目路径和Python虚拟环境路径。

  • [uwsgi]:这是配置的开始,指定我们正在为uwsgi进行配置。
  • master = true:这意味着启用了uWSGI的master模式。
  • processes = 4:这里设置uWSGI的工作进程数为4,你可以根据需要调整。
  • chdir = /你的项目名称,注意没有最后的"/":这是你的项目目录,应替换为实际项目路径。
  • module = 你的项目名称.wsgi:application:这定义了WSGI应用程序的位置,应该替换为你的实际项目名和WSGI应用对象。
  • socket = 127.0.0.1:自定义端口号:这是uWSGI服务绑定的IP地址和端口,地址为本机(127.0.0.1),端口号应替换为你自定义的端口。
  • logto = /你的项目名称/conf/uwsgi.log:这是uWSGI的日志文件的位置,应替换为实际的日志文件路径。
  • pidfile = /你的项目名称/conf/uwsgi.pid:这是uWSGI的pid文件的位置,通常用于存储主进程的PID,应替换为实际的pid文件路径。
# uwsgi.ini配置

[uwsgi]
# 守护进程
master = true  
# 进程个数
processes = 4  # 随意更改不能为0

# 项目地址
chdir = /你的项目名称,注意没有最后的"/"
# 指定uwsgi文件
module = 你的项目名称.wsgi:application  # 找到对应wsgi.py文件夹,你的项目名称就是这个文件夹的名字

# 和nginx通信地址:端口  nginx.conf 定义的端口号 要和uwsgi_pass  一样要不启动起来
socket = 127.0.0.1:自定义端口号

# 日志文件地址
logto = /你的项目名称/conf/uwsgi.log 

# pid文件
pidfile = /你的项目名称/conf/uwsgi.pid

如果是默认安装的话,打开目录 /ect/nginx 目录下找到 nginx.conf

  • pid /run/nginx.pid; 这行代码指定了Nginx的pid文件的路径,该文件存储了主进程的进程ID。当你在前面加上 #,这行代码就被注释掉了,意味着Nginx不会再创建或者查找这个pid文件。
  • include /你的项目/conf/*.conf; 这行代码表示包含你的项目中的所有 .conf 结尾的配置文件。Nginx 会读取这些配置文件中的指令。这些配置文件通常包含有关服务器的详细设置,如位置块,服务器名称,监听的端口等。这些设置被合并到了主配置文件中。
pid /run/nginx.pid;  # 这个注销掉
# 在include中添加你项目中的 nginx.conf文件
# 举例
include /你的项目/conf/*.conf;

在这里插入图片描述

启动流程

前提nginx已经启动了,然后进入你Django项目中的conf文件夹,执行命令uwsgi --ini uwsgi.ini启动服务。

uwsgi --ini uwsgi.ini

执行命令uwsgi --reload uwsgi.pid可以重载服务,每次更改Django目录里的任何文件需要重新加载才能生效,否则不生效。

uwsgi --reload uwsgi.pid


启动之后是这样证明启动成功了,然后重新加载nginx。通过命令whereis nginx找到nginx目录,然后执行命令cd /usr/sbin进入目录,执行命令./nginx -s reload重新加载nginx就可以了。

whereis nginx
cd /usr/sbin
./nginx -s reload 

启动成功后会在你的项目的conf文件夹中生成如下文件。
在这里插入图片描述

配置DNS服务器

需要在你的域名中添加你在在nginx.conf 设置的 server_name否则不管用。把你Django开的各种端口关了就行了,一个项目只能有一个端口。
在这里插入图片描述

其他常用命令

包括安装软件的命令,启动和停止服务的命令,配置文件修改的命令等。

  • whereis nginx:这个命令用于在系统中查找nginx的相关文件,例如二进制文件、源代码文件和帮助文件等。
  • cd /usr/sbin:更改当前工作目录到/usr/sbin,这个目录通常包含非必须的系统管理命令。
  • ./nginx -s reload:在当前目录下执行nginx命令,参数-s reload用于重新加载nginx的配置文件。
  • systemctl start nginx.service:使用systemctl命令启动名为nginx.service的服务。
  • systemctl stop nginx.service:使用systemctl命令停止名为nginx.service的服务。
  • systemctl reload nginx.service:使用systemctl命令重新加载名为nginx.service的服务。
  • systemctl status nginx.service:使用systemctl命令查看名为nginx.service的服务的状态。
  • uwsgi --ini uwsgi.ini:使用uwsgi命令和--ini参数启动一个uWSGI服务器,配置文件为uwsgi.ini
  • uwsgi --reload uwsgi.pid:使用uwsgi命令和--reload参数重新加载进程ID文件为uwsgi.pid的uWSGI服务器。
  • netstat --ntlp:使用netstat命令,--ntlp参数显示网络状态,包括协议、本地地址、外部地址、状态以及正在使用这些连接的进程。
whereis nginx
cd /usr/sbin
./nginx -s reload

systemctl start nginx.service
systemctl stop nginx.service
systemctl reload nginx.service
systemctl status nginx.service

uwsgi --ini uwsgi.ini

uwsgi --reload uwsgi.pid

netstat --ntlp
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr数据杨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值