背景
sanic项目
阿里云Ubantu服务器
Gunicorn+Nginx部署
Python准备
1.安装python3.6
sudo apt-get update
sudo apt-get install software-properties-common
sudo add-apt-repository ppa:jonathonf/python-3.6
sudo apt-get update
sudo apt-get install python3.6
2.更改python快捷方式
查看python版本
pip --version
查看python命令指代的版本
cd /usr/bin
ls -l | grep python
删除python2.7快捷方式
sudo rm python
创建python3.6快捷方式,安装pip3
sudo ln -s python3.6m python
sudo apt-get install python-pip
3.创建python虚拟环境
安装Virtualenv
sudo pip install virtualenv
创建项目,修改权限
sudo mkdir /root/flowerdance
sudo chmod 777 /root/flowerdance
利用Xshell+Xftp本地项目传到阿里云
创建虚拟环境venv
mkvirtualenv -p python3 venv
virtualenv venv
进入虚拟环境
source venv/bin/activate
安装必要的库
pip install -r requirements.txt
Gunicorn
在虚拟环境下安装requirements.txt里的库时已经安装了,或者执行
pip install gunicorn
启动,我们在文件server.py中初始化了一个Sanic实例app
为了使用Gunicorn运行Sanic应用程序,我们需要使用sanic.worker.GunicornWorker作为Gunicorn的work-class参数
gunicorn server:app --bind 127.0.0.1:8000 --worker-class sanic.worker.GunicornWorker
参数上加-D后台运行
Nginx
安装
sudo apt-get install nginx
打开配置文件
vim /ext/nginx/sites-available/default
修改,如果有ssl证书,在这里开放443端口并写好ssl_*相关文件
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name www.xxxx.xxx;
listen 443 default_server;
listen [::]:443 ssl default_server;
# your ssl file
ssl_certificate /etc/nginx/cert/xxxxx.xxx.pem;
ssl_certificate_key /etc/nginx/cert/xxxxx.xxx.key;
ssl on;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
root /root/flowerdance
location / {
proxy_pass http://127.0.0.1:8000;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_cache_bypass $http_upgrade;
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命令
安装: sudo apt-get install nginx
启动:sudo service nginx start
重启:sudo service nginx restart
停止:sudo service nginx stop
测试:sudo service nginx configtest