tomcat 多实例部署以及负载均衡配置

Tomcat

  • 一、多实例部署
    • 1.1 安装Tomcat
    • 1.2 配置环境变量
    • 1.3 修改tomcat2的配置文件
    • 1.4 添加 tomcat 环境变量
      • 修改 tomcat 1
      • 修改 tomcat 2
    • 1.5 启动
    • 1.6 测试
  • 二、负载均衡,动态分离
    • 2.1 安装nginx服务器
    • 2.2 部署tomcat服务器
    • 2.3 动静分离配置
      • tomcat 1 设置
      • tomcat 2 配置
      • nginx 设置
      • 2.4 测试
  • 三、Nginx 负载均衡模式

一、多实例部署

1.1 安装Tomcat

cd /opt

# 解压缩
tar zxvf apache-tomcat-9.0.16.tar.gz

# 创建tomcat目录
mkdir /usr/local/tomcat

# 移动解压后的包去刚才创建的目录下,并改名tomcat1
mv apache-tomcat-9.0.16 /usr/local/tomcat/tomcat1

# 复制tomcat1 为 tomcat2
cp -a /usr/local/tomcat/tomcat1 /usr/local/tomcat/tomcat2

1.2 配置环境变量

  • vim /etc/profile.d/tomcat.sh
    • 创建变量文件
#tomcat1
export CATALINA_HOME1=/usr/local/tomcat/tomcat1
export CATALINA_BASE1=/usr/local/tomcat/tomcat1
export TOMCAT_HOME1=/usr/local/tomcat/tomcat1

#tomcat2
export CATALINA_HOME2=/usr/local/tomcat/tomcat2
export CATALINA_BASE2=/usr/local/tomcat/tomcat2
export TOMCAT_HOME2=/usr/local/tomcat/tomcat2

tomcat 多实例部署以及负载均衡配置_第1张图片

  • source /etc/profile.d/tomcat.sh
    • 刷新文件

1.3 修改tomcat2的配置文件

tomcat2和1不能有重复的端口号,这里直接+1

  • vim /usr/local/tomcat/tomcat2/conf/server.xml
# 第22行,默认为8005修改为8006
<Server port="8006" shutdown="SHUTDOWN">	

# 第69行,默认为8080修改为8081
<Connector port="8081" protocol="HTTP/1.1"	

# 第116行,默认为8009修改为8010
<Connector port="8010" protocol="AJP/1.3" redirectPort="8443" />	

1.4 添加 tomcat 环境变量

修改 tomcat 1

开始

  • vim /usr/local/tomcat/tomcat1/bin/startup.sh
# 第20行下添加
export CATALINA_BASE=$CATALINA_BASE1
export CATALINA_HOME=$CATALINA_HOME1
export TOMCAT_HOME=$TOMCAT_HOME1

tomcat 多实例部署以及负载均衡配置_第2张图片

停止

  • vim /usr/local/tomcat/tomcat1/bin/shutdown.sh
第20行下添加
export CATALINA_BASE=$CATALINA_BASE1
export CATALINA_HOME=$CATALINA_HOME1
export TOMCAT_HOME=$TOMCAT_HOME1

tomcat 多实例部署以及负载均衡配置_第3张图片

修改 tomcat 2

开始

  • vim /usr/local/tomcat/tomcat2/bin/startup.sh
# 第20行下添加
export CATALINA_BASE=$CATALINA_BASE2
export CATALINA_HOME=$CATALINA_HOME2
export TOMCAT_HOME=$TOMCAT_HOME2

tomcat 多实例部署以及负载均衡配置_第4张图片

停止

  • vim /usr/local/tomcat/tomcat2/bin/shutdown.sh
第20行下添加
export CATALINA_BASE=$CATALINA_BASE2
export CATALINA_HOME=$CATALINA_HOME2
export TOMCAT_HOME=$TOMCAT_HOME2

tomcat 多实例部署以及负载均衡配置_第5张图片

1.5 启动

  • /usr/local/tomcat/tomcat1/bin/startup.sh

tomcat 多实例部署以及负载均衡配置_第6张图片

  • /usr/local/tomcat/tomcat2/bin/startup.sh

tomcat 多实例部署以及负载均衡配置_第7张图片

  • netstat -anpt | grep java
    tomcat 多实例部署以及负载均衡配置_第8张图片

1.6 测试

  • http://192.168.253.11:8080
    tomcat 多实例部署以及负载均衡配置_第9张图片

  • http://192.168.253.11:8081
    tomcat 多实例部署以及负载均衡配置_第10张图片

二、负载均衡,动态分离

2.1 安装nginx服务器

地址设置:192.168.253.22:80

安装方法

# 关闭防火墙
systemctl stop firewalld
setenforce 0

# 安装软件包
yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make

# 创建nginx用户
useradd -M -s /sbin/nologin nginx

# 解压
cd /opt
tar zxvf nginx-1.12.0.tar.gz -C /opt/

# 编译
cd nginx-1.12.0/

./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-file-aio \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--with-http_flv_module \
--with-http_ssl_module

# 安装
make -j2 && make install

# 加入软链接
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

# 配置服务文件
vim /lib/systemd/system/nginx.service
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecrReload=/bin/kill -s HUP $MAINPID
ExecrStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target

# 加权限
chmod 754 /lib/systemd/system/nginx.service

# 开启服务
systemctl start nginx.service
systemctl enable nginx.service

2.2 部署tomcat服务器

配置方法

# 关闭防火墙
systemctl stop firewalld
setenforce 0

