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; }修改完成后需要先停止nginx然后再启动就行了(注:停止用./nginx -s quit|stop,且似乎没有status功能,可以自己ps -ef|grep nginx)
# 这一块不清楚干嘛用的 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; } }
posted on 2018-04-08 17:42 Silentdoer 阅读(885) 评论(0) 编辑 收藏 举报