部署Tomcat及其负载均衡

Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。一般来说,Tomcat虽然和Apache或者Nginx这些Web服务器一样,具有处理HTML页面的功能,然而由于其处理静态HTML的能力远不及Apache或者Nginx,所有Tomcat通常是作为一个Servlet和JSP容器,单独运行在后端。

1、案例实施

1.1、实施准备

1)关闭firewalld防火墙。

[root@localhost ~]# systemctl stop firewalld

2)在安装Tomcat之前必须先安装JDK。JDK 的全称是 Java Development Kit,是Sun公司免费
提供的Java语言的软件开发工具包,其中包含Java虚拟机(JVM)。编写好的Java源程序经过编译
可形成Java字节码,只要安装了JDK,就可以利用JVM解释这些字节码文件,从而保证了Java的跨平台性。

在平台兼容性方面,JDK作为解释字节码文件并据此调用操作系统API实现对应功能的 Java虚拟机,与操作系统类型和平台位数密切相关,因此存在不同类型的版本,而Tomcat也具有上述特征,默认情况下JDK已经安装,所以需要预先下载 Tomcat,本章中所使用的 Tomcat 软件的源码包为apache-tomcat-8.5.16.tar.gz。

1.2、查看JDK是否安装

运行java -version命令查看java是否安装。如果没有安装需要自行下载安装。

[root@localhost ~]# java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)

1.3、安装配置Tomcat

1)解压apache-tomcat-8.5.16.tar.gz包。

[root@localhost ~]# tar xf apache-tomcat-8.5.16.tar.gz 

2)解压后生成apache-tomcat-8.5-16文件夹,将该文件夹移动到/usr/local/下,并改名为tomcat8。

[root@localhost ~]# mv apache-tomcat-8.5.16/ /usr/local/tomcat8

3)启动tomcat。

[root@localhost ~]# /usr/local/tomcat8/bin/startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat8
Using CATALINA_HOME:   /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME:        /usr
Using CLASSPATH:       /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
Tomcat started.

Tomcat默认运行在8080端口,运行netstat命令查看8080端口监听的信息。

[root@localhost ~]# netstat -anpt | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      63339/java    

4)打开浏览器访问测试:http://192.168.136.21:8080/,如果出现以下界面则表示Tomcat已经启动成功。

如果想关闭Tomcat,则运行/usr/local/tomcat8/bin/shutdown.sh命令。

1.4、Tomcat配置相关说明

tomcat的主目录为/usr/local/tomcat8/。

[root@localhost ~]# cd /usr/local/tomcat8/
[root@localhost tomcat8]# ll
总用量 92
drwxr-x--- 2 root root  4096 1月  13 14:36 bin
drwx------ 3 root root   254 1月  13 16:06 conf
drwxr-x--- 2 root root  4096 1月  13 14:36 lib
-rw-r----- 1 root root 57092 6月  22 2017 LICENSE
drwxr-x--- 2 root root   197 1月  13 14:37 logs
-rw-r----- 1 root root  1723 6月  22 2017 NOTICE
-rw-r----- 1 root root  7064 6月  22 2017 RELEASE-NOTES
-rw-r----- 1 root root 15946 6月  22 2017 RUNNING.txt
drwxr-x--- 2 root root    30 1月  13 14:36 temp
drwxr-x--- 7 root root    81 6月  22 2017 webapps
drwxr-x--- 3 root root    22 1月  13 14:37 work

1)主要目录说明。

I --- bin/:存放Windows或Linux平台上启动和关闭Tomcat的脚本文件。
I --- conf/:存放Tomcat服务器的各种全局配置文件,其中最重要的是server.xml和web.xml。
I --- lib/:存放Tomcat运行需要的库文件(JARS)。
| --- logs:存放Tomcat执行时的LOG文件。
| --- webapps:Tomcat的主要Web发布目录(包括应用程序示例)。
|-- work:存为JSP编译后产生的class 文件

2)配置文件说明。

[root@localhost tomcat8]# ll conf/
总用量 224
drwxr-x--- 3 root root     23 1月  13 14:37 Catalina
-rw------- 1 root root  13816 6月  22 2017 catalina.policy
-rw------- 1 root root   7376 6月  22 2017 catalina.properties
-rw------- 1 root root   1338 6月  22 2017 context.xml
-rw------- 1 root root   1149 6月  22 2017 jaspic-providers.xml
-rw------- 1 root root   2358 6月  22 2017 jaspic-providers.xsd
-rw------- 1 root root   3622 6月  22 2017 logging.properties
-rw------- 1 root root   7607 1月  13 16:06 server.xml
-rw------- 1 root root   2164 6月  22 2017 tomcat-users.xml
-rw------- 1 root root   2633 6月  22 2017 tomcat-users.xsd
-rw------- 1 root root 168251 6月  22 2017 web.xml

