1、前言
apache+resin 来做想来大家都比较熟悉了,一般的配置都是很熟悉的了,我查看了一些论坛上的文章,这方便的文章比较多。在这里,我只要写写 apache+resin 实现独立的虚拟主机和 resin 自带的负载均衡。
2、系统和环境:
redhat9 and solaris9
httpd-2.50
resin-3.06
pure-ftpd-1.0.17a.tar.gz
3、安装软件:
3.1、安装 apache:
# tar zxvf httpd-2.49.tar.gz
# cd httpd-2.49
# ./configure --prefix=/usr/local/apache2 --enable-so --with-mpm=worker
# make
# make install
3.2、安装 resin:
# tar zxvf resin-3.06.tar.gz
# cd resin03.06
# ./configure --prefix=/usr/local/resin --with-apxs=/usr/local/apache2/bin/apxs
# make
# make install
3.3、安装 pureftp
# tar zxvf pure-ftpd-1.0.17a.tar.gz
# cd pure-ftpd-1.0.17a
# ./configure --prefix=/usr/local/pureftpd
--without-inetd --with-puredb
--with-cookie --with-throttling
--with-ratios --with-quotas
--with-ftpwho --with-largefile
--with-welcomemsg
# make
# make install
# mkdir /usr/local/pureftpd/etc
4、配置软件:
目的:用 apache 和 resin 做基于域名的虚拟主机,启用 resin 自身的负载均衡的引擎。resin 的负载均衡引擎实际上是可以启动多个 java 响应进程,通过内部机制来进行负载均衡。
4.1、配置 apache:
# vi /usr/local/apache2/conf/httpd.conf
---------------------------------------
DirctoryIndex index.html index.jsp
AddDefaultCharset Off
User nobody
Group nobody
NamevirtualHost 211.11.11.11
ServerAdmin peng.zhang@bj.china.com
DocumentRoot /data/web/xcity
ServerName xcity.chinaunix.com
ErrorLog logs/xcity.chinaunix.com-error_log
CustomLog logs/xcity.chinaunix.com-access_log common
ServerAdmin peng.zhang@bj.china.com
DocumentRoot /data/web/sports
ServerName sports.chinaunix.com
ErrorLog logs/sports.chinaunix.com-error_log
CustomLog logs/sports.chinaunix.com-access_log common
........
....
# mod_caucho Resin Configuration
#
LoadModule caucho_module /usr/local/apache2/modules/mod_caucho.so
ResinConfigServer 127.0.0.1
---------------------------------------
4.2、配置 resin:
# vi /usr/local/resin/conf/resin.conf
----------------------------------------
---注解:
(这里面,我用了系统本身的 127.0.0.1,绑定了 4 个端口做伏在均衡。还可以用不同的 ip 地址和同一端口,来作。例如:
还有些人,喜欢在 apache 中设置每一个 java 进程服务一个虚拟,这里我们不推荐,这样做,就会失去引擎本身的意义。)
/data/web/xcity
/opt/web/sports
........
....
--------------------------------------------------
---注:这里面是基于域名的虚拟主机,如果是针对ip的虚拟主机,在中,就应该是对应虚拟主机的 ip 了。也就是说,apache 和 resin 关于虚拟主机的地方要保持一致。还有,在 resin 中,对于每个虚拟主机所用的 web-app 目录,其实是相对于她的家目录下的/目录。
4.3、配置 pureftp
1、添加用户:
# pure-pw useradd xcityr -f /usr/local/pureftp/etc/ftppasswd -u nobody -g nobody -d /data/web/xcity -m
# pure-pw useradd sports -f /usr/local/pureftp/etc/ftppasswd -u nobody -g nobody -d /data/web/sports -m
---注:xcity :ftp 用户
-f ftppasswd:存放用户密码信息的文件
-u 用户 uid 一般是系统的一个用户,就是你的ftp用户的家目录的用户
-g 用户组 id
-d 锁定用户在家目录
-m 使 pureftp.d.passwd 写进 pureftpd.pdb,使更改生效。
*修改用户:
# pure-pw usermod --help
*删除用户:
# pure-pw userdel [-f ] [-m]
*更改拥护密码:
# pure-pw passwd [-f ] [-m]
*查看用户详细内容:
# pure-pw show [-f ]
*生成db文件,使密码生效:
# pure-pw mkdb [ [-f ]]
*列出所有用户:
# pure-pw list [-f ]
5、启动脚本:
当系统在 solaris 下:
apache 和 resin 的启动脚本:
# vi /etc/rc2.d/S99webapp
-------------------------------
/usr/local/resin/bin/httpd.sh -pid srun1.pid -server a start
/usr/local/resin/bin/httpd.sh -pid srun2.pid -server b start
/usr/local/resin/bin/httpd.sh -pid srun3.pid -server c start
/usr/local/resin/bin/httpd.sh -pid srun4.pid -server d start
/usr/local/apache2/bin/apachectl start
--------------------------------
pureftp 启动脚本:
--------------------------------
#!/bin/sh
/usr/local/pureftpd/sbin/pure-ftpd -j -lpuredb:/usr/local/pureftpd/etc/pureftpd.pdb &
-----------------------------------
在 linux 下,直接放到响应的开机启动等级目录下就 ok 了。
6、总结
apache+resin 应该是个很好的 java 应用平台了。实际使用中,还是有很多技巧。看了 resin 官方论坛的一些资料,说 resin3.x 以上的版本,对 image 和 html 的支持,比 apache 响应更快。我对此测试过,感觉还是有所欠缺。所以说,在大型一点的发布平台上,还是要 apache 和 resin 结合比较好。
对于 resin 的负载均衡使用上启动的进程数,我认为还是要根据自己的机器实际情况来考虑的。少了达不到效果,多了会机器系统也是一个负载。个人认为,4 个可以作为一个默认的选择来考虑。