服务=====Nginx+Tomcat 负载均衡群集

简介:

####实验环境  centos 6.5

####需要的安装包

jdk-7u65-linux-x64.gz

apache-tomcat-7.0.54.tar.gz

nginx-1.6.0.tar.gz


两台tomcat服务器,一台Nginx 服务器

tomcat1 的ip 192.168.1.100:8080

tomcat2 的ip 192.168.1.101:8080

Nginx 的ip 192.168.1.102


注:试验中必须关闭防火墙,selinux和安装了gcc的环境


=========================tomcat1 的配置=============================

39634f5896cf09d80f5ef8a3b69e121c.png-wh_


(1)安装JDK,配置JAVA 环境 

[root@localhost ~]# tar zxvf jdk-7u65-linux-x64.gz

[root@localhost ~]# mv jdk1.7.0_65/ /usr/local/java

[root@localhost ~]# vim /etc/profile.d/java.sh   #在此路径下写一个脚本,内容如下    

     export JAVA_HOME=/usr/local/java

     export PATH=$PATH:$JAVA_HOME/bin

 

[root@localhost ~]# source /etc/profile.d/java.sh   

(2)安装配置Tomcat

[root@localhost ~]# tar xf apache-tomcat-7.0.54.tar.gz 

[root@localhost ~]# mv apache-tomcat-7.0.54 /usr/local/tomcat7

[root@localhost ~]# /usr/local/tomcat7/bin/startup.sh   #启动tomcat,如下所示

Using CATALINA_BASE:   /usr/local/tomcat7

Using CATALINA_HOME:   /usr/local/tomcat7

Using CATALINA_TMPDIR: /usr/local/tomcat7/temp

Using JRE_HOME:        /usr/local/java

Using CLASSPATH:       /usr/local/tomcat7/bin/bootstrap.jar:/usr/local/tomcat7/bin/tomcat-juli.jar

Tomcat started.

You have new mail in /var/spool/mail/root

(3)打开浏览器访问测试,http://  192.168.1.100:8080,出现如下界面则成功

3ebb44cffb48112c8b889986302e9923.png

(4)建立JAVA的WEB 站点

[root@localhost ~]# mkdir -pv /web/webapp1   #创建web页面的目录

[root@localhost ~]# vim /usr/local/tomcat7/conf/server.xml  #修改配置文件,指定路径,添加黄色区域内容

内容如下:

  <Context docBase="/web/webapp1" path="" reloadable="false">

            </Context>

b3e79942765d20965ceca3c1ad9b9d8c.png

[root@localhost ~]# vim /web/webapp1/index.jsp   #添加测试页面

内容如下:

[root@localhost java]# cat /web/webapp1/index.jsp 

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<html>

 <head>

  <title>JSP test1 page</title>

 </head>

 <body>

   <% out.println("welcome to test site,http://www.test1.com");%>

 </body>

</html>

(5)验证测试成功

打开浏览器,输入http://192.168.1.100:8080,出现如下所示

db1b527b51ffee7fd7cc7a901f454782.png

=========================Tomcat2 的配置=====================

Tomcat2 的配置方法基本同tomcat1,其中包括

(1)关闭iptables 防火墙

(2)安装JDK, 配置JAVA 环境,版本与Tomcat1 server 保持一致

(3)安装配置Tomcat,版本与Tomcat1 server 保持一致

(4)创建/web/webapp1 目录,修改Tomcat配置文件server.xml,将网站文件目录更改到/web/webapp1/路径下

(5)在/web/webapp1/路径下建立Index.jsp,为了区别测试页面index.jsp 的内容更改如下

[root@localhost ~]# cat  /web/webapp1/index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<html>

 <head>

  <title>JSP test2 page</title>

 </head>

 <body>

   <% out.println("welcome to test site,http://www.test2.com");%>

 </body>

</html>


==========================Nginx 的配置==============================

[root@localhost 桌面]# yum -y install prce-devel zlib-devel openssl-devel

[root@localhost 桌面]# groupadd www

[root@localhost 桌面]# useradd -g www www -s /bin/false

root@localhost 桌面]# mv nginx-1.6.0.tar.gz ~

[root@localhost 桌面]# cd ~

[root@localhost ~]# tar zxvf nginx-1.6.0.tar.gz 

[root@localhost ~]# cd nginx-1.6.0

[root@localhost nginx-1.6.0]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-file-aio --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module --with-http_ssl_module

[root@localhost nginx-1.6.0]# make && make install

安装完成后编辑配置文件(前面为配置文件的行数,红色部分为添加内容)

