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 ...
随机推荐
- Git revert merge
从history1分出来的A, B两个branch A上有一些更改,例如 changeA2 changeA1 history1 B上有一些更改,例如 changeB2 changeB1 history ...
- session会话管理,与过滤器使用,访问控制
1 用户登录,是否注册用户,在登录处理页面进行用户验证,创建session保存用户名和密码 2否,进入用户注册页面 3是,系统保存该用户的登录信息 4进入要访问的页面 5用户直接访问某个页面, 6系统 ...
- 通过Chrome的inspect对手机webview进行调试
使用chrome的inspect可以对手机上的webview进行调试,因为真机没有什么比较好的调试工具,而chrome提供了这一个工具可以比较方便的查看真机上的元素,以及进行调试. 其实我对webvi ...
- jdbcTemplate in
参考 http://blog.csdn.net/gaopeng0071/article/details/75049952 使用NamedParameterJdbcTemplate public cla ...
- html图片链接不显示图片
html图片链接不显示图片,如下示: <a href="index.jsp"><img src="/img/index.png"/>&l ...
- hdoj1114 Piggy-Bank(DP 完全背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1114 思路: 题目看着有些绕,其实就是完全背包的变形,需要注意的是这里求最小值,所以需要将dp数组初始 ...
- Java 深浅拷贝
2016-07-02 1深拷贝:不仅拷贝对象,而且对象所引用地址的内容一块拷贝.改变一个对象的某个属性,并不影响另一个对象所引用的内容. 2浅拷贝:仅拷贝对象本身,并不对所引用(所指的)内容进行拷贝, ...
- [udemy]WebDevelopment_How the Internet Works
Browsing the web Enter google.com, who is this google.com This question gets asked all the way down ...
- 每天学一点儿HTML5的新标签
sections部分 (http://www.w3.org/TR/html5/sections.html) 标签:article article标签用来表示页面中一段完整的可以自我包含的片段,具有可重 ...
- 13-前端不通路径同一个请求访问同一个页面时,有时样式没有加载出来(jss,image,css)
通过如下方式访问同一个网站时,下面一个可以加载样式,而下面一个加载的页面却没有样式,思考良久没有想通,当时也忘记了用浏览器看下 css,js,image的请求路径,其实在前端页面里面我直接: 这样引 ...