对于java应用服务器,常用的一般为tomcat、jboss、resin。
一. 概述
经常会有这种情况:
1、一台服务器上,跑多个java应用
2、网站负载高,需要采用负载均衡(轮询)的方式来解决
一般用多个java应用服务器软件,或者用一个采用集群的方式;
二. 跑多个项目,或者做balance的方法
再安装一个resin,指向不同的项目目录
在安装完毕之后:
修改resin.conf里面的http port、cluster port和web-app目录;启动,就ok了。
方法二:只安装一个resin,使用不同的配置文件,指向不同的项目目录。方法二的配置相对复杂些。
1.安装好一个resin之后,cp resin.conf resin1.conf,分别修改另个resin,找到找到配置文件中的<!-- define the servers in the cluster -->,修改负载均衡配置,需要设置服务的ID、IP和port。 resin.conf修改为:
<server id="yk" address="127.0.0.1" port="6800"/>
resin1.conf 修改为:
<server id="yk1" address="127.0.0.1" port="6801"/>
resin2.con修改为:
<server id="yk2" address="127.0.0.1" port="6802"/> 注:其中修改http port,web-app 目录,jvm参数、最大线程数的修改,根据需要去调整。
2.拿部署的配置跟我的配置对比下:
[yangkai@mp2 conf]$ diff resin.conf webresin
84c84
< <cluster id="app-tier"> ---
> <cluster id="app-1">
107c107
< <jvm-arg>-Xmx256m</jvm-arg> ---
> <jvm-arg>-Xmx3096m</jvm-arg>
130c130
< <thread-max>256</thread-max> ---
> <thread-max>20480</thread-max>
149c149
< <server id="yk" address="127.0.0.1" port="6800"/> ---
> <server id="a" address="127.0.0.1" port="6801"/>
269a270 >
<stdout-log path="${resin.home}/log/stdout-cms.log" timestamp="[%Y-%m-%d %H:%M:%S.%s]" rollover-period="1D"/>
300c301
< <web-app id="/" root-directory="/home/yangkai/dir"/> ---
> <web-app id="/" root-directory="/data/touchcms"/>
[yangkai@mp2 conf]$ 其中84行的没必要修改。其中配置文件中,主要修改的,也就这些参数。
3.启动过程
[yangkai@mp2 conf]$ ../bin/httpd.sh -conf ./webresin.conf -server
[yangkai@mp2 conf]$ vim startallre.sh "startallre.sh" [New File]~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 0,0-1 All-- INSERT --0,1 All
#!/bin/bash2,1 All
/opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-cms.conf -server a start
/opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-zixun.conf -server b start
/opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-shenghuo.conf -server c start
/opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-kefu.conf -server d start
6,78 All:6,79 All6,78 All6,77 All:% :%s :%s/ :%s// :%s/// :%s///g :%s/o//g :%s/op//g :%s/opt//g :%s/opt/h/g :%s/opt/ho/g :%s/opt/hom/g :%s/opt/home/g :%s/opt/home 8 substitutions on 4 lineshome/resin/bin/httpd.sh -conf /home/resin/conf/resin-cms.conf -server a start
/home/resin/bin/httpd.sh -conf /home/resin/conf/resin-zixun.conf -server b start
/home/resin/bin/httpd.sh -conf /home/resin/conf/resin-shenghuo.conf -server c start
/home/resin/bin/httpd.sh -conf /home/resin/conf/resin-kefu.conf -server d start
6,1 All 8 substitutions on 4 lines6,1 All6,1 All4 changes; before #2 3 seconds ago
opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-cms.conf -server a start
opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-zixun.conf -server b start
opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-shenghuo.conf -server c start
opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-kefu.conf -server d start
3,1 All:% :%s :%s/ :%s// :%s/// :%s///g :%s/o//g :%s/op//g :%s/opt//g :%s/opt/&/g :%s/opt/&\/g :%s/opt/&\//g :%s/opt/&\/h/g :%s/opt/&\/ho/g :%s/opt/&\/hom/g :%s/opt/&\/home/g :%s/opt/&\/home 8 substitutions on 4 lineshome/resin/bin/httpd.sh -conf /opt/home/resin/conf/resin-cms.conf -server a starthome/resin/bin/httpd.sh -conf /opt/home/resin/conf/resin-zixun.conf -server b starthome/resin/bin/httpd.sh -conf /opt/home/resin/conf/resin-shenghuo.conf -server c starthome/resin/bin/httpd.sh -conf /opt/home/resin/conf/resin-kefu.conf -server d start6,1 All 8 substitutions on 4 lines6,1 All6,1 All4 changes; before #3 8 seconds agoresin/bin/httpd.sh -conf /opt/resin/conf/resin-cms.conf -server a startresin/bin/httpd.sh -conf /opt/resin/conf/resin-zixun.conf -server b startresin/bin/httpd.sh -conf /opt/resin/conf/resin-shenghuo.conf -server c startresin/bin/httpd.sh -conf /opt/resin/conf/resin-kefu.conf -server d start3,1 All:% :%s :%s/ :%s// :%s/// :%s///g :%s/o//g :%s/op//g :%s/opt//g :%s/opt/h/g :%s/opt/ho/g :%s/opt/hom/g :%s/opt/home/g :%s/opt/home\/g :%s/opt/home\//g :%s/opt/home\/y/g :%s/opt/home\/ya/g :%s/opt/home\/yan/g :%s/opt/home\/yang/g :%s/opt/home\/yangk/g :%s/opt/home\/yangka/g :%s/opt/home\/yangkai/g :%s/opt/home\/yangkai 8 substitutions on 4 lineshome/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin-cms.conf -server a start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin-zixun.conf -server b start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin-shenghuo.conf -server c start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin-kefu.conf -server d start6,1 All 8 substitutions on 4 lines6,1 All6,1 All~ 5,1 All4,1 All4,2 All4,3 All4,4 All4,5 All4,6 All4,7 All4,8 All4,9 All4,10 All4,11 All4,12 All4,13 All4,14 All4,15 All4,16 All4,17 All4,18 All4,19 All4,20 All4,21 All4,22 All4,23 All4,24 All4,25 All4,26 All4,27 All4,28 All4,29 All4,30 All4,31 All4,32 All4,33 All4,34 All4,35 All4,36 All4,37 All4,38 All4,39 All4,40 All4,41 All4,42 All4,43 All4,44 All4,45 All4,46 All4,47 All4,48 All3,48 All3,49 All3,50 All3,51 All3,52 All3,53 All3,54 All3,55 All3,56 All3,57 All3,58 All3,59 All3,60 All3,61 All3,62 All3,63 All3,64 All3,65 All3,66 All3,67 All3,68 All3,69 All3,70 Allcms.conf -server a startms.conf -server a starts.conf -server a start.conf -server a start4,70 Allzixun.conf -server b startixun.conf -server b startxun.conf -server b startun.conf -server b startn.conf -server b start.conf -server b start-- INSERT --4,70 All1.conf -server b start4,71 All5,71 All5,70 Allx-shenghuo.conf -server c start5,71 Allx-shenghuo.conf -server c start5,72 All5,73 All5,74 All5,75 All5,76 All5,77 All5,78 All5,79 All5,80 All5,81 Al.conf -server c start5,80 Al.conf -server c start5,79 Al.conf -server c start5,78 Al.conf -server c start5,77 Al.conf -server c start5,76 Al.conf -server c start5,75 Al.conf -server c start5,74 Al.conf -server c start5,73 Al.conf -server c start5,72 Al.conf -server c start5,71 Al.conf -server c start5,70 All2.conf -server c start5,71 All4,71 All3,71 All3,72 All3,73 All3,74 All3,75 All3,76 All3,77 All3,78 All3,79 All3,80 All3,81 All3,82 All3,83 All3,84 All3,85 Al start3,84 Ally start3,85 Alll start3,86 Al start3,85 Allk start3,86 All4,86 Al start4,85 Ally start4,86 Allk start4,87 All1 start4,88 All5,88 All5,87 All5,86 Al start5,85 Ally start5,86 Allk start5,87 All2 start5,88 All5,87 All:w :wq :wq "startallre.sh" "startallre.sh" [New] 5L, 293C written [yangkai@mp2 conf]$ cp startallre.sh stopallre.sh [yangkai@mp2 conf]$ vim stopallre.sh "stopallre.sh" "stopallre.sh" 5L, 293C#!/bin/bash
/home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin.conf -server yk start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin1.conf -server yk1 start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin2.conf -server yk2 start ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 1,1 All:% :%s :%s/ :%s// :%s/// :%s///g :%s/s//g :%s/st//g :%s/str//g :%s/str :%s/st//g:%s/sta//g :%s/star//g :%s/start//g :%s/start/s/g :%s/start/st/g :%s/start/sto/g :%s/start/stop/g :%s/start/stop 3 substitutions on 3 linesopopop5,1 All 3 substitutions on 3 lines5,1 All5,1 All:w :wq :wq "stopallre.sh" "stopallre.sh" 5L, 290C written [yangkai@mp2 conf]$ chmod +x *sh [yangkai@mp2 conf]$ ./stopallre.sh Resin/3.1.10 can't stop -server 'yk' for watchdog at 127.0.0.1:6600. java.lang.IllegalStateException: Can't connect to ResinWatchdogManager. java.net.ConnectException: http://127.0.0.1:6600/watchdog: Connection refused Resin/3.1.10 can't stop -server 'yk1' for watchdog at 127.0.0.1:6600. java.lang.IllegalStateException: Can't connect to ResinWatchdogManager. java.net.ConnectException: http://127.0.0.1:6600/watchdog: Connection refused Resin/3.1.10 can't stop -server 'yk2' for watchdog at 127.0.0.1:6600. java.lang.IllegalStateException: Can't connect to ResinWatchdogManager. java.net.ConnectException: http://127.0.0.1:6600/watchdog: Connection refused [yangkai@mp2 conf]$ ./startallre.sh Resin/3.1.10 started -server 'yk' for watchdog at 127.0.0.1:6600 Resin/3.1.10 started -server 'yk1' for watchdog at 127.0.0.1:6600 Resin/3.1.10 started -server 'yk2' for watchdog at 127.0.0.1:6600 [yangkai@mp2 conf]$ netstat -tnl Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:29472 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:14538 0.0.0.0:* LISTEN tcp 0 0 192.168.61.68:1521 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:37494 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:49400 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6012 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6013 0.0.0.0:* LISTEN tcp 0 0 ::ffff:127.0.0.1:6600 :::* LISTEN tcp 0 0 :::29518 :::* LISTEN tcp 0 0 :::8080 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6800 :::* LISTEN tcp 0 0 :::8081 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6801 :::* LISTEN tcp 0 0 :::8082 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6802 :::* LISTEN tcp 0 0 :::26645 :::* LISTEN tcp 0 0 :::22 :::* LISTEN tcp 0 0 ::1:6012 :::* LISTEN tcp 0 0 ::1:6013 :::* LISTEN tcp 0 0 :::23070 :::* LISTEN tcp 0 0 :::9758 :::* LISTEN [yangkai@mp2 conf]$ ./stopallre.sh Resin/3.1.10 stopped -server 'yk' for watchdog at 127.0.0.1:6600 Resin/3.1.10 stopped -server 'yk1' for watchdog at 127.0.0.1:6600 Resin/3.1.10 stopped -server 'yk2' for watchdog at 127.0.0.1:6600 [yangkai@mp2 conf]$ netstat -tnl Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:14538 0.0.0.0:* LISTEN tcp 0 0 192.168.61.68:1521 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:20370 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:6999 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6012 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6013 0.0.0.0:* LISTEN tcp 0 0 0.0.0.0:43583 0.0.0.0:* LISTEN tcp 0 0 :::22 :::* LISTEN tcp 0 0 ::1:6012 :::* LISTEN tcp 0 0 ::1:6013 :::* LISTEN [yangkai@mp2 conf]$ cat startallre.sh #!/bin/bash
/home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin.conf -server yk start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin1.conf -server yk1 start /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin2.conf -server yk2 start [yangkai@mp2 conf]$ cat stopallre.sh #!/bin/bash
/home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin.conf -server yk stop /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin1.conf -server yk1 stop /home/yangkai/resin/bin/httpd.sh -conf /home/yangkai/resin/conf/resin2.conf -server yk2 stop [yangkai@mp2 conf]$ echo "i will go to sleep,bye. i will go to sleep,bye. [yangkai@mp2 conf]$
### END LOG - DATE: 120429, TIME: 004713 ###
[yangkai@mp2 dir1]$ cd WEB-INF/ [yangkai@mp2 WEB-INF]$ ls classes tmp work [yangkai@mp2 WEB-INF]$ file work/_jsp/_index__jsp. _index__jsp.class _index__jsp.java _index__jsp.java.smap [yangkai@mp2 WEB-INF]$ file work/_jsp/_index__jsp.java work/_jsp/_index__jsp.java: ASCII C program text [yangkai@mp2 WEB-INF]$ file work/_jsp/_index__jsp.jav work/_jsp/_index__jsp.java work/_jsp/_index__jsp.java work/_jsp/_index__jsp.java l work/_jsp/_index__jsp.java l work/_jsp/_index__jsp.java-rwxr-xr-x 1 root root 5611 Apr 28 19:35 work/_jsp/_index__jsp.java [yangkai@mp2 WEB-INF]$ ;s -bash: syntax error near unexpected token `;' [yangkai@mp2 WEB-INF]$ cd .. [yangkai@mp2 dir1]$ sudo chmod -R 777 /home/yangkai/*
[sudo] password for yangkai: [yangkai@mp2 dir1]$ echo "ok ok [yangkai@mp2 dir1]$
4.64上查看:
61.64 [root@mp2 conf]# netstat -tnl Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:21 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6011 0.0.0.0:* LISTEN tcp 0 0 :::8096 :::* LISTEN tcp 0 0 :::2499 :::* LISTEN tcp 0 0 :::50790 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6600 :::* LISTEN tcp 0 0 :::5001 :::* LISTEN tcp 0 0 :::42985 :::* LISTEN tcp 0 0 :::8080 :::* LISTEN tcp 0 0 :::80 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6801 :::* LISTEN tcp 0 0 :::8081 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6802 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6803 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6804 :::* LISTEN tcp 0 0 :::12470 :::* LISTEN tcp 0 0 :::22 :::* LISTEN tcp 0 0 ::1:6011 :::* LISTEN tcp 0 0 :::6972 :::* LISTEN tcp 0 0 :::8095 :::* LISTEN [root@mp2 conf]# ../bin/httpd.sh -conf ./resin-kefu.conf -server d stop Resin/3.1.10 stopped -server 'd' for watchdog at 127.0.0.1:6600 [root@mp2 conf]# ../bin/httpd.sh -conf ./resin-kefu.conf -server d start Resin/3.1.10 can't start -server 'd' for watchdog at 127.0.0.1:6600. com.caucho.config.ConfigException: Resin/3.1.10 can't find configuration file '/opt/resin/resin-kefu.conf' [root@mp2 conf]# netstat -tnl Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:21 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6010 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6011 0.0.0.0:* LISTEN tcp 0 0 :::2499 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6600 :::* LISTEN tcp 0 0 :::5001 :::* LISTEN tcp 0 0 :::42985 :::* LISTEN tcp 0 0 :::8080 :::* LISTEN tcp 0 0 :::80 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6801 :::* LISTEN tcp 0 0 :::8081 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6802 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6803 :::* LISTEN tcp 0 0 :::12470 :::* LISTEN tcp 0 0 :::22 :::* LISTEN tcp 0 0 ::1:6010 :::* LISTEN tcp 0 0 ::1:6011 :::* LISTEN tcp 0 0 :::6972 :::* LISTEN tcp 0 0 :::8095 :::* LISTEN [root@mp2 conf]# [root@mp2 conf]# cat /opt/resin/startall.sh #!/bin/bash
/opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-cms.conf -server a start /opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-zixun.conf -server b start /opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-shenghuo.conf -server c start /opt/resin/bin/httpd.sh -conf /opt/resin/conf/resin-kefu.conf -server d start
[root@mp2 conf]# . /opt/resin/stopall.sh Resin/3.1.10 stopped -server 'a' for watchdog at 127.0.0.1:6600 Resin/3.1.10 stopped -server 'b' for watchdog at 127.0.0.1:6600 Resin/3.1.10 stopped -server 'c' for watchdog at 127.0.0.1:6600 Resin/3.1.10 can't stop -server 'd' for watchdog at 127.0.0.1:6600. java.lang.IllegalStateException: Can't connect to ResinWatchdogManager. java.net.ConnectException: http://127.0.0.1:6600/watchdog: Connection refused [root@mp2 conf]# . /opt/resin/startall.sh Resin/3.1.10 started -server 'a' for watchdog at 127.0.0.1:6600 Resin/3.1.10 started -server 'b' for watchdog at 127.0.0.1:6600 Resin/3.1.10 started -server 'c' for watchdog at 127.0.0.1:6600 Resin/3.1.10 started -server 'd' for watchdog at 127.0.0.1:6600 [root@mp2 conf]#netstat -tnl Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State tcp 0 0 0.0.0.0:21 0.0.0.0:* LISTEN tcp 0 0 127.0.0.1:6011 0.0.0.0:* LISTEN tcp 0 0 :::8096 :::* LISTEN tcp 0 0 :::2499 :::* LISTEN tcp 0 0 :::50790 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6600 :::* LISTEN tcp 0 0 :::5001 :::* LISTEN tcp 0 0 :::42985 :::* LISTEN tcp 0 0 :::8080 :::* LISTEN tcp 0 0 :::80 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6801 :::* LISTEN tcp 0 0 :::8081 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6802 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6803 :::* LISTEN tcp 0 0 ::ffff:127.0.0.1:6804 :::* LISTEN tcp 0 0 :::12470 :::* LISTEN tcp 0 0 :::22 :::* LISTEN tcp 0 0 ::1:6011 :::* LISTEN tcp 0 0 :::6972 :::* LISTEN tcp 0 0 :::8095 :::* LISTEN
[root@mp2 conf]#
三、小结
1.使用resin版本很重要,上面是使用resin3.1.8测试的结果,使用reisn3.0.*就不行,前者的http.sh是40行,后者是84行;前者的resin.conf是正常的,后者里面找不到:
<cluster id="app-tier"> <!-- 设置集群上下文的根, 相对于server.root --> <root-directory>.</root-directory> 也没有:
<!-- define the servers in the cluster --> 配置起来很麻烦。。。
2.其中如果对于方法的操作,resin的其启动与关闭,必须全部一起操作,否则就不会成功。这个是我测试的结果,开始我也以为不影响,调试了几个小时,最后发现是这个问题。也许是因为我某个地方配置不正确,谁知道请告诉我下,谢谢。
四、问题
关于性能上的问题,是使用一个resin使用不同的配置文件做集群性能好,还是安装多个resin性能好?如网站执行效率,服务器资源消耗等方面。