[root@localhost init.d]# vim /usr/local/nginx/conf/nginx.conf


 32     #gzip  on;

 33     upstream tomcat_server {

 34         server 192.168.1.100:8080 weight=1;

 35         server 192.168.1.101:8080 weight=2;

 36 

 37             }


 

 43 

 44         #access_log  logs/host.access.log  main;

 45 

 46         location / {

 47             root   html;

 48             index  index.html index.htm;

 49             proxy_pass   http://tomcat_server;

 50         }

 51 

 52         #error_page  404              /404.html;


为了启动方便写一个Nginx 的脚本,并把它放在环境变量中,脚本内容如下

[root@localhost init.d]# vim /etc/init.d/nginx

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#!/bin/bash
 
#chkconfig: - 99 20
#description: Nginx Server Control Script
 
PROG= "/usr/local/nginx/sbin/nginx"
PIDF= "/usr/local/nginx/logs/nginx.pid"
case  "$1"  in 
  start)
   $PROG
   ;;
   stop)
    kill  -s QUIT $( cat  $PIDF)
   ;;
   restart)
    $0 stop
    $0 start
   ;;
   reload)
   kill  -s HUP $( cat  $PIDF)
   ;;
   *)
    echo  "Usage: $0 (start|stop|restart|reload)"
    exit  1
esac
exit  0

[root@localhost init.d]# echo "PATH=$PATH:/etc/init.d/" >> /etc/profile

[root@localhost init.d]# . /etc/profile

[root@localhost init.d]# nginx restart     #重启Nginx

测试配置文件是否正确

[root@localhost init.d]# /usr/local/nginx/sbin/nginx -t

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful


重新启动nginx 

[root@localhost init.d]# nginx restart 

[root@localhost init.d]# netstat -anpt | grep nginx

tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      40041/nginx 

测试负载均衡效果

打开浏览器输入http://192.168.1.102

不断刷新浏览器测试发现权重相同,页面会反复在两个页面来回切换。



注:如果是虚拟机调到同一个wmnat中,且配置ip地址是永久的,尽量不要配临时的容易出错




本文转自 大雪儿 51CTO博客,原文链接:http://blog.51cto.com/dingxue/1975984,如需转载请自行联系原作者

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
7天前
|
应用服务中间件 网络安全 nginx
快速上手!使用Docker和Nginx部署Web服务的完美指南
快速上手!使用Docker和Nginx部署Web服务的完美指南
|
1天前
|
负载均衡 前端开发 应用服务中间件
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400
|
1天前
|
负载均衡 前端开发 应用服务中间件
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400(2)
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400(2)
|
6天前
|
负载均衡 应用服务中间件 nginx
解决nginx配置负载均衡时invalid host in upstream报错
在Windows环境下,配置Nginx 1.11.5进行负载均衡时遇到问题,服务无法启动。错误日志显示“invalid host in upstream”。检查发现上游服务器列表中,192.168.29.128的主机地址无效。负载均衡配置中,两个服务器地址前误加了&quot;http://&quot;。修正方法是删除上游服务器列表和proxy_pass中的&quot;http://&quot;。问题解决后,Nginx服务应能正常启动。
40 4
解决nginx配置负载均衡时invalid host in upstream报错
|
7天前
|
小程序 应用服务中间件 Linux
【Nginx】微信小程序后端开发、一个域名访问多个服务
【Nginx】微信小程序后端开发、一个域名访问多个服务
18 0
|
7天前
|
负载均衡 网络协议 应用服务中间件
【亮剑】在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。
【4月更文挑战第30天】本文介绍了在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。HAProxy是一个高性能的开源TCP和HTTP负载均衡器,适合处理大量并发连接;Nginx是一个多功能Web服务器和反向代理,支持HTTP、HTTPS和TCP负载均衡,同时提供缓存和SSL功能;Keepalived用于监控和故障切换,通过VRRP实现IP热备份,保证服务连续性。文中详细阐述了如何配置这三个工具实现负载均衡,包括安装、配置文件修改和启动服务,为构建可靠的负载均衡系统提供了指导。
|
7天前
|
负载均衡 算法 应用服务中间件
面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
字节跳动面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
50 0
|
7天前
|
负载均衡 应用服务中间件 API
Nginx配置文件详解Nginx负载均衡Nginx静态配置Nginx反向代理
Nginx配置文件详解Nginx负载均衡Nginx静态配置Nginx反向代理
45 4
|
7天前
|
负载均衡 算法 网络协议
LVS、Nginx和HAProxy负载均衡器对比总结
LVS、Nginx和HAProxy负载均衡器对比总结
|
7天前
|
负载均衡 应用服务中间件 nginx
Nginx 负载均衡
Nginx 负载均衡
27 2