python web应用部署_【简说Python WEB】Web应用部署

系统环境:Ubuntu 18.04.1 LTS

Python使用的是虚拟环境:virutalenv

Python的版本:Python 3.6.9

【简说Python WEB】Web应用部署

我们现在的演示都是Python WEB自带的工具,来验证我们的程序。但是生产环境下,不可能这样跑着。

一般简单的Python WEB应用,会应用到的服务中间件如下:

Nginx : WEB服务,作为WEB最前端的服务,可以作为反向代理和均衡负载使用。

Gunicorn : Python应用服务器

uWSGI :Python应用服务器,C语言编写,遵守uwsgi协议。

MySQL : 后端的数据存储服务

我们这里部署应用的是:Nginx,Gunicorn,MySQL

肯定还有朋友说,那么高负载,高并发,高性能,高可用呢?

这里就会有一个扩展。

应用层

Nginx的高可用,可能会有到Keepalived,Heartbeat。用于心跳线检测和故障转移使用。

负载均衡,可能会用到LVS,HAProxy

Nginx下可能挂载多个Python应用服务器(Gunicorn ), 常见的java web应用就是挂载多个tomcat服务

本质还是一样的,万变不离其宗。

缓存层

可能需要Redis和Memcached做缓存,而不是直接从数据库取,减少数据库的负载。

数据层

关系型数据库(MySQL,PG,Oracle)。NoSQL数据库(MongoDB)等。

数据库再延伸的话,可能还需要主从同步,分库分表。再把一部分读业务放到从库中,把一部分分析BI的业务放到

Greenplum。还有把一些事务性弱的业务,放到MongoDB中存储。

所以,任何一种架构,都是为需求服务的。不同的业务需求,延伸出来的架构就会不同。

跑火车了,言归正传。我们这里就是简单的WEB架构。Nginx+Gunicorn+MySQL。不用那么复杂的架构。

Gunicorn 的应用

1.安装Gunicorn

pip install gunicorn

2.Gunicorn的启动

(zsdpy1) $ gunicorn --workers=3 zsdblog:app -b 0.0.0.0:8000

[2020-03-26 13:52:19 +0800] [8682] [INFO] Starting gunicorn 20.0.4

[2020-03-26 13:52:19 +0800] [8682] [INFO] Listening at: http://0.0.0.0:8000 (8682)

[2020-03-26 13:52:19 +0800] [8682] [INFO] Using worker: sync

[2020-03-26 13:52:19 +0800] [8685] [INFO] Booting worker with pid: 8685

[2020-03-26 13:52:19 +0800] [8686] [INFO] Booting worker with pid: 8686

[2020-03-26 13:52:19 +0800] [8687] [INFO] Booting worker with pid: 8687

其中:

--workers代表启动的work进程,一般根据逻辑CPU的个数*2启动,

zsdblog:app 这里说明我是zsdblog.py的文件中,启动了名为app的application。所以这样启动python web服务。

-b 0.0.0.0:8000 代表绑定的IP和端口。

-D, --daemon 可选,可以以守护进程,放到后台执行

--access-logfile FILE 正常的输入访问日志设定

--error-logfile FILE, --log-file FILE 错误日志和标准日志文件输出地方

--log-level LEVEL 日志的级别,任何一个WEB服务器都有日志级别输出,方便调试程序。一般有debug,info

​ ,warning,error,critical日志级别。

以deamon的方式启动

gunicorn --workers=3 zsdblog:app -b 0.0.0.0:8000 -D

Nginx 的应用

Nginx作为一个高性能,高稳定性的web服务,被广泛应用。由于其C语言编写。配置简单,这次热部署。还有强大的反向代理和负载均衡功能。可以说在互联网领域,叱咤风云。

1.docker方式部署安装Nginx

1.1 拉去最新的docker nginx镜像

docker pull nginx:latest

1.2 查看本地镜像

root@zsd-virtual-machine:~# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

nginx latest 6678c7c2e56c 3 weeks ago 127MB

mysql latest 9b51d9275906 3 weeks ago 547MB

可以看到,我们有MySQL和Nginx镜像

1.3 运行Nginx容器

docker run --name nginx-zsd -p 80:80 -d nginx

其中:

--name nginx-zsd nginx-zsd代表我取的名字

-p 80:80 把容器内的80端口和虚拟机的80端口对应上。

-d nginx nginx服务在后台运行

1.4 .查看目前运行的容器

root@zsd-virtual-machine:~# docker container ls

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

d3c8f99c8df6 nginx "nginx -g 'daemon of…" 3 minutes ago Up 3 minutes 0.0.0.0:80->80/tcp nginx-zsd

1.5关闭和启动容器,如下:

root@zsd-virtual-machine:~# docker stop nginx-zsd

root@zsd-virtual-machine:~# docker start nginx-zsd

1.6删除容器

root@zsd-virtual-machine:/usr/local# docker stop nginx-zsd

nginx-zsd

root@zsd-virtual-machine:/usr/local# docker container rm nginx-zsd

nginx-zsd

1.7 拷贝容器中的配置文件

root@zsd-virtual-machine:/usr/local# docker cp nginx-zsd:/etc/nginx/nginx.conf /root/

1.8映射nginx的配置文件,可以本地目录配置

docker run --name nginx-zsd -p 80:80 -v /root/nginx.conf:/etc/nginx/nginx.conf -d nginx

1.9进入nginx容器

docker exec -it nginx-zsd bash

2.Nginx的文件配置

上述,可以看到我们把配置文件映射到了/root/nginx.conf。通过修改配置文件,达到定制化的效果:

添加upstream和server段

upstream Zfrontends {

server 127.0.0.1:8000;

}

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://Zfrontends;

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

}

}

重启nginx容器

docker restart nginx-zsd

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值