上线流程

时间:2019-09-16
本文章向大家介绍上线流程,主要包括上线流程使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Nginx+uwsgi+flask项目上线配置完整流程

2019-08-29 05:22:06 来源: 希希大队长 0


在这里我们使用一台完全新装的Linux的服务器做示例,从头开始所有装配

首先XSHELL连接远程服务器

服务器命令

管理员权限


1)以下所有的服务器命令均可以在管理员权限下执行,如果本就是根用户可忽略
>:sudo命令
配置终端
1)编辑配置文件
>: vim ~/.bash_profile

2)将原来内容全部删除掉
>: ggdG

3)进入编辑状态:填入下方两行
>: i

export PATH=$PATH:$HOME/bin
PS1='Path:\w\n>:'

4)退出编辑状态
>: esc

5)保存修改并退出
>: :wq

6)生效配置
>: source ~/.bash_profile
更新系统软件包
>:yum update -y
安装软件管理包和可能使用的依赖
>: yum -y groupinstall "Development tools"
>: yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel

安装的git

>:yum install git

安装Python3.6

1)前往用户根目录
>: cd ~

2)下载 或 上传 Python3.6.7
>: wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz
>: scp -r 本地Python-3.6.7.tar.xz ssh root@39.100.155.49:服务器路径
>: scp -r C:\source\Python-3.6.7.tar.xz ssh root@39.100.155.49:~

3)解压安装包
>: tar -xf Python-3.6.7.tar.xz

4)进入目标文件
>: cd Python-3.6.7

5)配置安装路径:/usr/local/python3
先按照依赖库
>:yum -y install gcc gcc-c++ autoconf automake
>:yum -y install zlib zlib-devel openssl openssl-devel pcre pcre-devel 
再配置
>: ./configure --prefix=/usr/local/python3
6)编译并安装
>: make && sudo make install
7)建立软连接:终端命令 python3,pip3
>: ln -s /usr/local/python3/bin/python3 /usr/bin/python3
>: ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3
8)删除安装包与文件:
>: rm -rf Python-3.6.7
>: rm -rf Python-3.6.7.tar.xz

安装虚拟环境:默认工作路径 ~/.virtualenvs

1)安装依赖
>: pip3 install virtualenv
>: pip3 install virtualenvwrapper

2)建立虚拟环境软连接
>: ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv

3)配置虚拟环境:填入下方内容
>: vim ~/.bash_profile

VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
source /usr/local/python3/bin/virtualenvwrapper.sh

4)退出编辑状态
>: esc

5)保存修改并退出
>: :wq

6)更新配置文件内容
>: source ~/.bash_profile

安装Mysql

1)前往用户根目录
>: cd ~

2)下载mysql57
>: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

3)安装mysql57
>: yum -y install mysql57-community-release-el7-10.noarch.rpm
>: yum -y install mysql-community-server

4)启动mysql57并查看启动状态
>: systemctl start mysqld.service
>: systemctl status mysqld.service

5)查看默认密码并登录
>: grep "password" /var/log/mysqld.log
>: mysql -uroot -p

6)修改密码
>: ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';



安装Redis

1)前往用户根目录
>: cd ~

2)下载redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz

3)解压安装包
>: tar -xf redis-5.0.5.tar.gz

4)进入目标文件
>: cd redis-5.0.5

5)编译环境
>: make

6)复制环境到指定路径完成安装
>: cp -r ~/redis-5.0.5 /usr/local/redis

7)配置redis可以后台启动:修改下方内容
>: vim /usr/local/redis/redis.conf

daemonize yes

8)完成配置修改
>: esc
>: :wq

9)建立软连接
>: ln -s /usr/local/redis/src/redis-server /usr/bin/redis-server
>: ln -s /usr/local/redis/src/redis-cli /usr/bin/redis-cli

10)后台运行redis
>: redis-server &
ctrl + c

11)测试redis环境
>: redis-cli
ctrl + c

12)关闭redis服务
>: pkill -f redis -9

安装uwsgi

1)在虚拟环境下安装,注意一定要在虚拟环境安装!!!!
当项目运行在虚拟环境时,用虚拟环境外的uwsgi无法正常启动项目!!!
pip3 install uwsgi

2)建立软连接
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

新建虚拟环境跑Django项目


1)创建虚拟环境
>: mkvirtualenv test_venv

2)安装依赖
>: pip install django

3)前往目标目录,创建项目工作目录,再进入
>: cd /home
>: mkdir project
>: cd project

4)创建Django项目,并进入
>: django-admin startproject test_site
>: cd test_site

5)完成项目配置:修改下方几行内容
>: vim /home/project/test_site/test_site/settings.py

ALLOWED_HOSTS = ['*']
6)跑原生服务
>: python3 manage.py runserver 0.0.0.0:80




安装Nginx

1)前往用户根目录
>: cd ~

2)下载nginx1.13.7
>: wget http://nginx.org/download/nginx-1.13.7.tar.gz

3)解压安装包
>: tar -xf nginx-1.13.7.tar.gz

4)进入目标文件
>: cd nginx-1.13.7

5)配置安装路径:/usr/local/nginx
>: ./configure --prefix=/usr/local/nginx
这里考虑安装https认证模块(上文未安装这个导致使用https协议保存):
>: ./configure --with-http_ssl_module
6)编译并安装 >: make && sudo make install 7)建立软连接:终端命令 nginx >: ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx 8)删除安装包与文件: >: rm -rf nginx-1.13.7 >: rm -rf nginx-1.13.7.tar.xz 9)测试Nginx环境,服务器运行nginx,本地访问服务器ip >: nginx >: 服务器绑定的域名 或 ip:80


Nginx命令