catalina.policy:权限控制配置文件。
catalina.properties:Tomcat 属性配置文件.
context.xml:上下文配置文件。
logging.properties:日志log相关配置文件。
server.xml:主配置文件。
tomcat-users.xml:manager-gui 管理用户配置文件(Tomcat安装后提供一个manager-gui的管理界面,通过配置该文件可以开启访问)。
web.xml:Tomcat的servlet,servlet-mapping.filter、MIME等相关配置。

1.5、Tomcat主配置文件说明

server.xml为Tomcat的主要配置文件,通过配置该文件,可以修改Tomcat的启动端口、网站目录、虚拟主机、开启https等重要功能。

整个server.xml由以下结构构成:< Server>、<Service>、< Connector/>、< Engine>、<Host>、<Context>、</Context>、</Host>、</Engine>、</Service>和</Server>。
其中<!-- -->内的内容是注释信息,黑色斜体部分是我们需要注意和需要经常更改的部分。

1.6、Tomcat Server的组成部分说明

1)Server

Server元素代表了整个Catalina的servlet容器


2) Service
Service 是这样一个集合:它由一个或者多个Connector,以及一个Engine(负责处理所有Connector所获得的客户请求)组成。


3) Connector
一个Connector 在某个指定端口上侦听客户请求,并将获得的请求交给Engine来处理,从Engine
处获得回应并返回客户。
Tomcat 有两个典型的 Connector,一个直接侦听来自 browser 的 http 请求,一个侦听来自其他WebServer 的请求.
Coyote Http/1.1 Connector 在端口8080处侦听来自客户browser的http请求。
Coyote JK2 Connector 在端口8009处侦听来自其他WebServer(Apache)的servlet/jsp代理请求。


4) Engine
Engine下可以配置多个虚拟主机 Virtual Host,每个虚拟主机都有一个域名。
当Engine获得一个请求时,它把该请求匹配到某个Host上,然后把该请求交给该Host来处理。
Engine有一个默认虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来
处理。


5) Host
Host 代表一个Virtual Host,即虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配。
每个虚拟主机下都可以部署(deploy)一个或者多个Web App,每个Web App对应于一个Context,
有一个Context path。
当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context 来处理,匹配的方法是"最长匹配",所以一个path == I"的Context将成为该Host的默认Context。
所有无法和其他Context的路径名匹配的请求都将最终和该默认Context匹配。


6) Context
一个Context对应于-个Web Application,一个Web Application由一个或者多个Servlet 组成。

1.7、建立java的Web站点

1)在根目录下建立一个web目录,并在里面建立一个webapp1目录,用于存放网站文件。

[root@localhost ~]# mkdir -pv /web/webapp1

2)在webapp1目录下建立一个index.jsp的测试页面。

[root@localhost ~]# vim /web/webapp1/index.jsp 
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
  <head>
    <title>JSP test1 page</title>
  </head>
  <body>
    <% out.println("Welcom to test site,http:www.test1.com");%>
  </body>
</html>

3)修改Tomcat的server.xml文件。

定义一个虚拟主机,并将网站文件路径指向已经建立的/web/webapp1,在host段增加context段。

[root@localhost ~]# vim /usr/local/tomcat8/conf/server.xml 
      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
       <Context docBase="/web/webapp1" path="" reloadable="false" >
       </Context>

4)关闭Tomcat,再重新启动。080

[root@localhost ~]# /usr/local/tomcat8/bin/shutdown.sh 
Using CATALINA_BASE:   /usr/local/tomcat8
Using CATALINA_HOME:   /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME:        /usr
Using CLASSPATH:       /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
[root@localhost ~]# /usr/local/tomcat8/bin/startup.sh 
Using CATALINA_BASE:   /usr/local/tomcat8
Using CATALINA_HOME:   /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME:        /usr
Using CLASSPATH:       /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
Tomcat started.

5)通过浏览器访问http://192.168.136.21:8080/,出现下图则说明该Tomcat站点已经配置成功,并且已经能够运行JSP了。

