nginx+tomcat负载均衡集群

                           nginx+tomcat负载均衡群集搭建

nginx+tomcat简介


Nginx 是一款非常优秀的http服务器软件,他能够支持高达50000个并发连接数的响应,拥有强大的静态资源处理能力,运行稳定,并且内存,CPU等系统资源消耗非常低,目前很多大型网站都用Nginx服务器做后端网站程序的反向代理及负载均衡器,来提升整个站点的负载并发能力。


Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应HTML(标准通用标记语言下的一个应用)页面的访问请求。实际上Tomcat 部分是Apache 服务器的扩展,但它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的。

诀窍是,当配置正确时,Apache 为HTML页面服务,而Tomcat 实际上运行JSP 页面和Servlet。另外,Tomcat和IIS等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Apache服务器。


安装前准备:


在安装Tomcat之前必须先安装JDK,JDK全称是 Java Development Kit,是SUN公司免费提供的java语言的软件开发工具包,其中包含Java虚拟机(JVM),编写好的java源程序经过编译可生产java字节码,只要安装了JDK,就可以利用JVM解释这些字节码文件,从而保证了Java的跨平台性。


JDK下载地址:http://www.oracle.com/technetwork/java/javase/downloads/java-archive-downloads-javase7-521261.html

tomcat下载地址:http://tomcat.apache.org


实验环境:

nginx服务器  : 192.168.3.254 

tomcat1服务器: 192.168.3.10

tomcat2服务器: 192.168.3.11


关闭防火墙:

[root@tomcat1 ~]# service iptables stop

[root@tomcat1 ~]# setenforce 0


一、安装tomcat服务(tomcat1)

1.安装jdk,配置java环境

[root@tomcat1 ~]# chmod +x jdk-6u20-linux-i586.bin   ( 32位操作系统为例)

[root@tomcat1 ~]# ./jdk-6u20-linux-i586.bin

[root@tomcat1 ~]# mv jdk1.6.0_20/ /usr/local/java


2.配置java脚本

[root@tomcat1 ~]# vim /etc/profile.d/java.sh

export JAVA_HOME=/usr/local/java

export PATH=$PATH:$JAVA_HOME/bin


3.执行脚本及查看java版本

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

[root@localhost ~]# java -version


4.安装tomcat

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

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


5.启动tomcat

[root@localhost ~]# /usr/local/tomcat7/bin/startup.sh

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.


6.查看默认运行在8080端口

[root@localhost ~]# netstat -anpt | grep :8080

tcp        0      0 :::8080                     :::*                        LISTEN      6689/java   


浏览器访问测试 http://192.168.3.10:8080


Tomcat 配置相关说明:


/usr/local/tomcat7 主目录

bin        存放windows或linux平台上启动或关闭的Tomcat的脚本文件

conf 存放Tomcat的各种全局配置文件,其中最主要的是server.xml和web.xml

lib 存放Tomcat运行需要的库文件(JARS)

logs 存放Tomcat执行时的LOG文件

webapps Tomcat的主要Web发布目录(包括应用程序事例)

work 存放jsp编译后产生的class文件



[root@tomcat1 ~]# ll /usr/local/tomcat7/conf/

catalina.policy         权限控制配置文件

catalina.properties   Tomcat属性配置文件

context.xml   上下文配置文件

logging.properties   日志log相关配置文件

server.xml   主配置文件

tomcat-users.xml   manager-gui管理用户配置文件(Tomcat安装后生成的管理界面,该文件可开启访问)

web.xml Tomcat的servlet,servlet-mapping,filter,MIME等相关配置

server.xml              主要配置文件,可修改启动端口,设置网站根目录,虚拟主机,开启https等功能。


server.xml的结构构成

<Server>

<Service>

<Connector />

<Engine>

<Host>

<Context> </Context>

</Host>

</Engine>

</Service>

</Server>


<!-- --> 内的内容是注视信息


7.建立java的web站点

[root@tomcat1 ~]# mkdir -pv /web/webapp1

mkdir: 已创建目录 "/web"

mkdir: 已创建目录 "/web/webapp1"


8.在webapp1目录下建立一个index.jsp的测试页面

[root@tomcat1 ~]# vim /web/webapp1/index.jsp

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

<html>

<head>

<title>JSP test page</title>

</head>

<body>

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

</body>

</html>

 

9.修改Tomcat的server.xml文件

[root@tomcat1 ~]# cp /usr/local/tomcat7/conf/server.xml{,.bak}

[root@tomcat1 ~]# vim /usr/local/tomcat7/conf/server.xml 

124       <Host name="localhost"  appBase="webapps"

125             unpackWARs="true" autoDeploy="true">

126             <Context docBase="/web/webapp1" path="" reloadable="flase" >

127             </Context>


