Ubuntu下python项目部署(uWSGI、nginx)环境搭建

服务器环境配置

  • 在本地的虚拟环境中,项目根目录下,执行命令收集所有包
pip freeze > plist.txt
  • 安装并创建虚拟环境
  • 在虚拟环境上安装所有需要的包
workon [虚拟环境名称]
pip install -r plist.txt
  • 更改settings.py文件

DEBUG = False

ALLOW_HOSTS=['*',]表示可以访问服务器的ip

此时启动服务器,运行正常,但是静态文件无法加载

WSGI简介

  • python manage.py runserver:这是一款适合开发阶段使用的服务器,不适合运行在真实的生产环境中
  • 在生产环境中使用WSGI:是Python应用程序或框架和Web服务器之间的一种接口
  • WSGI没有官方的实现, 因为WSGI更像一个协议,只要遵照这些协议,WSGI应用(Application)都可以在任何服务器(Server)上运行
  • 命令django-admin startproject会生成一个简单的wsgi.py文件,确定了settings、application对象
  • application对象:在Python模块中使用application对象与应用服务器交互
  • settings模块:Django需要导入settings模块,这里是应用定义的地方
  • 此处的服务器是一个软件,可以监听网卡端口、遵从网络层传输协议,收发http协议级别的数据

uWSGI

uWSGI实现了WSGI的所有接口,是一个快速、自我修复、开发人员和系统管理员友好的服务器

  • 安装uWSGI
pip install uwsgi
  • 配置uWSGI,在项目根目录下新建文件uwsgi.ini,编写如下配置
[uwsgi]
socket=外网ip:端口(使用nginx连接时,使用socket)
http=外网ip:端口(直接做web服务器,使用http)
chdir=项目根目录
wsgi-file=项目中wsgi.py文件的目录,相对于项目根目录
processes=4
threads=2
master=True
pidfile=uwsgi.pid
daemonize=uswgi.log

  • 启动:uwsgi --ini uwsgi.ini
  • 停止:uwsgi --stop uwsgi.pid
  • 重启:uwsgi --reload uwsgi.pid

uwsgi的启停需进入该文件目录下执行

此时查看网站运行情况,运行正常,但是静态文件无法加载

(一)nginx(下载压缩文件安装)

  • 使用nginx的作用
  • 负载均衡:多台服务器轮流处理请求
  • 反射代理:隐藏真实服务器
  • 实现构架:客户端请求nginx,再由nginx请求uwsgi,运行django框架下的python代码
  • nginx+uwsgi也可以用于其它框架的python web代码,不限于django
  • 到官网下载nginx压缩文件或通过命令安装

下载压缩文件安装:

解压缩:
tar zxvf nginx-1.6.3.tar.gz
进入nginx-1.6.3目录依次执行如下命令进行安装:
./configure
make
sudo make install
  • 默认安装到/usr/local/nginx目录,进入此目录执行命令
  • 查看版本:sudo sbin/nginx -v
  • 启动:sudo sbin/nginx
  • 停止:sudo sbin/nginx -s stop
  • 重启:sudo sbin/nginx -s reload
  • 通过浏览器查看nginx运行结果
  • 指向uwsgi项目:编辑conf/nginx.conf文件
