gtxyzz

超细腻的nginx负载均衡设置全程奉献

gtxyzz 运维技术 2022-11-15 455浏览 0

前面我们学习了很多关于lvs的负载均衡的相关内容,现在我们来看一下,nginx的负载均衡设置,同样,也是借由tomacat来实现。在这里我们用的是NFS服务器,要保证这些数据程序是同步的之后才能进行后面的操作。那么更具体的过程还是从下文中了解吧。

前端一台nginx服务器做调度.后端两台tomcat做WEB服务器.这里动态页与静态页都由tomcat来处理.

软件:

nginx-0.7.28.tar.gz

pcre-7.8.tar.gz

apache-tomcat-6.0.20.tar.gz

jdk-6u14-linux-i586-rpm.bin

架构说明

三台服务器:一台调度也就是nginx服务器,它还是NFS服务器,我们把2个tomcat的webapps目录挂载到NFS服务器上,这样数据程序是同步的了。

配置步骤:

一、web服务器的配置

首先安装两台tomcat,两台安装都一样

1.安装JDK

#pwd 
/usr/local 
#chmoda+xjdk-6u14-linux-i586-rpm.bin 
#./jdk-6u14-linux-i586-rpm.bin 
#ln-s/usr/java/jdk1.6.0_14/usr/local/java

设置环境变量 # vi profile 末尾增加如下内容

JAVA_HOME=/usr/java/jdk1.6.0_14 
CLASSPATH=/usr/java/jdk1.6.0_14/lib/dt.jar:/usr/java/jdk1.6.0_14/lib/tools.jar 
PATH=/usr/java/jdk1.6.0_14/bin:$PATH 
exportPATHJAVA_HOMECLASSPATH

2.安装tomcat

#cpapache-tomcat-6.0.20.tar.gz/usr/local/ 
#cd/usr/local/ 
#tarxzvfapache-tomcat-6.0.20.tar.gz 
#ln-sapache-tomcat-6.0.20tomcat 
#vi/usr/local/tomcat/bin/catalina.sh

#p# 加入一行:

JAVA_HOME=/usr/java/jdk1.6.0_14 
#/usr/local/tomcat/bin/startup.sh

启动服务后访问本地的8080端口可以看到对应apache tomcat页面了 把Tomcat加到自启动: # vi /etc/rc.d/rc.local 在里面加入如下代码:

exportJDK_HOME=/usr/java/jdk1.6.0_14 
exportJAVA_HOME=/usr/java/jdk1.6.0_14 
/usr/local/tomcat/bin/startup.sh

至此tomcat已安装成功了

优化: tomcat 比如防止内存溢出; TCP/IP 比如time_wait与closed_wait等等

二、 安装 nginx、nfs 注意它们是一台服务器上

1.安装 nginx

在安装之前首先要安装pcre-7.9.tar.gz

#tarzxvfpcre-7.9.tar.gz 
#cdpcre-7.9 
#./configure 
#make&&makeinstall

安装nginx

#tarzxvfnginx-0.7.61.tar.gz 
#cdnginx-0.7.61 
#./configure--with-http_stub_status_module--prefix=/usr/local/nginx 
#make&&makeinstall

#p# 修改nginx的配置文件

我这里是把原先的重命名然后新建了一个nginx.conf

