本篇文章最初发表于 2018-01-26。
本文包含部署使用 python3 编写的 Django 代码到 Digital Ocean 的一般步骤,涉及到 git, pyvenv, mysql, pm2 等技术,对于 Django 部署具有一定的参考借鉴意义。
开始部署前,你需要准备一台远程服务器,一个域名,并且将这个域名 A 记录解析到这台远程服务器。
版本控制
使用 Git 作为版本控制工具。
新建一个 git 账户
1. 在远程服务器上执行
$ sudo adduser git
$ su git
$ cd
$ mkdir .ssh && chmod 700 .ssh
$ touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys
2. 在本地开发 mac 本上生成 ssh key
$ cd
$ ssh-keygen
3. 将本地生成的 ssh key pub 文件上传至远程服务器并添加到授权文件尾部
$ cd
$ cd .ssh
$ ssh-copy-id -i id_rsa.pub git@
在远程服务器新建一个 git 仓库
$ sudo mkdir -p /gitbase/
$ sudo chown -R git:git /gitbase
$ su git
$ cd /gitbase/
$ git init --bare
提交本地代码到远程 git 服务器
$ cd ~/projects/
$ git init
$ git add .
$ git commit -m 'first commit.'
$ git remote add origin git@:/gitbase/
$ git push origin master
从远程 git 服务器拉取代码到远程服务器发布目录
$ sudo mkdir -p /deploy/
$ sudo chown -R : /deploy/
$ cd /deploy/
$ git clone git@:/gitbase/ .
替换上述的
和
为实际的用户名和远程服务器域名,下同。也可使用 gitee来作为版本控制服务器。更多可参考Git on the Server
配置 Django 运行环境
使用 pyvenv 来管理 python3 的运行环境,python2 的代码可以使用 python3 的lib2to3 模块工具来转义成 python3 代码。
$ python3 -m lib2to3 -w
使用 python3 的运行环境
$ cd
$ python3 -m venv py3env
$ source py3env/bin/activate
$ cd /deploy/
$ pip install -r requirements.txt
测试代码是否能正常运行,切换到项目根目录,并执行
$ python manage.py migrate
$ python manage.py createsuperuser
$ curl -i localhost:8000
安装并配置 mysql-server
安装 MySQL
$ sudo apt-get install mysql-client mysql-server
开启 mysql-server 远程访问
$ mysql -uroot -p yourpass
mysql> grant all on *.* to user_name@'%' identified by 'user_password';
找到 bind-address = 127.0.0.1 这一行,我们将它注释掉。
$ sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
确保 3306 端口的开启状态
$ sudo netstat -an | grep 3306
重启 mysql 服务
$ sudo service mysql restart
想了解更多可以参考Ubuntu 下开启 Mysql 远程访问的方法。
同步表接口和数据到远程服务器
使用 mysql 远程用户名和密码将备份的数据传输到远程服务器,可以直接使用 mysql 命令行,也可以使用可视化的 mysql 管理工具,例如 workbench、HeidiSQL、navicat、Sequel 等。
使用 pm2 部署 Django 代码
安装 node 和 pm2
从 node 官网下载 node linux 平台的可运行包,并利用 npm 安装 pm2。
$ cd
$ wget https://nodejs.org/dist/v8.9.4/node-v8.9.4-linux-x64.tar.xz
$ xz -d node-v8.9.4-linux-x64.tar.xz
$ tar -xf node-v8.9.4-linux-x64.tar
$ cd node-v8.9.4-linux-x64
$ sudo cp -r {bin,include,lib,share} /usr
$ npm i -g pm2
配置 pm2 运行参数
切换到项目根目录 /deploy/
,然后执行
$ touch process.yml
$ vim process.yml
将如下配置保存为 process.yml
apps:
- name: mysite
script: manage.py
args: ['runserver', '0.0.0.0:8000']
cwd: .
interpreter: ~/py3env/bin/python3
运行 pm2
$ pm2 start process.yml
查看 pm2 的运行结果
$ pm2 status
测试网站是否能访问
$ curl -i localhost:8000
使用 nginx 反向代理
确认 8000 和 80 端口开启后,然后再本地测试远程站点是否可以访问,若不能访问,则排查具体原因。继续使用nginx 来反向代理远程服务器上的 http服务,将内部站点端口映射到服务器的 80 端口,将相应域名的根目录映射为内部站点的子目录,以及加载静态资源文件等实现。具体可以参考网上文档,本文不再赘述。