阿里云项目环境搭建流程图
目录
阿里云项目环境搭建流程图
安装yum
>: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作为依赖安装号
git
安装redis
# 1
cd ~
# 2.下载redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz
也可以在window下载好在拉进去阿里云
>: scp -r C:\Users\dell\Desktop\pkg\redis-5.0.5.tar.gz root@39.99.192.127:~
# 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.建立软连接
>: ln -s /usr/local/redis/src/redis-server /usr/bin/redis-server
>: ln -s /usr/local/redis/src/redis-cli /usr/bin/redis-cli
# 8.后台运行redis
>: cd /usr/local/redis
>: redis-server &
# 9. 测试redis环境
>: redis-cli
# 10.关闭redis服务
>: pkill -f redis -9
安装mysql
# 1.前往用户根目录
>: cd ~
# 2.下载mysql57
>: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
# 3.也可以本地上传,这条命令要在本地终端上执行
>: scp -r C:mysql57-community-release-el7-10.noarch.rpm root@39.99.192.127:~
# 4.安装mysql57
>: yum -y install mysql57-community-release-el7-10.noarch.rpm
>: yum -y install mysql-community-server
# 5.启动mysql57并查看启动状态
>: systemctl start mysqld.service
>: systemctl status mysqld.service
# 6.查看默认密码并登录
>: grep "password" /var/log/mysqld.log
>: mysql -uroot -p
# 7.修改密码
>: ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
安装python
# 1.前往用户根目录
>: cd ~
# 2.服务器终端
>: wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz
# 3.本地终端,给服务器上传
>: scp -r 本地Python-3.6.7.tar.xz ssh root@39.99.192.127:服务器路径
>: scp -r C:\Users\dell\Desktop\pkg\Python-3.6.7.tar.xz ssh root@39.99.192.127~
# 4.解压安装包
>: tar -xf Python-3.6.7.tar.xz
# 5.进入目标文件
>: cd Python-3.6.7
# 6.配置安装路径:/usr/local/python3
>: ./configure --prefix=/usr/local/python3
# 7.编译并安装
>: make && sudo make install
# 8.建立软连接:终端命令 python3,pip3
>: ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
>: ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3
# 9.删除安装包与文件:
>: rm -rf Python-3.6.7
>: rm -rf Python-3.6.7.tar.xz
安装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
#Nginx命令
1)启动
>: nginx
2)关闭nginx
>: nginx -s stop
3)重启nginx
>: nginx -s reload
4)查看端口,强行关闭
>: ps -aux|grep nginx
>: kill <pid:进程编号>
nginx转发静态文件(前端项目)
# 1 mv ~/dist /home/html
# 2 cd /usr/local/nginx/conf
# 3 vim 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问题
}
}
}
esc
:wq # 保存并推出
# 重启nginx
nginx -s reload
# 前端项目就有了
安装虚拟环境
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
安装uwsgi
# 1.在真实环境下安装
pip3 install uwsgi
# 2.虚拟环境也要安装
pip3 install uwsgi
# 3.建立软连接
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi
django+nginx+uwsgi+vue上线前
1.前端
# 1.本地终端操作
1)本地项目打包,前往luffycity项目目录下
>: cnpm run build
# 2.本地终端上传
>: scp -r dist root@39.99.192.127:~
# 3.开始服务器连接,在服务器终端操作
# 3.1 移动并重命名
mv ~/dist /home/html
# 3.2去向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问题
}
}
}
# 4.退出
>: esc
>: :wq
# 5.重启nginx
>: nginx -s reload
2. 后台的准备工作
2.0 本地导出项目环境
2)本地导出项目环境
>: pip3 freeze > packages.txt
2.1prod.py
# 关闭测试环境
DEBUG = False
ALLOWED_HOSTS = [
'39.99.192.127' # 公网ip地址
]
CORS_ORIGIN_ALLOW_ALL = True # 允许所有跨域
# 静态文件配置:上线后还有额外配置,见下方 后台样式问题
STATIC_URL = '/static/'
# 后台http根路径
# BASE_URL = 'http://127.0.0.1:8000'
BASE_URL = 'http://39.99.192.127:8000'
# 前台http根路径
# LUFFY_URL = 'http://127.0.0.1:8080'
LUFFY_URL = 'http://39.99.192.127:80'
# 订单支付成功的后台异步回调接口
NOTIFY_URL = BASE_URL + '/order/success/'
# 订单支付成功的前台同步回调接口
RETURN_URL = LUFFY_URL + '/order/pay/success/'
REST_FRAMEWORK = {
# 渲染模块
'DEFAULT_RENDERER_CLASSES': [
'rest_framework.renderers.JSONRenderer',
# 'rest_framework.renderers.BrowsableAPIRenderer',
],
# ...
}
2.2wsgi.py 、manage_prod.py
一个是dev.py和manage.py上线前都要复制一份
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.prod')
3.收集xadmin,rest_framework静态样式
# 1.新建static文件
# 2. 修改static配置
STATIC_URL = '/static/'
STATIC_ROOT = '/home/project/luffyapi/luffyapi/static'
STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),)
# 3.完成静态文件迁移
>: python /home/project/luffyapi/manage_prod.py collectstatic
4. 配置uwsgi.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>
5. 清空迁移文件
把每个migrations文件夹下的0001_initial.py
都清空
上线后
克隆在阿里云上用git把项目拉下来,把前台和后台放在一个文件里/home/project
1.修改nginx配置
>: 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 {
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;
}
}
}
2.启动django
python manage_pro.py makemigraions
python manage_pro.py migrate
python manage_pro.py createsuperuser
重启nginx
>: nginx -s reload
启动django
>:python manage_pro.py runserver 0.0.0.0:8000
前面的启动是为了测试django还有什么问题
剩下的以后都用我们在django项目配置的uwsgi启动项目
# 1)启动uwsgi
>: uwsgi -x /home/project/luffyapi/luffyapi.xml
2)重启nginx
>: nginx -s reload