用flask开发了服务端的api,过程中遇到了写坑,记录部署上服务器的过程,以供后续使用。
安装python3.6
本身服务器只安装了python2,我需要安装python3,所以就下载安装python3.6,不能去动已安装的python2.X
1.下载 wget https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tar.xz2. 解压 tar xvf Python-3.6.6.tar.xz3.编译安装 进入目录 ./configure make && make install python3源码编译已经自带pip3
创建原生虚拟环境
也可以不用虚拟环境,如不用则跳过这步
cd /opt/app_server/your_project_name python3 -m venv <venv_name># 比如: python3 -m venv test_venv# 创建成功后,就会创建一个test_venv目录,该目录下就会有基础的python3文件# 最后激活虚拟环境:source test_venv/bin/activate# 激活成功后,会在控制台中显示虚拟环境的名称。
安装项目中需要的python 模块
1.安装模块
# 先生成项目需要的模块:我这使用pipreqs,如果没有安装先安装: pip3 install pipreqs# 这个工具的好处是可以通过对项目目录的扫描,自动发现使用了那些类库,自动生成依赖清单。缺点是可能会有些偏差,需要检查并自己调整下。# 进入本地项目目录运行:pipreqs ./# 生成requirements.txt文件# 把requirements.txt文件放到服务器上pip3 install -r requirements.txt # 安装相应模块
2. 安装cx_Oracle
# 项目中需要连接oracle数据库,所以要安装cx_Oracle:pip3 install cx_Oracle# 安装时会检查系统中Oracle Client libraries的配置,如果没配置则会报错。# 所以需要先配置Oracle Client libraries:具体可见https://oracle.github.io/odpi/doc/installation.html#linux# 配置完后,安装不会报错。要注意:下载的cx_Oracle安装文件一定要跟pyhton的位数和版本一致,pyhton的位数最好是跟系统位数一致。
安装配置测试Gunicorn
1. 安装gunicorn
# 安装gunicornpip3 install gunicorn# 等待安装完成# 创建gunicorn存放日志文件夹,我这创建在项目目录下,方便查找sudo mkdir /opt/app_server/your_project_name/logs# 更改权限sudo chmod -R 777 /opt/app_server/your_project_name/logs
2.测试gunicorn
# 这个时候其实已经可以运行了,进入项目路径下,运行:gunicorn -b 0.0.0.0:8000 run:app# run是flask的启动python文件,app则是flask应用程序实例 # 通过gunicorn -h可以看到gunicorn有非常多的配置项
3.创建gunicorn配置文件
配置文件的配置详解可以见:https://blog.csdn.net/y472360651/article/details/78538188
# -*- coding: utf-8 -*-# 为了更好的管理gunicorn,通常会写个config文件,在项目目录下创建gunicorn_conf.py文件,内容如下import osimport multiprocessing# 获取当前该配置文件的绝对路径。gunicorn的配置文件是python文件,所以可以直接写python代码path_of_current_file = os.path.abspath(__file__) path_of_current_dir = os.path.split(path_of_current_file)[0] chdir = path_of_current_dir#workers = multiprocessing.cpu_count() * 2 + 1 # 可以理解为进程数,会自动分配到你机器上的多CPU,完成简单并行化workers = 1 # 我这里不用多进程worker_class = 'sync' # 默认的worker的类型,如何选择见:[http://docs](http://docs).[gunicorn.org/en/stable/design.html#choosing-a-worker-type](http://gunicorn.org/en/stable/design.html#choosing-a-worker-type)bind = '0.0.0.0:18088' # 服务使用的端口pidfile = '%s/gunicorn.pid' % path_of_current_dir # 存放Gunicorn进程pid的位置,便于跟踪accesslog = '%s/logs/gunicorn_access.log' % path_of_current_dir # 存放访问日志的位置,注意首先需要存在logs文件夹,Gunicorn才可自动创建log文件errorlog = '%s/logs/gunicorn_error.log' % path_of_current_dir # 存放错误日志的位置,可与访问日志相同reload = True # 如果应用的代码有变动,work将会自动重启,适用于开发阶段daemon = False # 是否后台运行debug = Falsetimeout = 5 # server端的请求超时秒数loglevel = 'error'
4.用gunicorn配置文件启动
gunicorn run:app -c your_path/gunicorn_conf.conf# 可以看看日志是否启动,尝试访问看是否成功。
5.重启/关闭gunicorn进程
查看Gunicorn进程
pstree -ap|grep gunicorn
重启Gunicorn任务
kill -HUP 7865
关闭Gunicorn任务
kill -9 7862
安装配置supervisor做守护进程
虽然gunicorn在配置了daemon参数为True后,就是控制面板关闭后,进程也不会退出,但不会出错后自动重启等操作。所以还是需要使用supervisor做后台守护。注意,如果要用supervisor管理gunicorn的,gunicorn的配置文件中一定要把daemon设置为False,如果配置daemon = True的话supervisor启动就会报错。所以但凡用supervisor管理的话,需要将守护进程模式改掉。
# 退出虚拟环境deactivate
1.如果服务器中没有安装supervisor,先进行安装
# yum的方式# supervisor没有发布在标准的CentOS源,需要安装epel源。# 这种方式安装的可能不是最新版本,但比较方便,安装完成之后,配置文件会自动帮你生成。# 还有个问题,我发现用yum安装的老版本(2.x的版本)配置文件里没有[include]选项,手动添加也没用,不知道是不是我没配置好。sudo yum install supervisor # 我这使用easy_install的方式安装easy_install supervisor # 安装完后是没有配置文件的,需要手动添加echo_supervisord_conf > /etc/supervisord.conf # 这里添加好的配置文件里有[include]选项,只是被注释了。
作者:GREG蓝天
链接:https://www.jianshu.com/p/6e288ed9279f