注释:docBase="/web/webapp1"         web应用的文档基准目录

      path="" 设置默认"类"

      reloadable="flase" 设置监视"类"是否变化


10.关闭tomcat,在重新启动

[root@tomcat1 ~]# /usr/local/tomcat7/bin/shutdown.sh

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


[root@tomcat1 ~]# /usr/local/tomcat7/bin/startup.sh

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.


浏览器访问测试 http://192.168.3.10:8080


二、tomcat2服务器和tomcat1服务器同样配置


关闭防火墙,selinux

安装JDK,配置Java环境,版本与Tomcat 1 保持一致

安装Tomcat,版本与Tomcat 1 保持一致

建立一个web目录,并在里面建立一个webapp1目录,用于存放网站文件

在webapp1目录下建立一个index.jsp的测试页面


[root@tomcat2 ~]# vim /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>


[root@tomcat2 ~]# /usr/local/tomcat7/bin/shutdown.sh

[root@tomcat2 ~]# /usr/local/tomcat7/bin/startup.sh


浏览器访问测试 http://192.168.3.11:8080


三、Nginx 服务器配置


1.关闭防火墙

[root@nginx ~]# service iptables stop

[root@nginx ~]# setenforce 0


2.安装依赖的软件包

[root@nginx ~]# yum -y install pcre-devel zlib-devel openssl-devel lrzsz


3.创建nginx用户

[root@nginx ~]# groupadd nginx

[root@nginx ~]# useradd -g nginx nginx -s /sbin/nologin

[root@nginx ~]# tar xf nginx-1.6.2.tar.gz 

[root@nginx ~]# cd nginx-1.6.2

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



--prefix=/usr/local/nginx 指定安装目录

--user=www --group=www 指定运行的用户和组

--with-file-aio 启用文件修改支持

--with-http_stub_status_module         启用状态统计

--with-http_ssl_module 启用ssl模块

--with-http_flv_module 启用flv模块,提供寻求内存使用基于时间的偏移量文件

--with-http_gzip_static_module 启用gzip静态压缩


[root@nginx nginx-1.6.2]# make && make install


4.配置nginx.conf

[root@nginx nginx-1.6.2]# cp /usr/local/nginx/conf/nginx.conf{,.bak}

[root@nginx nginx-1.6.2]# vim /usr/local/nginx/conf/nginx.conf


user  nginx;

worker_processes  1;

error_log  logs/error.log;

pid        logs/nginx.pid;


events {

    worker_connections  10240;

}


http {

    include       mime.types;

    default_type  application/octet-stream;


    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '

                      '$status $body_bytes_sent "$http_referer" '

                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  logs/access.log  main;


    sendfile        on;

    keepalive_timeout  65;

    upstream tomcat_server{                  

server 192.168.3.10:8080 weight=1;     

server 192.168.311:8080 weight=1;      

    }                                       


    server {

        listen       80;

        server_name  localhost;


        location / {

            root   html;

            index  index.html index.htm;

   proxy_pass http://tomcat_server;          #####与上面的upstream向对应 ,此处是用来将用户的请求代理转发到定义好的后台的服务器池####

        }


        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

    }

}


5.添加nginx启动脚本

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

#!/bin/bash

#chkconfig: 2345 89 23

#description: Nginx is http(s) server revers server 

PORG="/usr/local/nginx/sbin/nginx"

PIDF="/usr/local/nginx/logs/nginx.pid"

case $1 in

start)

        $PORG && echo "nginx is running..."

;;

stop)

        kill -s QUIT $(cat $PIDF)

        echo "nginx is stopped.."

;;

reload)

        kill -s HUP $(cat $PIDF) && echo "nginx is reloaded.."

;;

restart)

        $0 stop

        $0 start

;;

*)

        echo "$0 Usage: {start|stop|reload|restart}"

        exit 1

esac

exit 0


添加系统服务

[root@nginx nginx-1.6.2]# chkconfig --add nginx

[root@nginx nginx-1.6.2]# chkconfig nginx on

[root@nginx nginx-1.6.2]# chkconfig --list nginx


[root@nginx nginx-1.6.2]# /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

[root@nginx nginx-1.6.2]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

[root@nginx nginx-1.6.2]# netstat -anpt |grep :80

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


[root@nginx nginx-1.6.2]# ps aux |grep nginx

root      1369  0.0  0.0   5928   708 ?        Ss   20:19   0:00 nginx: master process /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

www       1370  0.0  0.3   8104  3304 ?        S    20:19   0:00 nginx: worker process                                          

root      2410  0.0  0.0   5024   684 pts/2    R+   21:15   0:00 grep nginx



客户端测试:

打开浏览器访问: http://192.168.3.254

刷新页面会反复切换


实验完成































你可能感兴趣的:(服务器,源代码,网站程序)