1)启动 >: nginx  
2)关闭nginx >: nginx -s stop  
3)重启nginx >: nginx -s reload  
4)查看端口,强行关闭 >: ps -aux|grep nginx >: kill <pid:进程编号>


查看8000端口占用 netstat -tunlp|grep 8000

Nginx & uwsgi 运行项目


1)在项目的虚拟环境安装uwsgi
>: workon test_venv
>: pip install uwsgi

2)项目根目录配置uwsgi:填入下方内容
>: vim /home/project/test_site/test_site.xml

<uwsgi>    
   <socket>127.0.0.1:9001</socket> <!-- 内部端口,自定义 --> 
   <pythonpath>/root/project/test_site/</pythonpath> <!-- 项目路径 -->
   <module>manage.py</module>  <!-- home为wsgi.py所在目录名--> 
   <callable>manage:manager</callable> <!-- 启动文件名:管理的执行app,如果是flask项目app.run(),这里写app就好 -->
   <master/>
   <memory-report/>
   <processes>4</processes> <!-- 进程数 -->     
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>



Django项目需要配置3)
3)完成项目配置:修改下方几行内容
>: vim /home/project/test_site/test_site/settings.py

DEBUG = False
ALLOWED_HOSTS = ['*']

4)去向Nginx配置目录,备份配置,完全更新配置:填入下方内容
>: cd /usr/local/nginx/conf
>: cp nginx.conf nginx.conf.bak
>: vim nginx.conf
>: ggdG
>: i

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 8000;
        server_name  127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1:8808;  # 端口要和uwsgi里配置的一样
           uwsgi_param UWSGI_SCRIPT test_site.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/test_site/; # 项目路径
        }
    }
}
      
5)启动uwsgi
>: uwsgi -x /home/project/test_site/test_site.xml

测试uwsgi --socket 0.0.0.0:5000 --protocol=http -p 3 -w manage(启动文件名):app(app)

ps:uwsgi -x /root/project/FlaskProject/FlaskProject.xml

6)启动nginx
>: nginx

7)浏览器测试:http://39.100.155.49/admin

8)关闭uwsgi所有进程
>: pkill -f uwsgi -9




配置前台项目(前后端分离项目需配置)

1)项目本地打包

2)上传
scp -r dist ssh root@47.92.32.216:~

3)
mv -r dist /home/html 

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 8000;
        server_name  127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1:8808;  # 端口要和uwsgi里配置的一样
           uwsgi_param UWSGI_SCRIPT test_site.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/test_site/; # 项目路径
        }
    }
    server {
        listen 80;
        server_name  127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
        charset utf-8;
        location / {
            root /home/html; #html访问路径
            index index.html; #html文件名称
        }
    }
}                                                                   



1、如果启动nginx报 404错误nginx ,项目下uwsgi.log没有更新错误  ,那就是nginx配置有问题

2、如果报错 invalid...server之类的,那就是项目运行报错,需要去检查项目下面的uwsgi.log日志

3、在配置nginx配置文件和uwsgi配置文件时往往uwsgi配置会容易出现问题,要理解xml内的配置含义

4、如果使用https协议配置nginx会有所不同,需要在nginx安装路径中的nginx.conf配置一段不同的内容

    并且还需要在项目根目录下配置一个配置文件,代码贴出如下


进入nginx原配置目录

>:cd /usr/local/nginx/conf  >:vim nginx.conf

清空原内容,加入下面示例代码:

events { 
    worker_connections  1024; 
} 
http { 
    include       mime.types; 
    default_type  application/octet-stream; 
    sendfile        on; 
    include /root/project/FlaskProject/*.conf;  # 将项目目录下的所有.conf文件导入 
  server { 
          listen 80 default_server; 
          server_name _; return 404; 
         } 
} 


项目根目录下新建 nginx.cinf


>: vim /root/project/test_site/nginx.conf

加入下面示例代码:

## 将HTTP请求全部重定向至HTTPS 
server { 
  listen       80; 
  server_name  dgfuture.cn;  #  
  charset utf-8; 
  access_log /root/project/mv-80.access.log; 
  error_log  /root/project/mv-80.error.log; 
  rewrite ^ http://dgfuture.cn; 
} 
server { 
  listen 443 ssl;
 server_name dgfuture.cn;
 root /root/project/FlaskProject/;#项目路径
 charset utf-8;
 ssl_certificate    /data/SSL/mv/1_mv.qianzhengkai.cn_bundle.crt;#.pem证书路径
 ssl_certificate_key  /data/SSL/mv/2_mv.qianzhengkai.cn.key;#.key证书路径
 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
 ssl_prefer_server_ciphers on;
 ssl_session_cache shared:SSL:10m;
 ssl_session_timeout 10m;
 error_page 497  https://$host$request_uri;
 location / {
 root html/www;
 include uwsgi_params;
 uwsgi_pass 127.0.0.1:9001;
 uwsgi_param UWSGI_SCRIPT manage.py;  # 项目执行入口,如果flask项目app被manager管理,这里填 manage:app
 uwsgi_param UWSGI_CHDIR /root/project/FlaskProject/;#项目路径 }
location /static/ {
 alias /root/project/FlaskProject/info/static/; #静态资源路径
 }
 access_log  /root/project/dgfuture.access.log;
 error_log  /root/project/dgfuture.error.log;
}

依据这个改吧改吧就问题不大了


django项目目录重构后的uwsgi配置和nginx配置参考

uwsgi.ini配置方式

在该文件路径下进入虚拟环境,通过配置文件启动uwsgi

启动命令:

uwsgi -i uwsgi.ini

/usr/local/nginx/conf/nginx.conf 文件配置  这里只展示了server部分


nginx重启命令:

nginx -s reload







收藏
登录发表你的评论
0条评论
 

原文地址:https://www.cnblogs.com/guanchao/p/11526556.html