#vinginx.conf 
usernobodynobody; 
worker_processes8; 
pid/usr/local/nginx/logs/nginx.pid; 
worker_rlimit_nofile51200; 
events 
{ 
useepoll; 
worker_connections51200; 
} 
http{ 
includemime.types; 
default_typeapplication/octet-stream; 
server_names_hash_bucket_size128; 
client_header_buffer_size32k; 
large_client_header_buffers432k; 
client_max_body_size8m; 

sendfileon; 
tcp_nopushon; 
keepalive_timeout60; 
tcp_nodelayon; 
fastcgi_connect_timeout300; 
fastcgi_send_timeout300; 
fastcgi_read_timeout300; 
fastcgi_buffer_size64k; 
fastcgi_buffers464k; 
fastcgi_busy_buffers_size128k; 
fastcgi_temp_file_write_size128k; 
gzipon; 
gzip_min_length1k; 
gzip_buffers416k; 
gzip_http_version1.0; 
gzip_comp_level2; 
gzip_typestext/plainapplication/x-javascripttext/cssapplication/xml; 
gzip_varyon; 
#设定负载均衡列表 
upstreambackend 
{ 
server192.168.100.89:8080; 
server192.168.100.90:8080; 
} 
#设定虚拟主机 
server{ 
listen80; 
server_namewww.syitren.com; 
#对/所有做负载均衡(本机nginx采用完全转发,所有请求都转发到后端的tomcat集群) 
location/{ 
root/var/www; 
indexindex.jspindex.htmindex.html; 
proxy_redirectoff; 
#保留用户真实信息 
proxy_set_headerHost$host; 
proxy_set_headerX-Real-IP$remote_addr; 
proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for; 
proxy_passhttp://backend; 
} 

#location/nginx{ 
#access_logon; 
#auth_basic"NginxStatus"; 
#auth_basic_user_file/usr/local/nginx/htpasswd; 
#} 
log_formataccess'$remote_addr-$remote_user[$time_local]"$request"' 
'$status$body_bytes_sent"$http_referer"' 
'"$http_user_agent"$http_x_forwarded_for'; 
access_log/var/log/access.logaccess; 
} 
} 

#p# 检查nginx的配置文件

# /usr/local/webserver/nginx/sbin/nginx -t

启动nginx

# /usr/local/webserver/nginx/sbin/nginx

重启nginx

# kill -HUP `cat /usr/local/nginx/logs/nginx.pid`

(1)查看负载均衡信息

location/nginx{ 
stub_statuson; 
access_logon; 
auth_basic"NginxStatus"; 
auth_basic_user_file/usr/local/nginx/htpasswd; 
}

其中/usr/local/nginx/htpasswd可以用apache自带的功能生成。

***在IE里访问:

http://www.syitren.com/nginx, 然后输入用户名密码就进入了。

进入之后的说明

输入地址 http://www.syitren.com/nginx/,输入验证帐号密码,即可看到类似如下内容:

Activeconnections:328 
serveracceptshandledrequests 
9309898228890 
Reading:1Writing:3Waiting:324

***行表示目前活跃的连接数

第三行的第三个数字表示Nginx运行到当前时间接受到的总请求数,如果快达到了上限,就需要加大上限值了。

第四行是Nginx的队列状态

(2)负载均衡

upstreambackend 
{ 
server192.168.100.89:8080; 
server192.168.100.90:8080; 
}

#p# 三、 配置NFS 需要安装rpm包portmap、nfs,

#vi/etc/export 
/var/www192.168.100.89(rw,sync,no_root_squash),192.168.100.90(rw,sync,no_root_squash) 
#serviceportmaprestart 
#servicenfsstart 
#exportfs-rv

重新输出共享目录,

# showmoun -e

查看本机共享的目录

然后tomcat的两台服务器挂载,

# mount 192.168.100.88:/var/www /usr/local/tomcat/weapps

然后我们要在两台tomcat的配置文件中即server.xml中做虚拟主机要与nginx.conf里的一致才OK。

#viserver.xml 
<Hostname="www.syitren.com"debug="0"appBase="webapps"unpackWARs="true"autoDeploy="true"xmlValidation="false"xmlNamespaceAware="false">
<Contextpath=""docBase="/usr/local/tomcat/webapps/"debug="0"reloadable="true"crossContext="true"/> 
<LoggerclassName="org.apache.catalina.logger.FileLogger"directory="logs"prefix="www.syitren.com_log."suffix=".txt"
timestamp="true"/>
</Host>

四、测试

写了一个测试session的页,上传到虚拟主机对应的目录。

(1)访问一次刷新一次再刷新发现时间每次都不一样,就是来回出现两台tomcat的系统时间,说明成功了。

(2)然后把其中的一台tomcat停掉,这时我们再刷新其中有一个就没有响应了,但过了一分钟左右就是一台机器提供服务了,说明,nginx可以自动把 down的服务器去除,从而使客户端透明。

(3)然后再把停掉的tomcat服务器开启,过一段时间后,nginx服务器又把它加入调度行列。这都是自动的。

本文原址连接:http://bbs.yahunet.com/thread-10029-1-1.html

继续浏览有关 网络 的文章
发表评论