nginx做前端反代负载均衡,后端httpd+tomcat

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
简介:

实验内容:用nginx做前端反代负载均衡后端httpd+tomcat


实验环境:物理机win7,虚拟机centos7;

node1:172.18.11.111 httpd+tomcat

node2:172.18.11.112 httpd+tomcat

node3:172.18.11.113 nginx反代负载均衡


说明:httpd有两种方式与tomcat通信;

(1)httpd可使用http模块反代tomcat,此时tomcat使用http链接器;

(2)httpd还可使用ajp模块反代tomcat,此时tomcat使用ajp链接器;

wKiom1df9KKxa2-kAABeLevrCLc804.png

在node3上:

安装nginx

]# yum  -y install nginx-1.8.0-1.el7.ngx.x86_64.rpm 

]# vim /etc/nginx/conf.d/default.conf

在server配置段添加:

location / {

  root   /usr/share/nginx/html;

  index  index.html index.htm;

  proxy_pass http://websrvs;

}


]# vim /etc/nginx/nginx.conf

在http配置段添加:

upstream websrvs {

  server 172.18.11.111:80 weight=1;

  server 172.18.11.112:80 weight=2;

}


分别在node1和node2上:安装httpd和tomcat

安装java运行环境:

]# yum -y install java-1.7.0-openjdk java-1.7.0-openjdk-devel

]# vim /etc/profile.d/java.sh

export JAVA_HOME=/usr


]# . /etc/profile.d/java.sh


安装tomcat:

]# yum install tomcat tomcat-lib tomcat-webapps tomcat-admin-webapps


在web工作目录创建应用存放目录;

]# cd /var/lib/tomcat/webapps/

]# mkdir testapp

]# mkdir classes lib WEB-INF META-INF

]# vim  /var/lib/tomcat/webapps/testapp/index.jsp

wKiom1df-g_xtldtAAAuY0ofLk4067.png

]# vim /etc/tomcat/server.xml 

在Engine配置段添加:

<Context path="/test" docBase="testapp"/>


]# systemctl start tomcat.service


把创建的所有目录文件复制一份到node2上,然后再做配置文件修改:

]# scp -r /var/lib/tomcat/webapps/testapp/ node2:/var/lib/tomcat/webapps/

]# scp /etc/tomcat/server.xml node2:/etc/tomcat/


在node2上:

]# vim /var/lib/tomcat/webapps/testapp/index.jsp

wKiom1df-pCzqMTcAAA2Dt0cSX0340.png

]# systemctl start tomcat


安装好tomcat后,分别在node1和node2上安装httpd并编辑配置文件:

]# yum -y install httpd

]# vim /etc/httpd/conf/httpd.conf 

#DocumentRoot "/var/www/html"


]# vim /etc/httpd/conf.d/proxy_http_tomcat.conf

wKiom1df_k_TDw3HAAAwe0Ppc8k484.png

因为node1和node2都是httpd本地反代tomcat,所有配置文件完全一样;


本次使用proxy_http_module反代模块基于http协议与tomcat通信:

]# httpd -M

wKiom1dgBJDyEiHfAAAqpC92lOk177.png

]# systemctl start httpd


浏览器测试,输入http://172.18.11.113/testapp/index.jsp

多次刷新后,实现负载均衡且比例为1:2,实现了前端nginx反代后端tomcat。


wKiom1dgBSuDKcpIAAA6rbXUPak762.png

wKioL1dgBj7TynFsAAA1SMVh4_Q294.png


如果要做会话粘性,可在nginx上在upstream配置段添加一条指令即可:

upstream websrvs {

  server 172.18.11.111:80 weight=1;

  server 172.18.11.112:80 weight=2;

  ip_hash;

}

说明:ip_hash是基于源ip做会话绑定的。


浏览器测试,输入http://172.18.11.113/testapp/index.jsp

多次刷新后,会绑定在一个源ip上。


httpd还可使用ajp协议进行反代tomcat,这样的好处是避免用户请使用求跨过httpd来访问tomcat,因为如果使用http协议反代,则有可能会用户直接访问后端的tomcat而跨过了httpd。

其配置也非常简单,根据以上配置稍作修改即可:


只需修改node1和node2上的配置文件:

]# vim /etc/httpd/conf.d/proxy_http_tomcat.conf

wKioL1dgCRyjTb_HAABR88kO03M525.png

其它都不变。

查看httpd已加载的模块:

wKiom1dgCGDwRIFBAAAqqv2jOws219.png

以上过程就是简单实现nginx作为反代负载均衡至后端tomcat服务器的配置实验。










本文转自 crystaleone 51CTO博客,原文链接:http://blog.51cto.com/linsj/1789310,如需转载请自行联系原作者
相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
9天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
99 18
|
2月前
|
负载均衡 监控 应用服务中间件
配置Nginx反向代理时如何指定后端服务器的权重?
配置Nginx反向代理时如何指定后端服务器的权重?
154 61
|
21天前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
67 3
|
3月前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
33 1
|
3月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
1137 0
|
3月前
|
前端开发 JavaScript 小程序
前端uni开发后端用PHP的圈子系统该 如何做源码?
圈子系统系统基于TP6+Uni-app框架开发;客户移动端采用uni-app开发,管理后台TH6开发。系统支持微信公众号端、微信小程序端、H5端、PC端多端账号同步,可快速打包生成APP
|
3月前
|
前端开发 Java 数据库
springBoot:template engine&自定义一个mvc&后端给前端传数据&增删改查 (三)
本文介绍了如何自定义一个 MVC 框架,包括后端向前端传递数据、前后端代理配置、实现增删改查功能以及分页查询。详细展示了代码示例,从配置文件到控制器、服务层和数据访问层的实现,帮助开发者快速理解和应用。
|
3月前
|
安全 应用服务中间件 网络安全
Tomcat如何配置PFX证书?
【10月更文挑战第2天】Tomcat如何配置PFX证书?
282 7
|
3月前
|
存储 算法 应用服务中间件
Tomcat如何配置JKS证书?
【10月更文挑战第2天】Tomcat如何配置JKS证书?
436 4
|
5月前
|
网络协议 Java 应用服务中间件
tomcat配置域名及HTTPS
tomcat配置域名及HTTPS