实验环境:
- 首先关闭iptables及selinux
主机1:172.18.10.3为tomcat1服务器
主机2:172.18.10.4为tomcat2服务器
主机3:172.18.10.1为nginx反向代理服务器
分别为主机1和主机2安装tomcat及相关软件和openjdk
# yum -y install tomcat tomcat-lib tomcat-admin-webapps tomcat-webapps tomcat-docs-webapp
# yum -y install java-1.7.0-openjdk.x86_64
给主机3安装nginx服务
# yum -y install nginx
给主机1设置主机名为node1.magedu.com
给主机2设置主机名为node2.magedu.com
给主机3设置主机名为www.magedu.com
# hostnamectl set-hostname node1.magedu.com
# hostnamectl set-hostname node2.magedu.com
# hostnamectl set-hostname www.magedu.com
分别在三台主机的/hosts文件中设置域名解析
#vim /etc/hosts
添加以下三行:
172.18.10.4 node1.magedu.com node1
172.18.10.3 node2.magedu.com node2
172.18.10.1 www.magedu.com www
第一种实现方法:
- nginx当调度主机,后面跟多个tomcat服务器
- 给两个tomcat主机配置测试界面
给主机1配置测试页面:
- 给两个tomcat主机配置测试界面
切入文件夹
# cd /usr/share/tomcat/webapps
新建文件夹并在新建文件夹下编辑主页文件
# mkdir myapp
# cd myapp
# vim index.jsp
内容如下:
为了更好的做接下来的实验!我们应该每做一步,都必须进行检验测试
主机2配置基本相同,测试页略有改动,为了便于观察
主机2测试主页:
测试效果:
下面设置主机3:nginx主机的反向代理设置
# vim /etc/nginx/nginx.conf
启动nginx服务,查看端口是否打开
测试:这里我们准备一台主机充当客户机去访问nginx查看调度效果,可以看出默认使用轮询方式调度
第二种实现方法:
- 使用http协议向后反代,balancer模块构建负载均衡集群
把nginx服务停止,然后安装httpd服务
# yum -y install httpd
配置httpd配置文件关闭正向代理,启用反向代理并设置权重
# cd /etc/httpd/conf.d
# vim http-tomcat.conf
内容如下:
测试:
- 使用ajp协议向后反代,balancer模块构建负载均衡集群
# cd /etc/httpd/conf.d
# vim ajp-tomcat.conf
内容如下:
测试:因为标记了主机1不可用,而且http有健康性检查,所以只往主机2调度
测试内建管理界面(建议不对外开放)