Linux系统:选用Redhat的开源版本CentOS操作系统(这里用CentOS 5.5版本)
JDK:选用版本为jdk1.7.0_45,安装包jdk-7u45-linux-i586.tar.gz
Apache:选用版本2.4.7,安装包httpd-2.4.7.tar.gz
Tomcat:选用版本7.0.47,安装包apache-tomcat-7.0.47.tar.gz
JK:选用版本1.2.37,安装包:tomcat-connectors-1.2.37-src.tar.gz
找一台计算机做linux服务器,在上面安装CentOS操作系统,可以采用光盘安装、u盘安装等方式进行,网络上有很多相对完整的教程,这里就不做具体阐述了
在linux服务器上安装CentOS之后,事先将所有软件的安装包上传到linux服务器上,并放置在/software目录下。
JDK安装(1):如图所示,因为CentOS自带有open jdk,需要将其删除,再重新安装oracle jdk。但如果直接在centOS的“应用程序--添加/删除软件--基本系统--java”中,删除java,与之相关的openoffice等软件,也会自动随之删除,因此,在进行原有的jdk删除之前,最好先安装配置好新的jdk及相应的环境。
JDK安装(2):安装下载的oracle jdk。 (1)在/usr/local目录下新建Java文件夹,并将安装包从/software目录拷贝到/usr/local/Java目录下(图形界面下直接“复制”-“粘贴”即可)。 #cp /software/jdk-7u45-linux-i586.tar.gz/usr/local/Java (2)定位到文件夹/usr/local/Java。 #cd /usr/local (3)解压安装包到当前目录。 #tar -zxvf jdk-7u45-linux-i586.tar.gz (4)配置java的环境变量。为了系统中所有用户都能使用java环境,修改系统中的环境配置文件/etc/profile。在文件最后添加下列语句: export JAVA_HOME=/usr/local/Java/jdk1.7.0_45 export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib export PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin (5)修改完成以后,logout再重新登陆,或#source /etc/profile,使文件立即生效。
JDK安装(3):查看与系统自带open jdk有关的包。在终端中输入“rpm -qa|grep gcj”,查看gcj的版本号,在这里得到的结果如图所示:
JDK安装(4):卸载系统自带open jdk。 在终端中输入“yum -y remove javajava-1.4.2-gcj-compat-1.4.2.0-40jpp.115”,然后等待,等待系统卸载完自带的jdk。最终在终端中显示“Complete!”,卸载完成。
JDK安装(5):卸载系统自带open jdk时出现问题及解决方案。【问题】使用yum安装或卸载软件,出现如图所示的提示错误。 原因是系统进程已经有一个yum的update进程在运行了。可用ps -ef | grep update查看进程。解决办法是在命令行输入下面两条命令: #rm -f/var/run/yum.pid /sbin/service #yum-updatesdrestart然后重新执行yum的删除命令即可。
JDK安装(6):查看jdk版本。 在命令行中输入java -version命令可查看安装的jdk版本。如果显示出jdk安装的版本信息则说明jdk安装成功。 如果出现如图所示的错误信息,则是因为系统的selinux的设置问题,即开启了selinux服务。解决办法如下:(1)打开/etc/selinux/config;(2)把selinux=enforcing改为selinux=disabled;(3)重启linux。
Apache安装(1):如下图所示,使用# rpm -qa|grep httpd,查看与httpd相关软件包。发现CentOS自带有apache,版本为2.2.3。因此在安装我们需要的apache之前,需要卸载CentOS自带的apache。
Apache安装(2):卸载CentOS自带Apache。 上一步我们已经查看了与httpd相关的软件包,这一步要删除删除httpd。在命令行中使用:# rpm -e httpd。 如果出现如图所示错误,说明还有一个相关的软件包没有删除,清除之,即:# rpm -e gnome-user-share。
Apache安装(3):再次删除httpd:# rpm -e httpd。 可以使用参数--nodeps的意思就是不管各个程序包间的依赖关系。#rpm -e --nodeps httpd //这样不需要删除gnome-user-share了。
Apache安装(4):重新安装自己下载的Apache(1)将安装包从/software目录拷贝到/usr/local目录下。 #cp /software/httpd-2.4.7.tar.gz /usr/local(2)定位到文件夹/usr/local。 #cd /usr/local(3)解压安装包到当前目录。 #tar -zxvf httpd-2.4.7.tar.gz (4)定位到文件夹/usr/local /httpd-2.4.7。 #cd httpd-2.4.7(5)设置安装路径和需要编译的模块。 # ./configure--prefix=/usr/local/apache --enable-so -enable-proxy -enable-proxy_http=shared--enable-module=so --enable-mods-shared=all --enable-proxy-ajp=shared --enable-proxy-balancer -with-mpm=worker//备注:prefix定义apache的安装路径(6)编译通过,继续安装apache。 #make && makeinstall
Apache安装(5):apache安装的check过程中出错,如图所示:APR not found 。原因是没有安装apr。在/usr/local目录下安装apr: #tar -zxvf apr-1.5.0.tar.gz #cd apr-1.5.0 #./configure --prefix=/usr/local/apr #make #make install安装完成后再来configure apache。
Apache安装(6):apache安装的check过程中出错,如图所示:APR-util not found。原因是没有安装apr-util。 在/usr/local目录下安装apr-util: #tar -zxvf apr-util-1.5.3.tar.gz #cd apr-util-1.5.3 #./configure--prefix=/usr/local/apr-util --with-apr=/usr/local/apr #make #make install安装完成后,在apache的./configure 最后增加--with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util,重新configure apache。
Apache安装(7):apache安装的check过程中出错,如图所示,原因是没有安装pcre。在/usr/local目录下安装pcre: # tar -zxvf pcre-8.32.tar.gz #cd pcre-8.32 #./configure--prefix=/usr/local/pcre #make #make install安装完成后,在apache的./configure 最后增加./configure 时加上参数 --with-apr=/usr/local/apr/ --with-apr-util=/usr/local/apr-util/--with-pcre=/usr/local/pcre,重新configure apache。
Apache安装(8):编译通过,继续安装apache。 #make && makeinstall 。
Apache配置及测试(1):安装完毕后,在测试启动apache之前先修改/apache/conf /httpd.conf。 (1)查找ServerName,打开注释,将ServerName值改为对应的IP地址。 (2)在DirectoryIndex中添加 index.jsp。 (3)以下2个注释去掉: #Include conf/extra/httpd-mpm.conf #Include conf/extra/httpd-default.conf
Apache配置及测试(2):保存httpd.conf文件的修改,启动apache服务。 # /usr/local/apache/bin/apachectl start 浏览器访问http://127.0.0.1,提示无法连接。说明apache没有成功启动。查看错误日志(/apache/logs/error_log),发现如图错误信息。原因是httpd.conf里面的mod_slotmem_shm.so没有加载。将httpd.conf 文件中的“#LoadModule slotmem_shm_module modules/mod_slotmem_shm.so”前的“#”去掉即可。
Apache配置及测试(3):(1)重新启动apache并查看httpd是否运行。 # /usr/local/apache/bin/apachectl start # ps -ef | grep httpd(2)浏览器测试apache。在浏览器中访问http://127.0.0.1 。页面出现“It's Works!”字样即为成功。
Apache的启动和关闭:在/usr/local/apache/bin下有可执行程序。(1)启动apache服务:# /usr/local/apache/bin/apachectl start(2)关闭apache服务:# /usr/local/apache/bin/apachectlstop(3)重启apache服务:# /usr/local/apache/bin/apachectl restart
Tomcat安装、测试及配置(1):安装tomcat(1)将安装包从/software目录拷贝到/usr/local目录下(图形界面下直接“复制”-“粘贴”即可)。 #cp /software/apache-tomcat-7.0.47.tar.gz/usr/local(2)定位到文件夹/usr/local/。 #cd /usr/local(3)解压安装包到当前目录。 #tar -zxvf apache-tomcat-7.0.47.tar.gz(4)修改配置文件,增加java的环境变量信息。在/usr/local/apache-tomcat-7.0.47/bin下有文件catalina.sh 在文件头部增加下列信息: exportJAVA_HOME=/usr/local//Java/jdk1.7.0_45 exportCLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib exportPATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin(5)启动tomcat,结果如下图所示。 #/usr/local/apache-tomcat-7.0.47/bin/startup.sh
Tomcat安装、测试及配置(2):浏览器测试tomcat是否启动测试tomcat。打开浏览器访问http://127.0.0.1:8080,可以看到tomcat的启动欢迎页面,证明tomcat配置正确。
Tomcat安装、测试及配置(3):tomcat的启动和关闭在/usr/local/apache-tomcat-7.0.47/bin下有可执行程序。(1)启动tomcat服务: # /usr/local/apache-tomcat-7.0.47/bin/startup.sh # /usr/local/apache-tomcat-7.0.47/bin/catalina.sh start(2)关闭tomcat服务: # /usr/local/apache-tomcat-7.0.47/bin/shutdown.sh # /usr/local/apache-tomcat-7.0.47/bin/catalina.sh stop
Tomcat安装、测试及配置(4):java web项目发布(1)用eclipse将编译好的Java Web项目导出成war包。(2)将war包放置到linux服务器上的tomcat的webapps目录下。如本次配置放在/usr/local/apache-tomcat-7.0.47/webapps下。(3)启动tomcat后,tomcat会自动将war包解压并运行Java Web项目。(4)打开浏览器,输入http://127.0.0.1:8080/SessionTest(项目名),就可以访问项目。
Tomcat安装、测试及配置(5):设置Tomcat默认访问项目 打开/usr/local/apache-tomcat-7.0.47/conf/server.xml,在
mod_jk安装: mod_jk的作用:连接apache和tomcat集群的中间件。 mod_jk的安装包:tomcat-connectors-1.2.37-src.tar.gz。安装步骤如下:(1)将安装包从/software目录拷贝到/usr/local目录下(图形界面下直接“复制”-“粘贴”即可)。 #cp /software/tomcat-connectors-1.2.37-src.tar.gz /usr/local(2)定位到文件夹/usr/local/。 #cd /usr/local(3)解压安装包到当前目录。 # tar -zxvf tomcat-connectors-1.2.37-src.tar.gz(4)编译安装mod_jk。 #cd /tomcat-connectors-1. 2.37-src/native # chmod 755buildconf.sh # ./buildconf.sh # ./configure--with-apxs=/usr/local/apache/bin/apxs # make # make install(5)将/tomcat-connectors-1.2.37/apache-2.0下的mod_jk.so文件拷贝到apache安装目录下的modules文件夹下面。 # cp ./apache-2.0/mod_jk.so/usr/local/apache/modules/
负载均衡集群配置(1):修改Tomcat/conf 路径下的server.xml。 修改< Connector>节点值,是关于使用ajp连接apache和tomcat时的配置。修改成如下形式:
负载均衡集群配置(2):修改Tomcat/conf 路径下的server.xml。 修改
负载均衡集群配置(3):修改Tomcat/conf 路径下的server.xml。在
负载均衡集群配置(4):修改Tomcat/conf 路径下的server.xml。修改
负载均衡集群配置(5):修改待发布项目的web.xml 需要发布的项目放在tomcat的webapps文件夹下,在每个待发布项目的web.xml末尾的标签里添加
负载均衡集群配置(6):Apache配置——修改 httpd.conf在apache的conf下的httpd.conf 文件尾部追加以下内容: #加载mod_jk Module LoadModule jk_module modules/mod_jk.so
负载均衡集群配置(7):Apache配置——创建workers.properties httpd.conf的最后添加的配置中workers.properties文件是不存在的,需要我们自己在apache/conf路径下创建。workers.properties文件用于对负载均衡的负载器worker(即tomcat)进行具体的登记,此处的2个tomcat就作为2个worker被登记在这个文件中。workers.properties具体配置如下:#workers.properties## in unix, weuse forward slashes:ps=/# workers 列表worker.list=tomcat1,tomcat2, loadbalancer, status#--------------------------------------------------------------------# 第一个tomcat#--------------------------------------------------------------------worker.tomcat1.port=8009 #对应tomcat的server.xml中配置的ajp13端口号worker.tomcat1.host=127.0.0.1 #tomcat1的主机地址,如不为本机,请填写IP地址worker.tomcat1.type=ajp13 #定向包协议worker.tomcat1.lbfactor=1 #server的负载分配权重,值越高,分得的请求越多#以下为非必要配置,这部分配置tomcat2的配置同tomcat1#worker.tomcat1.cachesize=1000 #配置tomcat的jk连接缓存大小 (非必要)#worker.tomcat1.cachesize_timeout=600 # (非必要)#worker.tomcat1.reclycle_timeout=300 # (非必要)#worker.tomcat1.socket_keepalive=1 #防止防火墙切断未激活的网络连接(非必要)#worker.tomcat1.socket_timeout=300 #(非必要)#worker.tomcat1.local_worker=1 # (非必要)#worker.tomcat1.retries=3 # (非必要) #----------------------------------------------------------------------# 第二个tomcat#----------------------------------------------------------------------worker.tomcat2.port=8009worker.tomcat2.host=172.**.***.202 #tomcat2的主机IP地址worker.tomcat2.type=ajp13worker.tomcat2.lbfactor=1#----------------------------------------------------------------------# load balancerworker -负载均衡控制器# ---------------------------------------------------------------------worker.loadbalancer.type=lbworker.loadbalancer.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcatworker.loadbalancer.sticky_session=1 #设置为粘性sessionworker.loadbalancer.sticky_session_force=0 #设置当多次请求未响应,请求将转发worker.status.type=status## end workers.properties
负载均衡集群配置(8):Apache配置——设置apache对项目的访问路径 修改/apache/conf/目录下的httpd.conf文件中的DocumentRoot和Directory值,将文件访问路径定位到tomcat的webapps文件夹,即待发布项目的存放位置,修改结果如下:DocumentRoot'/usr/local/apache-tomcat-7.0.47/webapps'
负载均衡集群Session测试(1):创建测试工程SessionTest① 新建一个Java Web工程SessionTest,在工程下新建index.jsp,文件内容如下:<%@ pageimport='java.util.*' %>
value
<% String key =request.getParameter('key'); if(key!=null &&key.isEmpty()==false) { String value =request.getParameter('value'); session.setAttribute(key, value); Enumeration e =session.getAttributeNames(); while (e.hasMoreElements()) { String sKey = (String)e.nextElement(); String sValue = (String)session.getAttribute(sKey); out.print(sKey+ ' ='+sValue+'
'); } }%>② 修改SessionTest的web.xml,在web.xml末尾的标签里添加
负载均衡集群Session测试(2):session粘性测试 启动同组tomcat以及apache。浏览器访问apache所在的主机IP地址:http://172.18.145.201/, 显示如图一所示页面。从页面显示的session Id可以看出请求访问的是tomcat1。 如图二所示,发现多次刷新或submit后,请求访问的一直是tomcat1,并且session Id一直保持不变,session中的数据也能够保持,说明session粘性良好。
负载均衡集群Session测试(3):session复制测试 启动同组tomcat以及apache。浏览器访问apache所在的主机IP地址:http://172.18.145.201/,从页面显示的session Id可以看出请求访问的是tomcat1。提交几组session数据,显示结果如图一所示。 此时停掉tomcat1,再次提交session数据,或刷新页面,结果如图二所示,发现请求被转发给tomcat2,页面访问正常。页面颜色改变,但Session Id保持不变,session数据也全部传递给tomcat2,表明session复制良好。
至此,apache+tomcat的负载均衡集群就全部配置完成了。如果想实现开机时负载集群服务自启动的话,可将如下内容添加至/etc/rc.d/rc.local文件末尾: /usr/local/apache-tomcat-7.0.47/bin/catalina.shstart /usr/local/apache/bin/apachectlstart