Centos6.2上做nginx和tomcat的集成及负载均衡

---------------------------------------------------------Jdk-------------------------------------------------------------------

1:centos上安装jdk6

Jdk:

jdk-6u34-linux-i586.bin

 安装命令:

./jdk-1_5_0_06-linux-i586.bin

配置环境变量如下

用vi打开/etc/profile在文件尾部添加如下内容

 
 

JAVA_HOME="/usr/local/jdk"

CLASS_PATH="$JAVA_HOME/lib:JAVA_HOME/jre/lib"

PATH=".:$PATH:%JAVA_HOME/bin%"

export JAVA_HOME CATALINA_HOME

测试:

通过java –version命令测试是否会出现相关java信息,有则安装成功.如下

---------------------------------------------------------Jdk-------------------------------------------------------------------

---------------------------------------------------------Nginx----------------------------------------------------------------

2:安装nginx

 Nginx:

下载: http://nginx.org/en/download.html

安装命令:

Step 1: rpm -ivh nginx-release-centos-6-0.el6.ngx.noarch.rpm

Step 2: yum install nginx

会显示一大堆信息,问你ok不ok啊:Is this ok [y/N]:
输入y,屏幕滚了一会之后就安装完毕,最后提示“Complete!”就是安完了。

软件说明:   
1 配置所在目录:/etc/nginx/
2 PID目录:/var/run/nginx.pid
3 错误日志:/var/log/nginx/error.log

  Nginx常用命令:

1 启动:nginx
2 重启:killall -HUP nginx
3 测试配置:nginx –t

测试:

用命令”nginx”起动服务,在浏览器中输入”127.0.0.1”如果出现欢迎信息说明安装成功

---------------------------------------------------------Nginx----------------------------------------------------------------

---------------------------------------------------------Tomcat--------------------------------------------------------------

3:安装tomcat

  Tomcat:

apache-tomcat-6.0.35.tar.gz

 安装命令:

tar xvzf apache-tomcat-6.0.35.tar.gz (解压到了当前目录)

mv tomcat(源) 
/usr/local/tomcat(目) ---移到目标目录

  常用命令:

起动:bin/startup.sh

关闭:bin/shutdown.sh

测试:

127.0.0.1:8080是否出现tomcat信息页面

---------------------------------------------------------Tomcat--------------------------------------------------------------

---------------------------------------------------------整合-----------------------------------------------------------------

4:整合nginx和tomcat

 在/etc/nginx/nginx.conf中添加如下内容  http {}添加

upstream www.imeixi.cn {

server 127.0.0.1:8080 weight=1;#转向tomcat

}

在 /etc/nginx/conf.d/default.conf 
中修改

server
{

listen       80;

server_name localhost; //  也可以是www.imeixi.cn

location / {

root   html;

index index.jsp index.html
index.htm;

proxy_redirect off;

proxy_set_header Host $host; #这一句至关重要

proxy_set_header X-Real-IP
$remote_addr;

proxy_set_header X-Forwarded-For
$proxy_add_x_forwarded_for;

proxy_pass http://www.mygogo.com;    //这句是指转发(将nginx作为反向代理配置)

}

error_page   500 502 503 504 /50x.html;

location = /50x.html {

root   html;

}

}

添加之后需要重启nginx生效

 
 

killall
-HUP nginx

测试:

在tomcat中加入一个简单web应用(一个html页面就ok),分别访问127.0.0.1/yourweb(nginx—图1)和127.0.0.1:8080/yourweb(tomcat 图2)是否会出现相同的页面,有则成功

 
   

图1

图2

---------------------------------------------------------整合-----------------------------------------------------------------

---------------------------------------------------------负载均衡----------------------------------------------------------

5:负载均衡

1、 架构图:

 
   

2、安装第二个tomcat:

由于是在同一台机子上安装两个tomcat,所以要做相应的修改,如下

1:从第一个tomcat生成新的tomcat

 
 

cp /usr/local/tomcat /usr/local/tomcat2

2:在/etc/profile文件尾部添加如下内容   【可省略】

CATALINA_2_BASE=/usr/local/tomcat2

CATALINA_2_HOME=/usr/local/tomcat2

TOMCAT_2_HOME=/usr/local/tomcat2

export CATALINA_2_BASE CATALINA_2_HOME TOMCAT_2_HOME

3:在tomcat2/bin/catalina.sh文件顶部添加如下内容   【可省略】

 
 

export JAVA_HOME=/usr/local/jdk

export PATH=$PATH:$JAVA_HOME/bin

export CLASSPATH=$JAVA_HOME/lib

export CATALINA_HOME=$CATALINA_2_HOME

export CATALINA_BASE=$CATALINA_2_BASE

更改profile后,使用
#source  /etc/profile 
使新配置的环境变量生效

4:修改tomcat2/conf/server.xml文件

修改三个监听端口

<Server port="8005"
shutdown="SHUTDOWN">改成<Server port="9005" shutdown="SHUTDOWN">

<Connector port="8080"
protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" />改成<Connector port="9080" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" />

<Connector port="8009" protocol="AJP/1.3"
redirectPort="8443" />改成<Connector port="9009" protocol="AJP/1.3"
redirectPort="8443" />

5:在两个tomcat下发布相同的web应用并且起动两个tomcat

 
 

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

/usr/local/tomcat2/bin/startup.sh

3、配置nginx

 

在/etc/nginx/nginx.conf中添加如下内容  http {}
添加

 

upstream www.imeixi.cn {

server 127.0.0.1:8080 weight=1;              //server localhost:8080 weight=1(权重)

server 127.0.0.1:9080 weight=1;              //server localhost:9080 weight=5

}


/etc/nginx/conf.d/default.conf
中不做改动。