# 解压缩至 /usr/local 目录
tar zxvf jdk-8u91-linux-x64.tar.gz -C /usr/local/

# 编辑环境变量
vim /etc/profile
## 新增
export JAVA_HOME=/usr/local/jdk1.8.0_91
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

# 重载文件
source /etc/profile

# 解压缩
tar zxvf apache-tomcat-8.5.16.tar.gz

# 压缩内容移动到/usr/local目录下并改名tomcat
mv /opt/apache-tomcat-8.5.16/ /usr/local/tomcat

# 开启
/usr/local/tomcat/bin/shutdown.sh 
/usr/local/tomcat/bin/startup.sh

# 查看是否开启
netstat -ntap | grep 8080

2.3 动静分离配置

tomcat 1 设置

# 创建目录
mkdir /usr/local/tomcat/webapps/test

# 编辑配置文件
vim /usr/local/tomcat/webapps/test/index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test1 page</title>
</head>
<body>
<% out.println("动态页面 1-hello tomcat1");%>		# 网页内容
</body>
</html>

# 进入主配置文件修改
vim /usr/local/tomcat/conf/server.xml

# 替换原host配置
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
	<Context docBase="/usr/local/tomcat/webapps/test" path="" reloadable="true">
	</Context>
</Host>

# 重启服务
/usr/local/tomcat/bin/shutdown.sh 
/usr/local/tomcat/bin/startup.sh

tomcat 多实例部署以及负载均衡配置_第11张图片

tomcat 2 配置

实例1

mkdir /usr/local/tomcat/tomcat1/webapps/test
mkdir /usr/local/tomcat/tomcat2/webapps/test

# 新建动态网页文件
vim /usr/local/tomcat/tomcat1/webapps/test/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test2 page</title>
</head>
<body>
<% out.println("动态页面 2-hello tomcat2");%>
</body>
</html>

# 修改主配置文件
vim /usr/local/tomcat/tomcat1/conf/server.xml

# 和tomcat1 一样设置
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
	<Context docBase="/usr/local/tomcat/tomcat1/webapps/test" path="" reloadable="true" />
</Host>

# 重启服务
/usr/local/tomcat/tomcat1/bin/shutdown.sh 
/usr/local/tomcat/tomcat1/bin/startup.sh 

实例2

# 设置动态网页内容
vim /usr/local/tomcat/tomcat2/webapps/test/index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<title>JSP test3 page</title>
</head>
<body>
<% out.println("动态页面 3-hello tomcat3");%>
</body>
</html>

# 修改主配置文件
vim /usr/local/tomcat/tomcat2/conf/server.xml

# 和实例1设置一样
<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
	<Context docBase="/usr/local/tomcat/tomcat2/webapps/test" path="" reloadable="true" />
</Host>

# 重启服务
/usr/local/tomcat/tomcat2/bin/shutdown.sh 
/usr/local/tomcat/tomcat2/bin/startup.sh

nginx 设置

# 准备静态页面和静态图片
echo '

闭嘴

'
> /usr/local/nginx/html/index.html # 创建img目录,放置网页图片 mkdir /usr/local/nginx/html/img # 进入主配置文件 vim /usr/local/nginx/conf/nginx.conf http { #gzip on; upstream tomcat_server { server 192.168.253.22:8080 weight=1; server 192.168.253.11:8080 weight=1; server 192.168.253.11:8081 weight=1; } server { listen 80; server_name www.cc.com; charset utf-8; # 取消注释 #access_log logs/host.access.log main; # 配置Nginx处理动态页面请求 location ~ .*\.jsp$ { proxy_pass http://tomcat_server; proxy_set_header HOST $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } # 配置Nginx处理静态图片请求 location ~ .*\.(gif|jpg|jpeg|png|bmp|swf|css)$ { root /usr/local/nginx/html/img; expires 10d; } location / { root html; index index.html index.htm; }

tomcat 多实例部署以及负载均衡配置_第12张图片

tomcat 多实例部署以及负载均衡配置_第13张图片

2.4 测试

  • Windows客户端访问 http://192.168.253.33/index.jsp

tomcat 多实例部署以及负载均衡配置_第14张图片
tomcat 多实例部署以及负载均衡配置_第15张图片
tomcat 多实例部署以及负载均衡配置_第16张图片

  • 访问 http://192.168.253.33/111.png
    tomcat 多实例部署以及负载均衡配置_第17张图片

三、Nginx 负载均衡模式

  • rr 负载均衡模式

    • 每个请求按时间顺序逐一分配到不同的后端服务器,如果超过了最大失败次数后(max_fails,默认1),在失效时间内(fail_timeout,默认10秒),该节点失效权重变为0,超过失效时间后,则恢复正常,或者全部节点都为down后,那么将所有节点都恢复为有效继续探测,一般来说rr可以根据权重来进行均匀分配
  • least_conn 最少连接

    • 优先将客户端请求调度到当前连接最少的服务器
  • ip_hash 负载均衡模式

    • 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题,但是ip_hash会造成负载不均,有的服务请求接受多,有的服务请求接受少,所以不建议采用ip_hash模式,session 共享问题可用后端服务的 session 共享代替 nginx 的 ip_hash
  • fair(第三方)负载均衡模式

    • 按后端服务器的响应时间来分配请求,响应时间短的优先分配
  • url_hash(第三方)负载均衡模式

    • 和ip_hash算法类似,是对每个请求按url的hash结果分配,使每个URL定向到一个同 一个后端服务器,但是也会造成分配不均的问题,这种模式后端服务器为缓存时比较好

你可能感兴趣的:(Tomcat,linux,nginx,tomcat,运维,centos)