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

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

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

现在我们来学习一下,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

1.# pwd

2./usr/local

3.# chmod a+x jdk-6u14-linux-i586-rpm.bin

4.# ./jdk-6u14-linux-i586-rpm.bin

5.# ln -s /usr/java/jdk1.

6.0_14 /usr/local/java

设置环境变量

# vi profile

末尾增加如下内容

1.JAVA_HOME=/usr/java/jdk1.6.0_14

2.CLASSPATH=/usr/java/jdk1.6.0_14/lib/dt.jar:/usr/java/jdk1.6.0_14/lib

/tools.jar

3.PATH=/usr/java/jdk1.6.0_14/bin:$PATH

4.export PATH JAVA_HOME CLASSPATH

2.安装tomcat

1.# cp apache-tomcat-6.0.20.tar.gz /usr/local/

2.# cd /usr/local/

3.# tar xzvf apache-tomcat-6.0.20.tar.gz

4.# ln -s apache-tomcat-6.0.20 tomcat

5.# vi /usr/local/tomcat/bin/catalina.sh

加入一行:

1.JAVA_HOME=/usr/java/jdk1.6.0_14

2.# /usr/local/tomcat/bin/startup.sh

启动服务后访问本地的8080端口可以看到对应apache tomcat页面了

把Tomcat加到自启动:

# vi /etc/rc.d/rc.local

在里面加入如下代码:

1.export JDK_HOME=/usr/java/jdk1.6.0_14

2.export JAVA_HOME=/usr/java/jdk1.6.0_14

3./usr/local/tomcat/bin/startup.sh

至此tomcat已安装成功了

优化: tomcat 比如防止内存溢出; TCP/IP 比如time_wait与closed_wait等等二、安装 nginx、nfs 注意它们是一台服务器上

1.安装 nginx

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

1.# tar zxvf pcre-7.9.tar.gz

2.# cd pcre-7.9

3.# ./configure

4.# make && make install

安装nginx

1.# tar zxvf nginx-0.7.61.tar.gz

2.# cd nginx-0.7.61

3.# ./configure --with-http_stub_status_module --prefix=/usr/local/ngi

nx

4.# make && make install

修改nginx的配置文件

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

1.#vi nginx.conf

er nobody nobody;

3.worker_processes 8;

4.pid /usr/local/nginx/logs/nginx.pid;

5.worker_rlimit_nofile 51200;

6.events

7.{

e epoll;

9.worker_connections 51200;

10.}

11.http{

12.includemime.types;

13.default_type application/octet-stream;

14.server_names_hash_bucket_size 128;

15.client_header_buffer_size 32k;

rge_client_header_buffers 4 32k;

17.client_max_body_size 8m;

18.

19.sendfile on;

20.tcp_nopush on;

21.keepalive_timeout 60;

22.tcp_nodelay on;

23.fastcgi_connect_timeout 300;

24.fastcgi_send_timeout 300;

25.fastcgi_read_timeout 300;

26.fastcgi_buffer_size 64k;

27.fastcgi_buffers 4 64k;

28.fastcgi_busy_buffers_size 128k;

29.fastcgi_temp_file_write_size 128k;

30.gzip on;

31.gzip_min_length 1k;

32.gzip_buffers 4 16k;

33.gzip_http_version 1.0;

34.gzip_comp_level 2;

35.gzip_typestext/plain application/x-javascript text/css application/x

ml;

36.gzip_vary on;

37.#设定负载均衡列表

38.upstream backend

39.{

40.server 192.168.100.89:8080;

41.server 192.168.100.90:8080;

42.}

43.#设定虚拟主机

44.server {

45.listen 80;

46.server_name ;

47.#对 / 所有做负载均衡 (本机nginx采用完全转发,所有请求都转发到后端的tomcat集

群)

48.location / {

49.root /var/www ;

50.index index.jsp index.htm index.html;

51.proxy_redirect off;

52.#保留用户真实信息

53.proxy_set_header Host $host;

54.proxy_set_header X-Real-IP $remote_addr;

55.proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

56.proxy_pass http://backend;

57.}

58.

59.#location /nginx {

60.#access_log on;

61.#auth_basic "NginxStatus";

62.#auth_basic_user_file /usr/local/nginx/htpasswd;

相关文档
最新文档