server {

listen       80;

server_name www.imeixi.cn;

location / {

root   html;

index index.jsp index.html
index.htm;

proxy_redirect off;

proxy_set_header Host $host; #这一句至关重要

proxy_set_header X-Real-IP
$remote_addr;

proxy_set_header X-Forwarded-For
$proxy_add_x_forwarded_for;

proxy_pass http://www.mygogo.com;

}

error_page   500 502 503 504 /50x.html;

location = /50x.html {

root   html;

}

}

添加之后需要重启nginx生效

 
 

killall
-HUP nginx

4、测试:

访问www.imeixi.cn  将以轮寻的方式访问两个tomcat

---------------------------------------------------------负载均衡----------------------------------------------------------

Centos6.2上做nginx和tomcat的集成及负载均衡(已实践)的更多相关文章

  1. 【Linux运维-集群技术进阶】Nginx+Keepalived+Tomcat搭建高可用/负载均衡/动静分离的Webserver集群

    额.博客名字有点长.. . 前言 最终到这篇文章了,心情是有点激动的. 由于这篇文章会集中曾经博客讲到的全部Nginx功能点.包含主要的负载均衡,还有动静分离技术再加上这篇文章的重点.通过Keepal ...

  2. Nginx实现tomcat集群进行负载均衡

    一.背景 随着业务量和用户数量的激增,单一的tomcat部署应用已经无法满足性能需求,而且对于每次发布项目期间服务不可用的问题也凸显,既然出现了这个问题,那么我们本文就借助nginx来完美的解决这个问 ...

  3. Nginx部署tomcat/wildfly集群负载均衡

    1.调度器配置: docker run -p 80:80 --name nginx --restart=always  -v /root/nginx/www/:/usr/share/nginx/htm ...

  4. 实战Apache+Tomcat集群和负载均衡

    实战Apache+Tomcat集群和负载均衡 目录 1.    什么是J2EE集群... 3 1.1.     序言... 3 1.2.     基本术语... 3 伸缩性(Scalability): ...

  5. tomcat集群和负载均衡的实现(session同步)

      (一)环境说明 (1)服务器有4台,一台安装apache,三台安装tomcat (2)apache2.0.55.tomcat5.5.15.jk2.0.4.jdk1.5.6或jdk1.4.2 (3) ...

  6. 图文解说:Nginx+tomcat配置集群负载均衡

    图文解说:Nginx+tomcat配置集群负载均衡 博客分类: appserver nginxTomcatUbuntuLinux网络应用  作者:niumd Blog:http://ari.iteye ...

  7. 排查nginx、tomcat内存和服务器负载之后

    最近客户现在提出系统访问非常慢,需要优化提升访问速度,在排查了nginx.tomcat内存和服务器负载之后,判断是数据库查询速度慢,进一步排查发现是因为部分视图和表查询特别慢导致了整个系统的响应时间特 ...

  8. Nginx + Tomcat Windows下的负载均衡配置

     Nginx + Tomcat Windows下的负载均衡配置 一.为什么需要对Tomcat服务器做负载均衡?    Tomcat服务器作为一个Web服务器,其并发数在300-500之间,如果超过50 ...

  9. 搭建 Keepalived + Nginx + Tomcat 的高可用负载均衡架构

    1 概述 初期的互联网企业由于业务量较小,所以一般单机部署,实现单点访问即可满足业务的需求,这也是最简单的部署方式,但是随着业务的不断扩大,系统的访问量逐渐的上升,单机部署的模式已无法承载现有的业务量 ...

随机推荐

  1. [BZOJ2049][Sdoi2008]Cave 洞穴勘测 LCT模板

    2049: [Sdoi2008]Cave 洞穴勘测 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 9705  Solved: 4674[Submit] ...

  2. iOS运行时,如何增加成员变量

    必须实现getter和setter方法 ``` - (void)setName:(NSString *)name { /** * 为某个类关联某个对象 * * @param object#> 要 ...

  3. python socket 连续send,出现粘包问题

    使用网上socket代码实现ssh功能,如下: server.py #服务端Linux系统下:处理命令并返回import socketimport os#声明类型,生成socket链接对象server ...

  4. ZCMU新人训练赛-B

     Tom's Meadow Tom has a meadow in his garden. He divides it into N * M squares. Initially all the sq ...

  5. 母亲的牛奶(milk) (BFS)

    问题 A: 母亲的牛奶(milk) 时间限制: 1 Sec  内存限制: 64 MB提交: 14  解决: 8[提交][状态][讨论版] 题目描述 农民约翰有三个容量分别是A.B.C升的桶,A.B.C ...

  6. java中的JDBC

    Java 是通过 JDBC 技术实现对各种数据库访问的,换句话说,JDBC 充当了 Java 应用程 序与各种不同数据库之间进行对话的媒介. JDBC 是 Java 数据库连接(Java DataBa ...

  7. Ze_Min Tree 主席树

    前言 主席树,也叫可持久化线段树,所以他的本质是颗线段树,而可持久化指的是这颗线段树可以访问过去某个时刻线段树上的信息. 应用 应用的比较多的是查询区间的第k大值(因为其他的数据结构不好做). 实现 ...

  8. POJ 1113 Wall(凸包)

    [题目链接] http://poj.org/problem?id=1113 [题目大意] 给出一个城堡,要求求出距城堡距离大于L的地方建围墙将城堡围起来求所要围墙的长度 [题解] 画图易得答案为凸包的 ...

  9. Exercise01_09

    public class S{ public static void main(String[] args){ double w=4.5; double h=7.9; double d; double ...

  10. Problem M: 第几天——C语言初学者百题大战之十八

    #include<stdio.h> int main() { int a,b,c,s; scanf("%d-%d-%d",&a,&b,&c); ...