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 中 |
ElasticSearch笔记脚本(script)
Newtonsoft助手类
js单元测试,使用断言捕获抛出的异常
解决homebrew的权限问题
匹配驼峰命名、蛇形命名的正则表达式
supertest测试,expect不同的状态码,但都能通过
如何退出/关闭telnet终端
解决子模块的合并冲突
解决终端无法访问github.com 的错误