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)
CentOS7+Nginx+多个Tomcat配置的更多相关文章
- centos7+nginx负载均衡Tomcat服务
接着上一篇:www.cnblogs.com/lkun/p/8252815.html 我们在上一篇在一台centos7服务器上部署了两个nginx,接下来我们使用一个nginx实现tomcat的负载均衡 ...
- Linux(CENTOS7) Nginx负载均衡简单配置
负载均衡的作用 1.转发功能 按照一定的算法[权重.轮询],将客户端请求转发到不同应用服务器上,减轻单个服务器压力,提高系统并发量. 2.故障移除 通过心跳检测的方式,判断应用服务器当前是否可以正常工 ...
- linux centos7 nginx 安装部署和配置
1/什么是NginxNginx("enginex")是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器,在高连接并发的情况下Nginx是Apac ...
- Centos7 nginx 反向代理的配置
一.正向代理与反向代理 1.正向代理 正向代理往VPN理解 正向代理,也就是传说中的代理,他的工作原理就像一个跳板(VPN),简单的说: 我是一个用户,我访问不了某网站,但是我能访问一个代理服务器,这 ...
- CentOS7+Nginx配置Tomcat负载均衡环境
1.准备两个Tomcat 配置两个Tomcat一个端口是8080另外一个端口是8081,分别在webapps下面添加一个测试用的web项目,修改index.jsp文件,8080端口的index.jsp ...
- CentOS7 Nginx安装及配置反向代理
背景: Mono (Mono JIT compiler version 5.4.0.201 ) jexus-5.8.2-x64(<CentOS7 安装 jexus-5.8.2-x64>) ...
- nginx + tomcat配置负载均衡
目标:Nginx做为HttpServer,连接多个tomcat应用实例,进行负载均衡. 注:本例程以一台机器为例子,即同一台机器上装一个nginx和2个Tomcat且安装了JDK1.7. 1.安装Ng ...
- nginx,apache,tomcat配置https的阿里提供的文档
安装证书 ( 1 ) 打开 Nginx 安装目录下 conf 目录中的 nginx.conf 文件,找到 # HTTPS server # #server { # listen 443; # serv ...
- 图文解说:Nginx+tomcat配置集群负载均衡
图文解说:Nginx+tomcat配置集群负载均衡 博客分类: appserver nginxTomcatUbuntuLinux网络应用 作者:niumd Blog:http://ari.iteye ...
随机推荐
- 14 ConfigParse模块
1.ConfigParse模块的基本概念 此模块用于生成和修改常见配置文档. ConfigParser 是用来读取配置文件的包. 配置文件的格式如下:中括号“[ ]”内包含的为section.sect ...
- 进入一个docker容器
Starting from Docker 1.3 you can use Docker exec to enter a Docker container : docker exec -it CONTA ...
- mysql优化连接数
很多开发人员都会遇见”MySQL: ERROR 1040: Too many connections”的异常情况,造成这种情况的一种原因是访问量过高,MySQL服务器抗不住,这个时候就要考虑增加从服务 ...
- Layouts
[Layouts] Each layout file must contain exactly one root element, which must be a View or ViewGroup ...
- luoguP3366 [模板] 最小生成树
题目链接:https://www.luogu.org/problemnew/show/P3366 思路: 求最小生成树的模板题,求MST有两种算法——Prim.Kruskal. 两者区别:Prim在稠 ...
- ECMAScript5之JSON对象属性的遍历顺序
测试浏览器 Chrome.Safari 一 键可以用parseInt解析成整数的,按数值升序顺序. var intObj = { '3.3' : 3.3, '2' : 222, '1' :111 } ...
- IIS7web服务器调试ASP.net程序遇到的一些故障的解决办法
1. [由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面] 故障描述:[由于 Web 服务器上的“ISAPI 和 CGI 限制”列表设置,无法提供您请求的页面] ...
- TZOJ 4746 Xiangqi(模拟棋盘数组)
描述 Xiangqi is one of the most popular two-player board games in China. The game represents a battle ...
- python之递归锁【Rlock】
# 递归锁:就是一把锁中还有一把小锁,比如学校的大门口有一个大锁,学校里的 #每个教室也有一把小锁,以后所有的锁都用rlock就可以了,不要用lock,尤其是多层锁的时候,必须要用递归锁 import ...
- eclipse奇怪问题之端口占用记录
启动程序报端口占用(实际并没有启动占用端口的程序) 打开cmd查找占用端口的进程能查到,但又无法杀掉(命令和任务管理器都杀不掉),用了PCHunter(xuetr)结束进程后还会刷新还会重新出现 重启 ...