设为首页 收藏本站
查看: 952|回复: 0

[经验分享] nginx+tomcat负载均衡集群

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-1-26 08:44:40 | 显示全部楼层 |阅读模式
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/technetwor ... javase7-521261.html
tomcat下载地址:http://tomcat.apache.org

实验环境:
nginx服务器  : 192.168.3.254
tomcat1服务器: 192.168.3.10
tomcat2服务器: 192.168.3.11

关闭防火墙:
[iyunv@tomcat1 ~]# service iptables stop
[iyunv@tomcat1 ~]# setenforce 0

一、安装tomcat服务(tomcat1)
1.安装jdk,配置java环境
[iyunv@tomcat1 ~]# chmod +x jdk-6u20-linux-i586.bin   ( 32位操作系统为例)
[iyunv@tomcat1 ~]# ./jdk-6u20-linux-i586.bin
[iyunv@tomcat1 ~]# mv jdk1.6.0_20/ /usr/local/java

2.配置java脚本
[iyunv@tomcat1 ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/local/java
export PATH=$PATH:$JAVA_HOME/bin

3.执行脚本及查看java版本
[iyunv@tomcat1 ~]# source /etc/profile.d/java.sh
[iyunv@localhost ~]# java -version

4.安装tomcat
[iyunv@tomcat1 ~]# tar xf apache-tomcat-7.0.54.tar.gz
[iyunv@tomcat1 ~]# mv apache-tomcat-7.0.54 /usr/local/tomcat7

5.启动tomcat
[iyunv@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端口
[iyunv@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文件


[iyunv@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站点
[iyunv@tomcat1 ~]# mkdir -pv /web/webapp1
mkdir: 已创建目录 "/web"
mkdir: 已创建目录 "/web/webapp1"

8.在webapp1目录下建立一个index.jsp的测试页面
[iyunv@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文件
[iyunv@tomcat1 ~]# cp /usr/local/tomcat7/conf/server.xml{,.bak}
[iyunv@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,在重新启动
[iyunv@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

[iyunv@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的测试页面

[iyunv@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>

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

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

三、Nginx 服务器配置

1.关闭防火墙
[iyunv@nginx ~]# service iptables stop
[iyunv@nginx ~]# setenforce 0

2.安装依赖的软件包
[iyunv@nginx ~]# yum -y install pcre-devel zlib-devel openssl-devel lrzsz

3.创建nginx用户
[iyunv@nginx ~]# groupadd nginx
[iyunv@nginx ~]# useradd -g nginx nginx -s /sbin/nologin
[iyunv@nginx ~]# tar xf nginx-1.6.2.tar.gz
[iyunv@nginx ~]# cd nginx-1.6.2
[iyunv@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静态压缩

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

4.配置nginx.conf
[iyunv@nginx nginx-1.6.2]# cp /usr/local/nginx/conf/nginx.conf{,.bak}
[iyunv@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启动脚本
[iyunv@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

添加系统服务
[iyunv@nginx nginx-1.6.2]# chkconfig --add nginx
[iyunv@nginx nginx-1.6.2]# chkconfig nginx on
[iyunv@nginx nginx-1.6.2]# chkconfig --list nginx

[iyunv@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
[iyunv@nginx nginx-1.6.2]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
[iyunv@nginx nginx-1.6.2]# netstat -anpt |grep :80
tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      7184/nginx         

[iyunv@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
刷新页面会反复切换

实验完成







运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-41406-1-1.html 上篇帖子: 一台linux服务器配置多个tomcat应用 下篇帖子: tomcat与web程序结构与Http协议与HttpUrlConnection
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表