发布 Django 到 Digital

发布时间:2019-10-15 09:05:10编辑:auto阅读(2587)

    本篇文章最初发表于 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@<servername.com>

    在远程服务器新建一个 git 仓库

    $ sudo mkdir -p /gitbase/<projectname>
    $ sudo chown -R git:git /gitbase
    $ su git
    $ cd /gitbase/<projectname>
    $ git init --bare

    提交本地代码到远程 git 服务器

    $ cd ~/projects/<projectname>
    $ git init
    $ git add .
    $ git commit -m 'first commit.'
    $ git remote add origin git@<servername.com>:/gitbase/<projectname>
    $ git push origin master

    从远程 git 服务器拉取代码到远程服务器发布目录

    $ sudo mkdir -p /deploy/<projectname>
    $ sudo chown -R <user>:<user> /deploy/<projectname>
    $ cd /deploy/<projectname>
    $ git clone git@<servername.com>:/gitbase/<projectname> .

    替换上述的 <user><servername.com>为实际的用户名和远程服务器域名,下同。也可使用 gitee来作为版本控制服务器。更多可参考Git on the Server

    配置 Django 运行环境

    使用 pyvenv 来管理 python3 的运行环境,python2 的代码可以使用 python3 的lib2to3 模块工具来转义成 python3 代码。

    $ python3 -m lib2to3 -w <mycode.py>

    使用 python3 的运行环境

    $ cd
    $ python3 -m venv py3env
    $ source py3env/bin/activate
    $ cd /deploy/<projectname>
    $ 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/<projectname>,然后执行

    $ 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 端口,将相应域名的根目录映射为内部站点的子目录,以及加载静态资源文件等实现。具体可以参考网上文档,本文不再赘述。

关键字