前后端分离项目一台服务器上线

2020-06-19 15:39:14 浏览数 (1)

一.购买服务器

这里有几点注意

  • 选择配置 linux 系统的时候最好选择centos7 不要选择centos6
  • 配置开发端口最好把常用端口打开以及运行端口最好多开几个防止后续nginx 启动网页没法没法访问ip一般是端口权限没开
  • 默认服务器账户名为root

二.更新系统安装包(非常重要)

  • 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

三.安装mysql

  • cd ~
  • 下载安装包也可以 wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm 也可以直接上传安装包一样的
  • yum -y install mysql57-community-release-el7-10.noarch.rpm
  • yum -y install mysql-community-server
  • systemctl start mysqld.service
  • systemctl status mysqld.service
  • grep "password" /var/log/mysqld.log (查看初始密码)
  • mysql -uroot -p (登入mysql)
  • 修改密码
  • ALTER USER 'root'@'localhost' IDENTIFIED BY 'YWy1234?';

四.安装Redis

代码语言:javascript复制
1)前往用户根目录
>: cd ~

2)下载redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz

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

代码语言:javascript复制
1)前往用户根目录
>: cd ~

2)下载 或 上传 Python3.6.7
>: wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz

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镜像源

代码语言:javascript复制
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

七.安装虚拟环境

代码语言:javascript复制
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

八.pip3安装uwsgi

代码语言:javascript复制
1)在真实环境下安装
pip3 install uwsgi

2)建立软连接
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

九.安装Nginx

代码语言:javascript复制
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常用命令

代码语言:javascript复制
1)启动
>: nginx

2)关闭nginx
>: nginx -s stop

3)重启nginx
>: nginx -s reload

4)查看端口,强行关闭
>: ps -aux|grep nginx
>: kill <pid:进程编号>

十一.前端部署

代码语言:javascript复制
1.项目中关于与后端请求的ip改成服务器的ip(这个没有固定写法根据自己项目灵活设置)

前端项目打包
cnpm run build (项目目录执行)
打包后会有一个dist文件夹只要他就好了

上传到~(也就是root)

移动并重命名
mv ~/dist /home/html

十二.后端部署

代码语言:javascript复制
1)需要做上线修改的内容settings.py
DEBUG = False
ALLOWED_HOSTS = [
    '39.100.107.176'  # 公网ip地址
]

CORS_ORIGIN_ALLOW_ALL = True  # 允许所有跨域
CORS_ORIGIN_WHITELIST = [
]

2 )上传并移动至于/home/project

3 )提前先配置uwsgi设置
vim /home/project/你的后台项目名称/配置的文件名称.xml
里面写入内容如下:
 <uwsgi>    
   <socket>127.0.0.1:8808</socket> <!-- 内部端口,自定义 --> 
   <chdir>/home/project/你的后台项目名称/</chdir> <!-- 项目路径 -->            
   <module>xxxx.wsgi</module>  <!-- xxxx为wsgi.py所在目录名--> 
   <processes>4</processes> <!-- 进程数 -->     
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>

保存并退出

十三.导出本地依赖,服务器安装依赖

代码语言:javascript复制
走进后台项目
pip3 freeze > packages.txt

上传packages.txt至服务器
pip3 install -r packages.txt

十四.数据库迁移(没有数据库相关可以忽略)

代码语言:javascript复制
和玩DJANGO迁移在CMD中执行命令一模一样

十五.配置上线启动

代码语言:javascript复制
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 wsgi.py所在的目录名.wsgi;  #wsgi.py所在的目录名 .wsgi
           uwsgi_param UWSGI_CHDIR /home/project/项目路径/; # 项目路径
        }
        # 新增的配置静态文件
        location /static {
            alias /home/project/项目路径/wsgi.py所在的目录名/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问题
        }
    }
}

保存退出

十六.启动服务

代码语言:javascript复制
pkill -f uwsgi -9

uwsgi -x /home/project/项目路径/xxx.xml

nginx 

如果有做修改需要重新启动一次服务才生效

十七.简单的django启动办法

代码语言:javascript复制
cd 到manage.py所在目录

python3 manage.py runserver 0.0.0.0:80
    
这时候测试后台的ip 端口是服务器的ip

0 人点赞