当前位置: 首页 > news >正文

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
 

http://www.lryc.cn/news/217772.html

相关文章:

  • HDFS架构介绍
  • 微信小程序提示确认框 wx.showModal
  • 如何设置OBS虚拟摄像头给钉钉视频会议使用
  • SpringCloud 微服务全栈体系(十一)
  • 45基于matlab的ARIMA:AutoregressiveIntegratedMovingAverage model。
  • 2010年408计网
  • 初谈Linux-Linux环境搭建(阿里云免费服务器+xshell)
  • 如何利用AppScan扫描H5页面,进行安全测试?
  • Oracle数据库中的table@xyz是什么意思?
  • springboot常见网络相关错误及原因解析
  • 【C语言_线程pthread_互斥锁mutex_条件触发cond 之解析与示例 (开源)】.md updata:23/11/03
  • mongodb如何删除数据并释放空间
  • k8s之集群调度
  • 代码随想录算法训练营第四十二天丨 动态规划part05
  • [css] flex 子元素自动撑开父元素宽度
  • 全新干货!一招教你迅速提升流量主收入!包你轻松月入过万
  • 连接两个dataframe
  • 【入门Flink】- 05Flink运行时架构以及一些核心概念
  • 网络协议的基本概念
  • 广汽传祺E9上市,3DCAT实时云渲染助力线上3D高清看车体验
  • resource manager attributes structure(iofunc_attr_t) 扩展实例
  • 劳易测扫码条码分段读取实现方法
  • 【Linux】Nignx及负载均衡动静分离
  • AI:50-基于深度学习的柑橘类水果分类
  • mysql 中!= 到底走不走索引?
  • 4 sql语法基础
  • 网络工程师应知应会:基础知识(5)
  • Minio多节点多驱动分布式部署官网文档翻译
  • python连接clickhouse (CK)
  • 【C++】内联函数一看就懂?