阿里云项目环境搭建流程图

阿里云项目环境搭建流程图

安装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
posted @ 2020-08-01 15:06  小子,你摊上事了  阅读(259)  评论(0编辑  收藏  举报