Nignx及负载均衡&动静分离

核心要点:部署后台项目
1.配置jdk环境
    1.先将jdk的Linux版本的压缩包上传虚拟机中服务器
    2.解压上传的jdk压缩包    tar -zxvf jdk.gz
    3.先进入jdk的解压目录,再通过pwd查看当前解压包的路径
    4.将 解压包路径 配置到 /etc/profile
    5.更新环境变量 source /etc/profile 
    6.测试 java -version
    
2.配置tomcat环境
    1.先将tomcat的Linux版本的压缩包上传虚拟机中服务器
    2.解压上传的tomcat压缩包    tar -zxvf tomcat.gz
    3.进入 tomcat/bin执行 ./startup.sh
    4.默认防火墙是开启的,需要开放8080端口
    5.刷新防火墙规则
    6.测试 http://ip:8080
    
3.配置MySQL环境
    1.先将MySQL的Linux版本的安装包上传虚拟机中服务器
    2.先查询是否存在默认的数据库,如果有就删掉
    3.创建一个mysql5.7,将上传的安装包解压到指定目录
    4.执行4个命令 
        npm -ivh
    5.查看MySQL中的日志文件,获取初始化的登录密码
    6.登录MySQL,降低密码的设置等级,设置密码设置的长度
    7.setpassword修改密码,flush privilege
    8.此时外界不能链接,需要授权给root用户
    9.开放3306端口
    10.测试 Navicat
    
4.项目部署的流程
    1.先在本地启动项目,确定访问状况良好
    2.修改pom.xml中packaging为war,在通过maven clean清除掉
    target目录下的编译文件,再通过maven install将项目打包
    3.将ssm.war上传到虚拟机中的tomcat/webapp/...
    4.确定包虚拟机中的数据库是存在对应项目所需要用到的数据
    5。tomcat/bin/startup.sh
    
核心目标:部署前端项目
1.Nginx简介
    1.负载均衡:流量分摊
    2.反向代理:处理外网访问内网问题
    3.动静分离:判断动态请求还是静态请求,选择性的访问指定服务器
2.Nginx使用
    默认端口是80
    http://localhost:8080/ssm
    http://localhost:80/ssm
    http://localhost/ssm
    /etc/nginx/nginx.conf    配置上游服务upstream
    /etc/nginx/conf.d/default.conf
    
3.Nginx部署项目
    1.确保前台项目能用
    2.将前台项目打包 npm run build    (测试本地项目打包后没问题)
        build/utils.js
        config/index.js
    3.做ip/host主机映射
        将虚拟机ip映射域名www.zking.com
    4.完成Nginx动静分离的default.conf的相关配置
        定义规则:URL符合xxx标准走动态请求,不符合走静态请求
        ^~api
    5.将前台项目打包 npm run build (配合Nginx动静分离)
        注意:修改action.js 地址,添加api的路径配置
    6.将前端构建好的dist项目,上传到云服务器/usr/local/...
    7.server{
        server_name:www.zking.com
        root:/usr/local/mypro/dist
    }
    8.systemctl restart nginx
    9.www.zking.com完成整个前后端分离项目的测试
    

http://localhost:8080/T216_SSH/vue/treeNode 动态请求
http://192.168.195.143:8080/T216_SSH/vue/articleAction_list.action
@requestMapping("/vue")
Controller
    @requestMapping("/treeNode")
    menus()
http://localhost:8080/T216_SSH/static/css/layui.css
http://localhost:8080/T216_SSH/static/js/layui.js
http://localhost:8080/T216_SSH/static/img/sign.png


http://192.168.195.143/
http://192.168.195.143/index.html
解析Nginx.conf 
location / {
        #该句代码是为解决history路由不能跳转的问题,在vue-router官网有介绍 
    try_files $uri $uri/  /index.html;
}

http://192.168.195.143/
http://tomcat_list
location / {
      #root   /usr/share/nginx/html;
      #proxy_pass   http://172.17.0.3:8080;
      proxy_pass   http://tomcat_list;
      index index.html index.htm;
  }

  原始的用户
  http://192.168.195.143:8080/api/T216_SSH/vue/articleAction_list.action
  # 代理配置
    location / {
            #该句代码是为解决history路由不能跳转的问题,在vue-router官网有介绍 
        try_files $uri $uri/  /index.html;
    }
    location  ^~/api/ {
        #^~/api/表示匹配前缀是api的请求,proxy_pass的结尾有/, 则会把/api/*后面的路径直接拼接到后面,即移除api
        proxy_pass http://tomcat_list/;
    }
     http://tomcat_list/T216_SSH/vue/articleAction_list.action
    
     
     upstream  tomcat_list {  #服务器集群名字
        server    127.0.0.1:8080  weight=1;   #服务器1   weight是权重的意思,权重越大,分配的概率越大。
        server    127.0.0.1:8081  weight=1; #服务器2   weight是权重的意思,权重越大,分配的概率越大
    } 
     http://192.168.195.143:8080/T216_SSH/vue/articleAction_list.action
  
  最终效果:www.zking.com/
  
  listen       80;            #监听80端口,可以改成其他端口
    #server_name  localhost;    #当前服务的域名
    server_name  www.zking.com; #当前服务的域名(虚拟域名也可以)
    root         /usr/local/mypro/dist;      #将要访问的网站的根目录,nginx节点会自动继承父节点的配置;这里放到/usr/local/*,放到其他路径下会有权限相关问题;必要的时候配置Nginx.conf的user为root
    
  http://192.168.195.143/
  http://localhost:8080/T216_SSH/static/img/sign.png
    usr/local/mypro/dist/index.html
 

你可能感兴趣的:(java,linux)