Python web部署
内容简介
本篇介绍了使用uswgi与,gunicorn部署python web项目(flask框架)
为什么要使用nginx + gunicorn的组合,负载均衡的话gunicorn也可以做。主要是因为nginx可以做反向代理(多个服务共用一个端口),这种好处在只部署一个Web应用的时候不太容器体现,以及nginx对静态文件的支持比较好。
wsgi:gunciorn,uswgi
反向代理:nginx,apache
框架文件:flaskTest.py(flask)
方案一:nginx+gunicorn+flask
方案二:nginx+uwsgi+flask
具体内容
flaskText.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return 'ok'
if __name__=='__main__':
app.run('ip', 80)
gunicorn
两种启动方式
命令行启动
gunicorn -w 2 -b :80 flaskTest:app
配置文件启动
配置文件:gunicorn.conf.py
import multiprocessing
import os
import logging
import logging.handlers
from logging.handlers import WatchedFileHandler
bind = "127.0.0.1:80"
workers = workers = multiprocessing.cpu_count() * 2 + 1 #进程数
threads = 2 #指定每个进程开启的线程数
backlog = 512 #监听队列
BASE_DIR = os.path.abspath(os.path.dirname(__file__))
print('----------------')
# 日志配置
loglevel = 'info' #日志级别,这个日志级别指的是错误日志的级别,而访问日志的级别无法设置
access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"' #设置gunicorn访问日志格式,错误日志无法设置
accesslog = os.path.join(BASE_DIR, "log/gunicorn_access.log") #访问日志文件
errorlog = os.path.join(BASE_DIR, "log/gunicorn_error.log") #错误日志文件
print('--------------------------------------------------')
配置完配置文件后启动
gunciorn -c gunicorn.conf.py flaskTest:app
uWsgi
两种启动方式
直接启动
uwsgi --socket 127.0.0.1:80 --protocol=http -p 3 -w flasktext:app
配置文件启动 uwsgi.ini
[uwsgi]
http=:80
wsgi-file=/root/flasktest/flasktext.py
callable=app
processes=4
threads=2
启动命令
uwsgi --ini ./uwsgi.ini
停止命令
pkill -f -9 uwsgi
Supervisor
Supervisor是用Python开发的一套通用的进程管理程序,能将一个普通的命令行进程变为后台daemon,并监控进程状态,异常退出时能自动重启。
原文地址:Supervisor使用详解 - 小学弟- - 博客园 (cnblogs.com)
supervisorctl status //查看所有进程的状态
supervisorctl stop es //停止es
supervisorctl start es //启动es
supervisorctl restart //重启es
supervisorctl update //配置文件修改后使用该命令加载新的配置
supervisorctl reload //重新启动配置中的所有程序
Supervisor安装过程遇到的问题:
使用supervisor进程管理命令之前先启动supervisord,否则程序报错。
使用命令supervisord -c /etc/supervisord.conf
启动。
nginx
常用命令:
nginx -s stop #停止nginx
nginx -s reload #重新加载nginx配置
nginx -s reopen #重新启动
nginx -s quit #退出nginx
配置反向代理与负载均衡
user comdev comdev;
worker_processes 10;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
#最大文件描述符
worker_rlimit_nofile 51200;
events
{
use epoll;
worker_connections 51200;
}
http
{
include mime.types;
default_type application/octet-stream;
keepalive_timeout 120;
tcp_nodelay on;
upstream flask_balance {
server 192.168.1.110:8080;
server 192.168.1.111:8080;
}
server
{
listen 80;
server_name 192.168.1.109;
location / {
proxy_pass http://flask_balance;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
}
部署SSL证书
本文来自博客园,作者:糖烤栗子&,转载请注明原文链接:https://www.cnblogs.com/grocerystore/p/15336035.html