项目上线

购买服务器

1
2
# 购买阿里云服务器
# 短期或是测试使用,创建 按量收费 服务器,可以随时删除,删除后不再计费,但要保证账户余额100元以上

连接服务器

1
2
3
4
5
1)账号
>: ssh root@39.98.144.221
2)密码
>: ********

服务器命令

管理员权限
1
2
1)以下所有的服务器命令均可以在管理员权限下执行
>: sudo 命令

  

配置终端
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
1)编辑配置文件
>: vim ~/.bash_profile
2)将原来内容全部删除掉
>: ggdG
3)进入编辑状态:填入下方两行
>: i
export PATH=$PATH:$HOME/bin
PS1='Path:w >:'
4)退出编辑状态
>: esc
5)保存修改并退出
>: :wq
6)生效配置
>: source ~/.bash_profile

重要

更新系统软件包
1
>: yum update -y
安装软件管理包和可能使用的依赖
1
2
>: yum -y groupinstall "Development tools"
>: yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel

安装Mysql

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
1)前往用户根目录
>: cd ~
2)下载mysql57
>: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
也可以本地上传,这条命令要在本地终端上执行
>: scp -r C:UsersdellDesktoppkgmysql57-community-release-el7-10.noarch.rpm root@39.98.144.221:~
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';
>: ALTER USER 'root'@'localhost' IDENTIFIED BY 'Owen1234?';

安装Redis

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
1)前往用户根目录
>: cd ~
2)下载redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz
>: scp -r C:UsersdellDesktoppkg edis-5.0.5.tar.gz root@39.98.144.221:~
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

安装Python3.6

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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.98.144.221:服务器路径
>: scp -r C:UsersdellDesktoppkgPython-3.6.7.tar.xz ssh root@39.98.144.221:~
 
3)解压安装包
>: tar -xf Python-3.6.7.tar.xz
 
4)进入目标文件
>: cd Python-3.6.7
 
5)配置安装路径:/usr/local/python3
>: ./configure --prefix=/usr/local/python3
 
6)编译并安装
>: make && sudo make install
 
7)建立软连接:终端命令 python3,pip3
>: ln -s /usr/local/python3/bin/python3.6 /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

配置pip源:阿里云不用配置,默认配置阿里源

1
2
3
4
5
6
7
8
9
10
11
12
1)创建pip配置路径
>: mkdir ~/.pip
 
2)进入目录编辑配置文件:填入下方内容
cd ~/.pip && vim pip.conf
 
[global]
index-url = http://pypi.douban.com/simple
[install]
use-mirrors =true
mirrors =http://pypi.douban.com/simple/
trusted-host =pypi.douban.com

安装uwsgi

1
2
3
4
5
1)在真实环境下安装
pip3 install uwsgi
 
2)建立软连接
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

安装虚拟环境

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
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
 
7)虚拟环境默认根目录:~/.virtualenvs

了解:服务器运行测试Django项目

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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 = ['*']
#DATABASES = {
#    'default': {
#        'ENGINE': 'django.db.backends.sqlite3',
#        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
#    }
#}
 
6)跑原生服务
>: python3 manage.py runserver 0.0.0.0:80

安装Nginx

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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
 
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
2
3
4
5
6
7
8
9
10
11
12
1)启动
>: nginx
 
2)关闭nginx
>: nginx -s stop
 
3)重启nginx
>: nginx -s reload
 
4)查看端口,强行关闭
>: ps -aux|grep nginx
>: kill <pid:进程编号>

了解:Nginx & uwsgi 运行Django

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
1)在项目的虚拟环境安装uwsgi
>: workon test_venv
>: pip install uwsgi
 
2)项目根目录配置uwsgi:填入下方内容
>: vim /home/project/test_site/test_site.xml
 
<uwsgi>   
   <socket>127.0.0.1:8808</socket> <!-- 内部端口,自定义 -->
   <chdir>/home/project/test_site/</chdir> <!-- 项目路径 -->           
   <module>test_site.wsgi</module>  <!-- test_site为wsgi.py所在目录名-->
   <processes>4</processes> <!-- 进程数 -->    
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>
 
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: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/; # 项目路径
        }
    }
}
 
5)启动uwsgi
>: uwsgi -x /home/project/test_site/test_site.xml
 
6)启动nginx
>: nginx
 
7)浏览器测试:http://39.98.144.221/admin
 
8)关闭uwsgi所有进程
>: pkill -f uwsgi -9

路飞项目部署:Nginx + uwsgi + django + vue

配置前台项目

上线前配置

assets/settings.js
1
base_url: 'http://39.98.144.221:8000',  // 设置公网ip

  

上线

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
1)本地项目打包,前往luffycity项目目录下
>: cnpm run build
 
2)上传
>: scp -r dist root@39.98.144.221:~
 
3)移动并重命名
mv ~/dist /home/html
 
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 80;
        server_name  127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
        charset utf-8;
        location / {
            root /home/html; # html访问路径
            index index.html; # html文件名称
            try_files $uri $uri/ /index.html; # 解决单页面应用刷新404问题
        }
    }
}

路飞后台部署

上线前配置

prod.py:上线的配置文件,内容拷贝dev.py,前身就是settings.py
1
2
3
4
5
6
7
8
9
10
11
12
1)需要做上线修改的内容
DEBUG = False
ALLOWED_HOSTS = [
    '39.98.144.221'  # 公网ip地址
]
 
CORS_ORIGIN_ALLOW_ALL = True  # 允许所有跨域
CORS_ORIGIN_WHITELIST = [
]
 
