【nginx反向代理多个tomcat服务】

第一步配置多个tomcat->修改tomcat/conf/server.xml中的3个端口号

tomcat的server.xml配置文件端口号作用简单说明及其他

这里我们从tomcat7.0下的conf目录文件下找到server.xml,打开它,发现它配置啦三个端口号,

server1:
8011
9001
8021
server2:
8012
9002
8022
server3:
8013
9003
8023:

第一个,我们可以看到这里是tomcat监听的关闭端口号,这里指定端口号为8005,


 
 
 
 
 
 
 
                  type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
 

下一部分,connector(连接器)用于监听请求,protocol(协议)HTTP/1.1协议,用于监听浏览器发送过来的请求,如果设置80或者8080端口,可以直接用http/://localhost访问。connectionTimeout连接超时时间,这里是20秒。如果发送的是https(http安全版)就将请求转发到8443端口。Tomcat服务器通过Connector连接器组件与客户程序建立连接,Connector组件负责接收客户的请求,以及把Tomcat服务器的响应结果发送给客户。默认情况下,Tomcat在server.xml中配置了两种连接器。

这个连接器监听8080端口,负责建立HTTP连接。在通过浏览器访问Tomcat服务器的Web应用时,使用的就是这个连接器。

 
                   connectionTimeout="20000"
               redirectPort="8443" />
下一部分,使用8009接收其他服务器转发的请求,AJP/1.3协议,用来监听其他服务器转发的请求,这里AJP13是定向包协议,因为性能原因,采用二进制格式来传输可读性文本。

这个连接器监听8009端口,负责和其他的HTTP服务器建立连接。在把Tomcat与其他HTTP服务器集成时,就需要用到这个连接器。


Web客户访问Tomcat服务器上JSP组件的两种方式如图1所示。

tomcat8以后默认编码格式是utf-8;7之前的都是iso8859-1,如果默认情况下,tomcat使用的的编码方式:iso8859-1,修改tomcat下的conf/server.xml文件找到如下代码:    

可以在这里添加一个属性:URIEncoding,将该属性值设置为UTF-8,即可让Tomcat(默认ISO-8859-1编码)以UTF-8的编码处理get请求。
修改完成后:

第二步:nginx反向代理多个tomcat服务

        nginx 异常的处理:

CentOS 7.5下启动Nginx出现如下错误:(由于配置文件的破坏或丢失造成,使用-c重置配置文件)

nginx: [error] open() "/run/nginx.pid" failed (2: No such file or directory)

解决方法:找到你的nginx.conf的文件夹目录,然后运行类似如下命令

nginx -c /etc/nginx/nginx.conf

再运行nginx -s reload,就可以了
 

一台Linux服务器有多个tomcat服务,多个端口不容易记忆,可以使用nginx反向代理,用一个端口访问到所有的tomcat服务。只需要安装一个nginx,然后配置反向代理即可。

安装nginx这里不在重复。安装好以后修改配置文件,在conf目录下的nginx.conf文件,server里配置反向代理的tomcat信息:

    server {
  #监听的端口
        listen       10001;
        server_name  192.168.1.221;
        location / {
            root   html;
            index  index.html index.htm;
        }
        location /aaa{ //配置反向代理的第一个tomcat服务
            root   html;
            proxy_pass  http://192.168.1.221:8080/aaa;
            proxy_set_header           Host $host;
            proxy_set_header  X-Real-IP  $remote_addr;
            proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for;
            client_max_body_size  100m;
            index  index.html index.htm;
        }

        location /bbb{//配置反向代理的第一个tomcat服务
            root   html;
            proxy_pass  http://192.168.1.221:8081/bbb;
            proxy_set_header           Host $host;
            proxy_set_header  X-Real-IP  $remote_addr;
            proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for;
            client_max_body_size  100m;
            index  index.html index.htm;
        }

配置完成以后重启nginx,然后就可以访问了

http://192.168.1.221:10001/aaa访问aaa服务

http://192.168.1.221:10001/bbb访问bbb服务
 

你可能感兴趣的:(servlet,tomcat,java)