CentOS7+Nginx+多个Tomcat配置

转载自:https://blog.csdn.net/name_chc/article/details/73332272;亲测可用,加了一些注释;

配置多个tomcat转发

另附上tomcat启动慢的解决方案

需要在jdk下面修改一个配置

/usr/jdk/jdk1.7.0_80/jre/lib/security

找到java.security这个文件里面的securerandom.source

修改里面的配置如下即可

securerandom.source=file:/dev/./urandom

本服务器有3个相同的tomcat对外分别为8080端口8090端口9000端口

需要在服务器根目录下面找到

vi /etc/profile

增加里面的配置如下(建议在文件内容的末尾处增加)

TOMCAT_HOME_8090=/usr/tomcat/tomcat-8090
CATALINA_HOME_8090=/usr/tomcat/tomcat-8090
CATALINA_BASE_8090=/usr/tomcat/tomcat-8090
export  TOMCAT_HOME_8090  CATALINA_HOME_8090 CATALINA_BASE_8090


TOMCAT_HOME=/usr/tomcat/tomcat-8080
CATALINA_HOME=/usr/tomcat/tomcat-8080
CATALINA_BASE=/usr/tomcat/tomcat-8080
export  TOMCAT_HOME  CATALINA_HOME CATALINA_BASE


TOMCAT_HOME_9000=/usr/tomcat/tomcat-9000
CATALINA_HOME_9000=/usr/tomcat/tomcat-9000
CATALINA_BASE_9000=/usr/tomcat/tomcat-9000
export  TOMCAT_HOME_9000  CATALINA_HOME_9000 CATALINA_BASE_9000

增加完成后需要让配置文件的配置立即生效

执行命令source  /etc/profile

然后修改tomcat的启动项和停止项的命令文件(演示一个tomcat的修改方式,其他tomcat修改方式类似)

startup.sh修改如下

需要在exec "$PRGDIR"/"$EXECUTABLE" start "$@"前增加如下配置(注:配置这些是因为tomcat由jvm实例启动,而启动jvm实例又通过shell脚本,故可以在shell脚本里配置用什么jre,启动参数什么的)

export JAVA_HOME=/usr/jdk/jdk1.7.0_80  #jdk的目录
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=$JAVA_HOME/lib
export CATALINA_HOME=$CATALINA_HOME_9000  #注意这里关联的是profile中刚刚设置的环境变量名(不同的tomcat变量名称不一样)
export CATALINA_BASE=$CATALINA_BASE_9000   #注意这里关联的是profile中刚刚设置的环境变量名(不同的tomcat变量名称不一样)


shutdown.sh修改如下

需要在exec "$PRGDIR"/"$EXECUTABLE" start "$@"前增加如下配置

export JAVA_HOME=/usr/jdk/jdk1.7.0_80  #jdk的目录
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=$JAVA_HOME/lib
export CATALINA_HOME=$CATALINA_HOME_9000  #注意这里关联的是profile中刚刚设置的环境变量名(不同的tomcat变量名称不一样)
export CATALINA_BASE=$CATALINA_BASE_9000   #注意这里关联的是profile中刚刚设置的环境变量名(不同的tomcat变量名称不一样)

注意端口号需要在tomcat下面的conf文件夹中修改server.xml(注:有多少个tomcat可能被启动就要修改多少个tomcat下的server.xml配置,后者tomcat启动会产生端口占用的情况)

修改端口号的地方为以前是8080现在被改成了9000

    <Connector port="9000" protocol="HTTP/1.1"(注:这个地方还可以修改默认的字符编码,如果是tomcat8以上默认是utf8)
               connectionTimeout="20000"
               redirectPort="8443" />(注:这个redirectPort似乎是如果以类似https访问8080端口则会被转接到8443端口上??,但是一般不会出现)

光修改端口号可不行还需要修改的配置如下

这里原始的是8005被修改成了8007(因为这里存在3个tomcat所以现在被修改成了8007)(注:是三个分别为8005/8006/8007,这个server port是类似rabbitmq中给ctl开放的端口,即我可以向这个端口发送shutdown命令来执行tomcat内部的关闭操作而不是kill)

<Server port="8007" shutdown="SHUTDOWN">

这里原始的是8009被修改成了8011(因为这里存在3个tomcat所以现在被修改成了8011)(注:即便自己没用到这个功能但是这里配置了那么启动tomcat时就会去监听它,故不能重复)

<Connector port="8011" protocol="AJP/1.3" redirectPort="8443" />

以上条件满足的是不同的tomcat都需要修改以上配置且不能相同

如果tomcat启动不报错就算完成了

好了tomcat需要修改的配置就完成了接下来是nginx的配置