UP_BASE_URL = 'http://39.98.144.221:8080'
END_BASE_URL = 'http://39.98.144.221:8000' 
wsgi.py 和 manage.py
1
2
1)需要做上线修改的内容
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.prod')
清空日志文件

上线

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
1)在项目的虚拟环境安装uwsgi
>: mkvirtualenv luffy
>: workon luffy
# 走下方 pip导入导出依赖 说明,将本地的环境依赖同步到服务器环境中
>: pip install uwsgi
 
2)项目根目录配置uwsgi:填入下方内容
>: mkdir /home/project
 
# 注:将后台项目移至到/home/project,可以上传,也可以git,项目设置公开(私密需要配置ssl)
>: cd /home/project && git clone https://gitee.com/doctor_owen/luffyapi.git
>: vim /home/project/luffyapi/luffyapi.xml
 
<uwsgi>   
   <socket>127.0.0.1:8808</socket> <!-- 内部端口,自定义 -->
   <chdir>/home/project/luffyapi/</chdir> <!-- 项目路径 -->           
   <module>luffyapi.wsgi</module>  <!-- luffyapi为wsgi.py所在目录名-->
   <processes>4</processes> <!-- 进程数 -->    
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>
 
 ---- 3)配置上线项目的settings:见后台项目部署准备视频
 
4)去向Nginx配置目录,备份配置,完全更新配置:填入下方内容
>: vim /usr/local/nginx/conf/nginx.conf
 
5)在原来基础上添加一个server
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 luffyapi.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 项目路径
        }
    }
}
 
见下方配置:pip环境 + 数据库设置 + django2.0源码 配置完成后再进行往下(配置教程在下方)
 
5)启动uwsgi
>: uwsgi -x /home/project/luffyapi/luffyapi.xml
 
6)启动nginx
>: nginx -s stop
>: nginx
>: nginx -s reload
 
7)浏览器测试:http://39.98.144.221:8000/xadmin
 
8)关闭uwsgi所有进程
>: pkill -f uwsgi -9

pip导入导出依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
1) 本地导出项目环境,上传线上,导入到线上环境中
 
本地操作
# 桌面新建env文件夹,开启终端进入文件夹,执行下方命名
>: cd Desktopenv
>: pip3 freeze > packages.txt
# 注:把xadmin删掉
>: scp -r packages.txt root@39.98.144.221:~
 
服务器操作
# 进入虚拟环境
>: workon luffy
# 导入
>: pip3 install -r packages.txt
# 安装xadmin
>: pip install https://codeload.github.com/sshwsfc/xadmin/zip/django2

数据库设置 + django2.0源码(2.0.7不用修改源码)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
1.管理员连接数据库
>: mysql -uroot -pOwen1234?
 
2.创建数据库
>: create database luffy default charset=utf8;
 
# 3.设置权限账号密码
# 拥有公网或局域网,其他主机连mysql
>: grant all privileges on luffy.* to 'luffy'@'%' identified by 'Luffy123?';
# 要是本机连mysql连不上,再增加localhost域,本机就可以登录了
>: grant all privileges on luffy.* to 'luffy'@'localhost' identified by 'Luffy123?';
# 设置完有权限限制的账号后一定要刷新权限
>: flush privileges;
 
4.退出mysql
quit
 
5.修改 prod.py | manage.py
>: vim /home/project/luffyapi/luffyapi/settings/prod.py
 
"PASSWORD": "Luffy123?"
 
>: vim /home/project/luffyapi/manage.py
 
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.prod')
 
6.源码修改
>: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/base.py
 
# 36,37行注释
 
>: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/operations.py
 
# 146行添加
    query = query.encode()
 
7.数据库迁移
>: cd /home/project/luffyapi/
>: python3 manage.py makemigrations
>: python3 manage.py migrate
 
8.创建超级用户
>: python3 manage.py createsuperuser
# 账号密码:admin|admin123

后台样式问题

设置文件中配置STATIC_ROOT
1
2
3
4
5
6
7
# >: vim /home/project/luffyapi/luffyapi/settings/prod.py
# 在STATIC_URL下方再添加两句
STATIC_URL = '/static/'
STATIC_ROOT = '/home/project/luffyapi/luffyapi/static'  # 服务器的绝对路径
STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),)  # 小luffyapi下要有static文件夹
# >: esc
# >: :wq
迁移静态样式:项目目录下
1
2
3
可能错误
>: mkdir /home/project/luffyapi/luffyapi/static
>: python3 /home/project/luffyapi/manage.py collectstatic 
Nginx配置静态路径
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
>: vim /usr/local/nginx/conf/nginx.conf
 
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 luffyapi.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 项目路径
        }
        # 新增的配置静态文件
        location /static {
            alias /home/project/luffyapi/luffyapi/static;
        }
    }
    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文件名称
            try_files $uri $uri/ /index.html; # 解决单页面应用刷新404问题
        }
    }
}
 
>: esc
>: :wq  
重启服务
1
2
3
>: pkill -f uwsgi -9
>: uwsgi -x /home/project/luffyapi/luffyapi.xml
>: nginx -s reload

重点 重点 重点

1
2
3
4
5
6
7
# 1、真实环境和虚拟环境都要安装uwsgi,将真实环境下的uwsgi建立软连接
 
# 2、redis服务一定要后台启动:redis-server &
 
# 3、uwsgi启动django项目一定要进入虚拟环境下,因为环境都是安装在虚拟环境中
 
# 4、服务器的日志都会被记录在于uwsgi配置文件 luffyapi.xml 同类目下的 uwsgi.log 中
原文地址:https://www.cnblogs.com/yangxinpython/p/11938329.html