zoukankan      html  css  js  c++  java
  • django+uwsgi+nginx阿里云服务器部署

    一.环境介绍:
    (1)阿里云cms(ubumtu18.0.1)
    (2) git
    (3)mysql5.7
    (4)python
    (5) uwsgi
    (6) nginx
    (7)django2.0
    二:环境配置:
    1.安装前准备工作:
    (1)因为阿里云服务器安全要求比较高,因此,需要登录后台服务器,去安全组设置开放接口,
    需要开放3306(数据库),22(22)ssh后续连接,80(http)服务,此外打开3000-9000端口。
    (2)开启FTP服务,方便后续上传文件和安装包。
    2.git安装以及相关设置

    sudo apt-get install git

    2.1文件保存到github上。
    (1)注册github账户,同时下载bendigit客户端
    (2)在git客户端做基本配置,自己的名字和邮箱:
    git config --global user.name "yourname"
    git config --global user.email "youremail"
    (3)二、生成SSH密钥过程:
    1.查看是否已经有了ssh密钥:cd ~/.ssh如果没有密钥则不会有此文件夹,有则备份删除

    2.生成密钥:$ ssh-keygen -t rsa -C “yourenail”按3个回车,密码为空。可以看到如下内容:
    “Your identification has been saved in /home/tekkub/.ssh/id_rsa.
    Your public key has been saved in /home/tekkub/.ssh/id_rsa.pub.
    The key fingerprint is:………………最后得到了两个文件:id_rsa和id_rsa.pub”
    文件在用户/users/username/.ssh下。
    3.登录github,点击settings,添加密钥到ssh:ssh-add,添加的是“id_rsa.pub”里面的公钥。
    5.测试:ssh -Tgit@github.com,出现如下内容说明测试连接成功:

    “The authenticity of host ‘github.com (207.97.227.239)’ can’t be established.RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.Are you sure you want to continue connecting (yes/no)? yesWarning: Permanently added ‘github.com,207.97.227.239′ (RSA) to the list of known hosts.ERROR: Hi tekkub! You’ve successfully authenticated, but GitHub does not provide shell accessConnection to github.com closed.”

    git安装成功

    2.2搭建自己的git服务器:
    (1)创建git用户和权限:
    添加用户:adduser git
    修改权限:vi /etc/passwd
    找到文件:git:x:1001:1001:,,,:/home/git:/bin/bash做修改如下:
    git:x:1001:1001:,,,:/home/git:/usr/bin/git-shel
    (2)创建git公钥匙:
    同上述步骤3.1步骤的1和2.复制id_rsa.pub内容,回到服务器操作:
    $ cd /home/git/
    $ mkdir .ssh
    $ cd .ssh
    $ vi authorized_keys
    需要先检测是否有.ssh目录,将公匙保存在文件里,然后退出。
    (3)测试,创建一个仓库,常识获取:
    $ cd /var
    $ chown -R git:git git
    $chmod 777 git
    $ cd git
    接下来,我们用git命令初始化一个仓库:
    $ git init --bare arepoforyourproject.git
    回到你本地的电脑上,我们通过克隆来试试仓库是否可以使用:

    $ git clone git@10.0.0.121:/var/git/arepoforyourproject.git
    然后会提示你输入git的密码(创建用户时的密码),输入进去,

    git服务器已经OK了。

    3.数据库安装:
    sudo apt-get install mysql
    sudo apt-get update
    sudo apt-get install mysql-server
    sudo apt-get install mysql-client (安装过程中需要设置密码:123456)
    sudo apt-get install libmysqlclient-dev
    安装完成以后,输入:mysql -uroot -p 回车 输入密码看能否进行正常的本地登录。
    如果无法登陆(确认服务器打开了3306端口):
    3.1修改mysql监听IP:
    vim /etc/mysql/mysql.conf.d/mysqld.cnf
    找到bind-address,如果监听固定远程IP,则改成远程主机IP,
    若监听所有IP,则改成0.0.0.0或者注释bind-address:
    service mysql restart
    查看MySQL监听地址:
    netstat -ano | grep 3306,看到:
    tcp 0 0.0.0:3306 0.0.0.01:*(配置监听所有人)
    监听成功
    3.2远程登录实现:
    grant all privileges on *.* to '用户'@'ip' identified by '密码' with grant option;
    flush privileges;
    第一句语句语句中,*.*代表所有库表,若想给予所有IP权限, ”ip”写成“%”,所以第一句sql的意思是给予来自所有IP地址的通过“用户”, “密码”登录的用户对所有库表的所有操作权限。 第二句sql,刷新权限。
    service mysql restart
    然后同样重启MySQL生效。
    3.3 mysql -u ‘user’ -p,然后输入密码就可以登陆成功。

    mysql安装成功

    4.python安装:
    系统自带了2.7版本,以及3.6.7.项目使用3.6.2,因此,采用编译安装3.6.2版本的python:
    (1)依赖库的预安装:
    sudo apt-get install gcc make zlib1g-dev
    sudo apt-get install libbz2-dev
    sudo apt-get install libsqlite3-dev
    sudo apt-get install python3-dev libxml2-dev libffi-dev libssl-dev libxslt1-dev
    (2)安装:
    获取python包:
    wget https://www.python.org/ftp/python/3.6.2/Python-3.6.2.tar.xz
    或者下载本地,通过ftp上传服务器
    解压:
    tar xJf Python-3.6.1.tar.xz
    进入目录配置:
    ./configure --prefix=/usr/python3
    编译:
    make
    安装:sudo -H make install
    建立链接:
    ln -s /usr/python/bin/python3 /usr/bin/python3
    python3安装成功。

    4.1虚拟环境建立:
    apt-get install virtaulenv
    apt-get install virtualenvwrapper

    安装完virtualenvwrapper后,还需要配置virtualenvwrapper的环境变量。

    首先通过which virtualenvwrapper.sh命令查看virtualenvwrapper.sh文件所在的路径。
    在当前用户目录下创建.virtualenv文件夹,用来存放所有的虚拟环境目录。
    在当前用户目录下编辑.bashrc文件,添加以下代码:

    export WORKON_HOME=$HOME/.virtualenvs
    source /usr/local/bin/virtualenvwrapper.sh
    然后退出bashrc文件,输入命令source ~/.bashrc。

    5.安装uwsgi:
    pip3 install uwsgi

    6.安装nginx:
    apt-get install nginx

    三.部署自己的项目到服务器上:
    本地工作:
    (1)确认项目没有bug。
    (2)用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中,方便部署的时候安装。
    (3)项目上传到github或者自己服务器:
    git init 初始化仓库
    git add . 批量跟踪仓库文件
    git commit -m '提交说明'(必须要写)
    创建一个远程仓库:
    git remote add origin xxx.git (仓库地址)
    将本地仓库中的代码提交到远程服务器的master分支上
    git push -u origin master(首次提交需要加-u)
    服务器端工作:
    (1)mkvirtualenv --python=/usr/bin/python3 xfz-env 新建虚拟环境
    (2)进入虚拟环境:
    git init
    创建一个远程仓库:
    git remote add origin xxx.git (仓库地址)
    git pull origin master

    pip install -r requirements.txt
    (3)进入mysql数据库中,创建好项目的数据库。

    执行python manage.py makemigrations/migrate将模型映射到数据库中。

    执行python manage.py runserver 0.0.0.0:8000,然后在自己电脑上访问这个网站,确保没有BUG。

    在settings.py中的ALLOWED_HOST添加网站的域名或者ip地址。

    设置DEBUG=False,避免如果你的网站产生错误,而将错误信息暴漏给用户。

    在settings.py中配置STATIC_ROOT


    (4)执行git命令,更新到服务器上:
    当前目录下新建文件夹:STATIC_ROOT,并且执行python manage.py collectstatic
    执行python manage.py runserver 0.0.0.0:8000,然后在自己电脑上访问这个网站,确保没有BUG


    (5)当前目录下创建uwsgi,ini(修改项目路径,home,按照自己项目的路径):
    [uwsgi]

    # 必须全部为绝对路径
    # 项目的路径
    chdir = /srv/beike/xfz
    # Django的wsgi文件
    module = xfz.wsgi
    # Python虚拟环境的路径
    home = /root/.virtualenvs/xfz-env

    # 进程相关的设置
    # 主进程
    master = true
    # 最大数量的工作进程
    processes = 10

    http = :8000

    # 设置socket的权限
    chmod-socket = 666
    # 退出的时候是否清理环境
    vacuum = true

    daemonize = /var/log/xfz_uwsgi.log
    然后通过命令uwsgi --ini uwsgi.ini运行,确保没有错误。然后在浏览器中访问http://ip地址:8000,如果能够访问到页面(可能没有静态文件)说明uwsgi配置没有问题
    (6)在/etc/nginx/conf.d目录下,新建一个文件,叫做zhiliaoketang.conf(根据自己情况也可以叫其他名字,
    修改server 后的路径到自己的项目路径,server_name到自己的项目名):
    upstream zhiliaoketang {
    server unix:///srv/zhiliaoketang/zhiliaoketang.sock;
    }

    # 配置服务器
    server {
    # 监听的端口号
    listen 80;
    # 域名
    server_name 192.168.0.101;
    charset utf-8;

    # 最大的文件上传尺寸
    client_max_body_size 75M;

    # 静态文件访问的url
    location /static {
    # 静态文件地址
    alias /srv/zhiliaoketang/static_dist;
    }

    # 最后,发送所有非静态文件请求到django服务器
    location / {
    uwsgi_pass zhiliaoketang;
    # uwsgi_params文件地址
    include /etc/nginx/uwsgi_params;
    }
    }
    service nginx configtest,如果ok说明成功了
    service nginx restart
    在返回到项目目录,打开uwsgi:
    注释掉:
    “http = :8000”,并添加:
    “socket = srv/zhiliaoketang/zhiliaoketang.sock”(该内容需要与zhiliaoketang.conf下面的upstream
    中配置路径保持一致)。
    至此,整个配置完成。

    一个会写博客的程序员
  • 相关阅读:
    [react002] component基本用法
    [react001] 使用webpack自动构建react 项目
    [Elixir009]像GenServer一样用behaviour来规范接口
    [Elixir008]Nested Module里的动态函数调用方式
    [Elixir007] on_definition规范函数定义时的各种潜规则
    [Elixir006]CSV(Comma-separated values)处理
    [Elixir005] 查看指定数据的详细信息 i helper
    [Elixir004]通过环境变量(Environment Variables)来管理config
    [Elixir003] Mix Archives
    [Elixir002]节点启动后自动连接其它节点
  • 原文地址:https://www.cnblogs.com/znn041622/p/11145952.html
Copyright © 2011-2022 走看看