sudo conf/nginx.conf
在server下添加新的location项,指向uwsgi的ip与端口:
server {
 listen 127.0.0.1:80 default_server;
location / {
 include uwsgi_params;
 uwsgi_pass 127.0.0.1:8000;(uwsgi的ip与端口)
}
  • 重启nginx、uwsgi

在浏览器中查看项目,发现静态文件加载不正常,接下来解决静态文件的问题

(二)nginx(通过命令安装

命令安装

sudo apt-get install nginx
  • 默认安装到/etc/nginx目录
  • 查看版本:sudo /usr/sbin/nginx -v
  • 启动:sudo /usr/sbin/nginx
  • 停止:sudo /usr/sbin/nginx -s stop
  • 重启:sudo /usr/sbin/nginx -s reload
  • 编辑 etc/nginx/sites-enabled/default文件
在server下添加新的location项,指向uwsgi的ip与端口:
server {
 listen 127.0.0.1:80 default_server;
location / {
 include uwsgi_params;
 uwsgi_pass 127.0.0.1:8000;(uwsgi的ip与端口)
}

静态文件处理

  • 所有的静态文件都会由nginx处理,不会将请求转到uwsgi
  • 配置nginx的静态项,打开conf/nginx.conf文件,找到server,添加新location
location /static {
 alias /var/www/test/static/;
}
  • 在服务器上创建目录结构“/var/www/test/”
  • 修改目录权限
sudo chmod 777 /var/www/test
  • 创建static目录,注意顺序是先分配权限,再创建目录
mkdir static
  • 最终目录结构如下:
/var/www/test/static
  • 修改settings.py文件
STATIC_ROOT='/var/www/test/static/'
STATIC_URL='/static/'
  • 执行:python manage.py collectstatic
  • 会把所有静态文件传到:'/var/www/test/static/'下
  • 重启nginx、uwsgi

至此项目部署久完成,访问正常,静态文件加载正常

更改访问IP

ifconfig--查看服务器IP

1、更改nginx配置文件

server {
 listen 服务器IP:80 default_server;
location / {
 include uwsgi_params;
 uwsgi_pass 服务器IP:端口;
}

2、更改uwsgi.ini

[uwsgi]
socket=服务器IP:端口
...

3、重启nginx、uWSGI

4、访问服务器IP:端口

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uWSGINginx是一种常见的Flask应用程序部署组合。uWSGI是一种Web服务器,它可以在后台运行Python应用程序,并提供了许多高级功能,如负载均衡、缓存、网关接口等。Nginx是一种反向代理服务器,它可以将传入的请求转发给uWSGI服务器,并负责处理静态文件、SSL加密等。 下面是一些简单的步骤,可以帮助你使用uWSGINginx部署Flask应用程序: 1. 安装uWSGINginx 在Linux系统上,你可以使用包管理器来安装uWSGINginx。例如,在Ubuntu上,你可以运行以下命令: ``` sudo apt-get update sudo apt-get install nginx uwsgi uwsgi-plugin-python3 ``` 2. 创建Flask应用程序 在你的项目目录中创建一个名为`app.py`的文件,并编写Flask应用程序代码。例如: ```python from flask import Flask app = Flask(__name__) @app.route('/') def hello(): return 'Hello, World!' ``` 3. 创建uWSGI配置文件 在你的项目目录中创建一个名为`uwsgi.ini`的文件,并编写uWSGI配置。例如: ```ini [uwsgi] module = app callable = app master = true processes = 4 socket = /tmp/uwsgi.sock chmod-socket = 666 vacuum = true die-on-term = true ``` 其中,`module`参数指定了Flask应用程序的Python模块名,`callable`参数指定了Flask应用程序的实例名。`socket`参数指定了uWSGI服务器监听的Unix套接字路径,`processes`参数指定了uWSGI服务器的工作进程数。 4. 测试uWSGI服务器 在命令行中,进入你的项目目录,并运行以下命令启动uWSGI服务器: ``` uwsgi --ini uwsgi.ini ``` 如果一切正常,你应该能够通过访问Unix套接字路径来测试uWSGI服务器: ``` curl http://localhost/tmp/uwsgi.sock ``` 你应该看到Flask应用程序的输出。 5. 创建Nginx配置文件 在Nginx配置文件中添加以下内容: ``` server { listen 80; server_name yourdomain.com; location / { include uwsgi_params; uwsgi_pass unix:///tmp/uwsgi.sock; } } ``` 其中,`listen`参数指定了Nginx服务器监听的端口和IP地址,`server_name`参数指定了该虚拟主机的域名或IP地址。`location`块指定了请求转发规则,`uwsgi_pass`参数指定了uWSGI服务器监听的Unix套接字路径。 6. 启动Nginx服务器 在命令行中,运行以下命令启动Nginx服务器: ``` sudo service nginx start ``` 如果一切正常,你应该能够通过访问你的域名或IP地址来访问Flask应用程序。 注意:如果你使用的是Ubuntu 18.04或更高版本,你需要将Nginx配置文件中的`include uwsgi_params;`改为`include /etc/nginx/uwsgi_params;`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值