2、案例:Nginx+Tomcat负载均衡群集

2.1、Tomcat2 server配置

Tomcat2 server配置方法与tomcat1基本相同,其中包括:

1)关闭防火墙。

2)确认是否安装JDK、JAVA版本与Tomcat1 server保持一致。

3)安装配置Tomcat,版本与Tomcat1 server保持一致。

4)创建/web/webapp1目录,修改Tomcat配置文件server.xml,将网站文件目录更改到/web/webapp1/路径下。

5)在/web/webapp1/路径下建立index.jsp,为了区别测试将测试页面index.jsp的内容更改如下。

[root@localhost ~]# vim /web/webapp1/index.jsp 
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
  <head>
    <title>JSP test2 page</title>
  </head>
  <body>
    <% out.println("Welcom to test site,http:www.test2.com");%>
  </body>
</html>

6)启动Tomcat,浏览器访问Tomcat2 server,测试http://192.168.136.22:8080/。

http {
···//省略内容

    #gzip  on;
    upstream tomcat_server {
                  server 192.168.136.21:8080 weight=1;
                  server 192.168.136.22:8080 weight=1;
    }

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass http://tomcat_server;
        }

2.2、Nginx服务器配置

在Nginx服务器192.168.136.24上安装Nginx,反向代理两个Tomcat站点,并实现放在均衡。

1)关闭防火墙。

2)安装相关软件包。

[root@localhost ~]# yum -y install pcre-devel zlib-devel openssl-devel

3)解压并安装Nginx。

[root@localhost ~]# groupadd www
[root@localhost ~]# useradd -g www www -s /bin/false
[root@localhost ~]# tar xf nginx-1.12.0.tar.gz
[root@localhost ~]# cd nginx-1.12.0/
[root@localhost nginx-1.12.0]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-file-aio --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module
[root@localhost nginx-1.12.0]# make
[root@localhost nginx-1.12.0]# make install

4)配置nginx.conf。

http {
···//省略内容

    #gzip  on;
    upstream tomcat_server {  //配置负载均衡组
                  server 192.168.136.21:8080 weight=1;
                  server 192.168.136.22:8080 weight=1;
    }

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass http://tomcat_server;  //加上此配置代理设定好的tomcat_server负载均衡组
        }

5)测试Nginx配置文件是否正确。

[root@localhost ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

6)启动Nginx服务。

[root@localhost ~]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

7)查看Nginx服务进程。

[root@localhost ~]# ps aux | grep nginx
root      10476  0.0  0.0  20548   612 ?        Ss   15:16   0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
www       10477  0.0  0.1  23080  1640 ?        S    15:16   0:00 nginx: worker process
root      69146  0.0  0.0 112724   988 pts/0    S+   16:56   0:00 grep --color=auto nginx

8)查看端口号及PID进程号。

[root@localhost ~]# netstat -anpt | grep nginx
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      10476/nginx: master 

2.3、测试负载均衡效果

1)打开浏览器访问:http://192.168.136.24/

2)不断刷新浏览器测试,可以看到由于权重相同,页面会反复在以下两个页面来回切换。

第一次访问,出现test1的测试页面;刷新后,第二次访问,则会出现test2的测试页面。这说明负载均衡群集搭建成功,已经可以在两个Tomcat server站点进行切换了。

相关推荐
PyAIGCMaster25 分钟前
ubuntu装P104驱动
linux·运维·ubuntu
奈何不吃鱼25 分钟前
【Linux】ubuntu依赖安装的各种问题汇总
linux·运维·服务器
icy、泡芙27 分钟前
T527-----音频调试
linux·驱动开发·音视频
aherhuo30 分钟前
kubevirt网络
linux·云原生·容器·kubernetes
zzzhpzhpzzz39 分钟前
Ubuntu如何查看硬件型号
linux·运维·ubuntu
蜜獾云41 分钟前
linux firewalld 命令详解
linux·运维·服务器·网络·windows·网络安全·firewalld
o(╥﹏╥)1 小时前
linux(ubuntu )卡死怎么强制重启
linux·数据库·ubuntu·系统安全
娶不到胡一菲的汪大东1 小时前
Ubuntu概述
linux·运维·ubuntu
Yuan_o_2 小时前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
那就举个栗子!2 小时前
Ubuntu 20.04下Kinect2驱动环境配置与测试【稳定无坑版】
linux·ubuntu