项目上线
项目部署架构
补充
- kvm
- vmare
- OpenStack
- docker
- k8s
云服务器安装mysql
yum update -y #更新软件包
yum -y groupinstall "Development tools" # 装一个开发工具包(开发相关的一些软件,git)
yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel zlib* libffi-devel # 依赖,
git #验证git装完
1)前往用户根目录
>: cd ~
2)下载mysql57
>: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
也可以本地上传,这条命令要在本地终端上执行
>: scp .\mysql57-community-release-el7-10.noarch.rpm root@106.14.137.210:/root
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
xdjj(/qgj0A4
>: mysql -uroot -p
6)修改密码
>: ALTER USER ‘root‘@‘localhost‘ IDENTIFIED BY ‘new password‘;
>: ALTER USER ‘root‘@‘localhost‘ IDENTIFIED BY ‘Jerry123?‘;
云服务器安装redis
1)前往用户根目录
>: cd ~
2)下载redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz #源码包,c语言源码
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
>: cd /usr/local/redis
>: redis-server ./redis.conf &
ctrl + c
11)测试redis环境
>: redis-cli
ctrl + c
12)关闭redis服务
>: pkill -f redis -9
云服务器安装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
6)编译并安装
>: make && sudo make install
7)建立软连接:终端命令 nginx
>: ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx
8)删除安装包与文件:
>: cd ~
>: rm -rf nginx-1.13.7
>: rm -rf nginx-1.13.7.tar.xz
9)测试Nginx环境,服务器运行nginx,本地访问服务器ip
>: nginx
>: 服务器绑定的域名 或 ip:80
# 命令
1)启动
>: nginx
2)关闭nginx
>: nginx -s stop
3)重启nginx
>: nginx -s reload
4)查看端口,强行关闭
>: ps -aux|grep nginx
>: kill <pid:进程编号>
安装python
1)前往用户根目录
>: cd ~
2)下载 或 上传 Python3.7.7
# 服务器终端
>: wget https://www.python.org/ftp/python/3.7.7/Python-3.7.7.tar.xz
3)解压安装包
>: tar -xf Python-3.7.7.tar.xz
4)进入目标文件
>: cd Python-3.7.7
5)配置安装路径:/usr/local/python3
>: ./configure --prefix=/usr/local/python3.7
6)编译并安装
yum -y install zlib*
yum install libffi-devel
>: make && sudo make install # 把报错复制到百度里
7)建立软连接:终端命令 python3,pip3
>: ln -s /usr/local/python3.7/bin/python3.7 /usr/bin/python3.7
>: ln -s /usr/local/python3.7/bin/pip3.7 /usr/bin/pip3.7
8)删除安装包与文件:
>: rm -rf Python-3.7.7
>: rm -rf Python-3.7.7.tar.xz
安装uwsgi
# cgi,uwsgi...名词解释:http://www.liuqingzheng.top/article/1/05-CGI,FastCGI,WSGI,uWSGI,uwsgi%E4%B8%80%E6%96%87%E6%90%9E%E6%87%82/
# 安装uwsgi(不使用咱们装的解释器环境,使用阿里云内置的3.6.8)
pip3.7 install uwsgi
在任意路径下执行uwsgi会发现命令存在,这就可以了
ln -s /usr/local/python3.7/bin/uwsgi /usr/bin/uwsgi
配置虚拟环境
1)安装依赖
>: pip3.7 install virtualenv
>: pip3.7 install virtualenvwrapper
# 如果有问题
pip3.7 install --upgrade setuptools
python3.7 -m pip install --upgrade pip
2)建立虚拟环境软连接(使用内置的python3.6 不需要加)
>: ln -s /usr/local/python3.7/bin/virtualenv /usr/bin/virtualenv
3)配置虚拟环境:填入下方内容
>: vim ~/.bash_profile
VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3.7
source /usr/bin/virtualenvwrapper.sh
4)退出编辑状态
>: esc
5)保存修改并退出
>: :wq
6)更新配置文件内容
>: source ~/.bash_profile
7)虚拟环境默认根目录:~/.virtualenvs
8)创建虚拟环境
mkvirtualenv luffy
workon luffy
前端项目部署
# 修改服务端地址
base_url: ‘http://106.14.137.210:8000‘, // 真实环境:django项目就是跑在8000端口上的
# 编译
cnpm run build
压缩成zip,拖到服务器上去
# 在服务端安装
yum install unzip
# 解压
unzip dist.zip
mkdir /home/html
mv ~/dist /home/html
# 使用nginx代理静态文件
cd /usr/local/nginx/conf
# nginx.conf 配置文件是nginx的配置文件
#去向Nginx配置目录,备份配置,完全更新配置:填入下方内容
>: cd /usr/local/nginx/conf
>: mv nginx.conf nginx.conf.bak
>: vim nginx.conf
>: 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问题
}
}
}
# 退出
>: esc
>: :wq
# 重启nginx
>: nginx -s reload
后端项目部署
#1 把dev.py复制到pro.py中,相应的做修改(数据库。。。)
#2 新建一个manage_pro.py 指定配置文件为pro.py,以后迁移数据库,要迁移到pro.py配置的数据库中
#3 确认好wsgi.py,配置文件是不是pro.py
#4 导出项目依赖(在项目根路径下就会产生req.txt这是项目所有的依赖)
pip3 freeze > req.txt
# 5 把所有更改提交到git远端
# 6 在服务器上把代码拉下来
mkdir /home/project
cd /home/project
git clone https://gitee.com/liuqingzheng/luffy_api.git
# 7 使用uwsgi启动django
# 在项目根路径,新建uwsgi的配置文件luffy.xml
<uwsgi>
<socket>127.0.0.1:8888</socket>
<chdir>/home/project/luffy_api/</chdir>
<module>luffy_api.wsgi</module>
<processes>4</processes>
<daemonize>uwsgi.log</daemonize>
</uwsgi>
# 8 配置nginx 转发动态请求(加一个server)
>: vim /usr/local/nginx/conf/nginx.conf
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问题
}
}
# 新增的server
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:8888; # 端口要和uwsgi里配置的一样
uwsgi_param UWSGI_SCRIPT luffy_api.wsgi; #wsgi.py所在的目录名+.wsgi
uwsgi_param UWSGI_CHDIR /home/project/luffy_api/; # 项目路径
}
}
}
# 9 创建luffy库,新建lqz用户
1)管理员连接数据库
>: mysql -uroot -Lqz12345?
2)创建数据库
>: create database luffy default charset=utf8mb4;
3)设置权限账号密码:账号密码要与项目中配置的一致
>: grant all privileges on luffy.* to ‘cjt‘@‘%‘ identified by ‘Jerry123?‘;
>: grant all privileges on luffy.* to ‘cjt‘@‘localhost‘ identified by ‘Jerry123?‘;
>: flush privileges;
4)退出mysql
>: quit;
#### 注意:动态设置linux环境变量
export DB_PASSWORD=Lqz12345?
# 10 进入虚拟环境,安装依赖
# mysqlclient
workon luffy
pip install -r req.txt # 如果报错,相应解决报错
pip install uwsgi # 正式环境中,虚拟环境也要装
# 11 迁移数据库
# 必须在luffy虚拟环境下
python manage_pro.py migrate
# 创建超级用户
python manage_pro.py createsuperuser
# 12 启动uwsgi
uwsgi -x ./luffy.xml
ps aux |grep uwsgi
# 13 启动nginx
nginx -s reload
# 14 收集静态文件
mkdir /home/project/luffy/luffy_api/static
# 修改配置文件
STATIC_URL = ‘/static/‘
STATIC_ROOT = ‘/home/project/luffy/luffy_api/static‘
STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),)
python ./manage_pro.py collectstatic # 前后端混合项目,用于收集静态资源
# 15 使用nginx代理静态文件
# 新增的配置静态文件
location /static {
alias /home/project/luffy/luffy_api/static;
}
# 16 把测试数据导入
# 17 申请域名,备案
把域名指向我们服务器的地址即可
项目上线