注意:改配置文件的user配置可能与自己配的不一致(注:我个人的user是nginx,其实用root也可以)

nginx.config 配置参照如下如需直接使用需要修改成自己的域名即可

user www www;  # 注:可不配
worker_processes 1; #设置值和CPU核心数一致
error_log /usr/nginx/logs/nginx_error.log crit; #日志位置和日志级别;注:可用相对路径,相对于nginx安装目录
pid /usr/nginx/nginx.pid;
#Specifies the value for maximum file descriptors that can be opened by this process.
worker_rlimit_nofile 65535;  # 注:这个是配置worker_processes可以打开的最大文件数,一般不需要这么高;
events
{
  use epoll;  # 注:一个很有名的组件,并为nginx实现只是用到了此工具
  worker_connections 65535;  # 最大tcp连接数
}
http
{
  include mime.types;
  default_type application/octet-stream;
  log_format main  '$remote_addr - $remote_user [$time_local] "$request" '
               '$status $body_bytes_sent "$http_referer" '
               '"$http_user_agent" $http_x_forwarded_for';
  
#charset gb2312;  # 注server内也可以定义,这个是通用的??
     
  server_names_hash_bucket_size 128;
  client_header_buffer_size 32k;  # 注:这几行应该是指客户端请求数据的限制
  large_client_header_buffers 4 32k;
  client_max_body_size 8m;
     
  sendfile on;
  tcp_nopush on;
  keepalive_timeout 60;
  tcp_nodelay on;
  fastcgi_connect_timeout 300;
  fastcgi_send_timeout 300;
  fastcgi_read_timeout 300;
  fastcgi_buffer_size 64k;
  fastcgi_buffers 4 64k;
  fastcgi_busy_buffers_size 128k;
  fastcgi_temp_file_write_size 128k;
  gzip on;  # 注:开启gzip,tomcat里可以不用开了,或者这里不开tomcat里开启(感觉后者好一点,毕竟一个nginx服务于多个tomcat)
  gzip_min_length 1k;
  gzip_buffers 4 16k;
  gzip_http_version 1.0;
  gzip_comp_level 2;
  gzip_types text/plain application/x-javascript text/css application/xml;
  gzip_vary on;
 
  #limit_zone crawler $binary_remote_addr 10m;
 #下面是server虚拟主机的配置
  server
  {
   listen 80;#监听端口
    server_name app.sunmear.com;#域名
   location /
   {
      root html;
      proxy_pass http://127.0.0.1:9000;
   }
   #解决无法显示图片的问题
    location ~ .*.(gif|jpg|jpeg|png|bmp|swf|ico|js|css)$
    {
      root html;
      proxy_pass http://127.0.0.1:9000;
        expires 30d;
        # access_log off;
    }
   #解决的无法加载样式的问题
    location ~ .*.(js|css)?$
    {
      root html;
      proxy_pass http://127.0.0.1:9000;
        expires 15d;
       # access_log off;
    }
# 这一块不清楚干嘛用的 location ~ .*.(php|php5)?$ { #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi.conf; } access_log off; } server { listen 80;#监听端口 server_name www.sunmear.com;#域名 location / { root html; proxy_pass http://127.0.0.1:8080; } location ~ .*.(gif|jpg|jpeg|png|bmp|swf|ico|js|css)$ { root html; proxy_pass http://127.0.0.1:8080; expires 30d; # access_log off; } location ~ .*.(js|css)?$ { root html; proxy_pass http://127.0.0.1:8080; expires 15d; # access_log off; } location ~ .*.(php|php5)?$ { #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:8080; fastcgi_index index.php; include fastcgi.conf; } access_log off; # 注:关闭访问记录日志; } server { listen 80;#监听端口 server_name wap.sunmear.com;#域名(注:并非context,浏览器客户端区分不了context,只能区分不同的域名,context也会在请求行里而非host里) location / { root html; proxy_pass http://127.0.0.1:8090; } location ~ .*.(gif|jpg|jpeg|png|bmp|swf|ico|js|css)$ { root html; proxy_pass http://127.0.0.1:8090; expires 30d; # access_log off; } location ~ .*.(js|css)?$ { root html; proxy_pass http://127.0.0.1:8090; expires 15d; # access_log off; } location ~ .*.(php|php5)?$ { #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:8090; fastcgi_index index.php; include fastcgi.conf; } access_log off; } }
修改完成后需要先停止nginx然后再启动就行了(注:停止用./nginx -s quit|stop,且似乎没有status功能,可以自己ps -ef|grep nginx)
原文地址:https://www.cnblogs.com/silentdoer/p/8746337.html