基于apache的tomcat负载均衡和集群配置

最近不是很忙,用零碎时间做点小小的实验。

以前公司采用F5负载均衡交换机,F5将请求转发给多台服务器,每台服务器有多个webserver实例,每个webserver分布在多台服务器,交叉式的分布集群。F5只是简单了解,毕竟那玩意几十万的价格实在不是我一个小喽喽能弄来做试验玩的,而起公司也不能开放权限。后来知道apache、Nginx软件可以实现负载(F5是操作于IOS网络模型的传输层,Nginx、apache是基于http反向代理方式,位于ISO模型的第七层应用层。直白些就是TCP UDP 和http协议的区别,Nginx不能为基于TCP协议的应用提供负载均衡。)

现在对window下对Nginx+tomcat负载均衡做配置尝试,将全部请求转发到tomcat,并未做静态,动态分开,图片防盗链等配置,一切先简单来,后续慢慢添加完善。

用到软件:

Nginx ,两个tomcat ,eclipse肯定要有了,web项目自备,其他无。

1、下载nginx

2、目录结构

Nginx-

|_  conf   配置目录

|_  contrib

|_  docs 文档目录

|_  logs  日志目录

|_  temp 临时文件目录

|_  html 静态页面目录

|_  nginx.exe 主程序

window下安装Nginx极其简单,解压缩到一个无空格的英文目录即可(个人习惯,担心中文出问题),双击nginx启动,这里我安装到:D:\server目录,下面涉及到的tomcat也安装在此目录。

nginx启动:到目录下执行nginx

nginx停止:nginx -s stop

3、下载两个版本的tomcat6。

下面就是关键的配置问题了。

Nginx配置文件默认在conf目录,主要配置文件为nginx.conf,我们安装在D:\server\nginx-1.6.2、默认主配置文件为D:\server\nginx-1.6.2\nginx.conf。下面是nginx作为前端反向代理服务器的配置

nginx.conf

 1 #Nginx所用用户和组
 2 #user  niumd niumd;
 3
 4 #工作的子进程数量(通常等于CPU数量或者2倍于CPU)
 5 worker_processes  2;
 6
 7 #错误日志存放路径
 8 #error_log  logs/error.log;
 9 #error_log  logs/error.log  notice;
10 error_log  logs/error.log  info;
11
12 #指定pid存放文件
13 pid        logs/nginx.pid;
14
15 events {
16         #使用网络IO模型linux建议epoll,FreeBSD建议采用kqueue
17     #use epoll;
18
19     #允许最大连接数
20     worker_connections  2048;
21 }
22
23 http {
24     include       mime.types;
25     default_type  application/octet-stream;
26
27         #定义日志格式
28     #log_format  main  ‘$remote_addr - $remote_user [$time_local] $request ‘
29     #                  ‘"$status" $body_bytes_sent "$http_referer" ‘
30     #                  ‘"$http_user_agent" "$http_x_forwarded_for"‘;
31
32     #access_log  off;
33     access_log  logs/access.log;
34
35     client_header_timeout  3m;
36     client_body_timeout    3m;
37     send_timeout           3m;
38
39     client_header_buffer_size    1k;
40     large_client_header_buffers  4 4k;
41
42     sendfile        on;
43     tcp_nopush      on;
44     tcp_nodelay     on;
45
46     #keepalive_timeout  75 20;
47
48     include    gzip.conf;
49        upstream localhost {
50            #ip_hash
51       #ip_hash;
52       server localhost:8081;
53       server localhost:8080;
54      }
55
56     server {
57             listen       80;
58             server_name  localhost;
59
60             location / {
61                     proxy_connect_timeout   3;
62                     proxy_send_timeout      30;
63                     proxy_read_timeout      30;
64                 proxy_pass http://localhost;
65             }
66
67    }
68 }

gzip压缩相关配置如下:

gzip              on;
gzip_min_length      1000;
gzip_types         text/plain text/css application/x-javascript;

下面为tomcat的配置,这个大家应该很熟悉了

我这里有两个tomcat6,分别为apache-tomcat-6.0.37-8081和tomcat-6.0.18-8080,意思很明白一个用8081端口一个用8080端口,修改server.xml配置文件即可,端口修改这里不提。

启动两个tomcat成功后。检验效果的时候到了。

浏览器输入:http://localhost/user/test.do这是我自己项目的链接,查看连个服务的后台日志是否有打印,结果OK一切顺利。

期间顺带解决问题:去掉url中项目名称的问题。解决方法在server.xml加如下代码,path属性不填,正常情况为项目名,docBase为发布的地址,可以不再tomcat目录下大家随意。

      <Context docBase="D:\server\apache-tomcat-6.0.37-8081\wtpwebapps\项目名" path="" reloadable="true" source="org.eclipse.jst.jee.server:mySpring"/></Host>
时间: 2024-08-03 04:03:27

基于apache的tomcat负载均衡和集群配置的相关文章

基于apache的tomcat负载均衡和集群配置session共享

接上面的话题接着继续完善.为什么没接到上篇呢?原因很简单太长的文章不爱看!就像有人写了上千行的方法一样,不是逼得没办法谁爱看谁看,反正我不看. 期间我没有一次配置成功,从失败的开始说起, 1.准备jar包 注意:不同的tomcat版本(tomcat6,tomcat7)所需的包不一样,需要针对tomcat版本下载对应的包. 这是采用的最新稳定版1.6 首先我到官网:http://code.google.com/p/memcached-session-manager/下载了最新的jar 由于公司网络

Centos基于Apache的Tomcat负载均衡和集群

Centos基于Apache的Tomcat负载均衡和集群 一.背景原理1.tomcat 做个WEB服务器有它的局限性,处理能力低,效率低.承受并发小(1000左右).但目前有不少网站或者页面是JSP的.并采用了tomcat做为WEB,因此只能在此基础上调优.2.目前采取的办法是Apache + Mod_JK + tomcat 来解决一部分请求,用户访问的是apache,但有jsp页面的时候才会去请求tomcat.如果量一大,那么tomcat无法承受,那么只能做tomat集群,Apache + M

Apache、Tomcat负载均衡与集群

一. 环境准备 1.软件下载 a) apache_2.0.55-win32-x86-no_ssl.msi: b) apache-tomcat-5.5.17.rar c) mod_jk-apache-2.0.55.so 下载地址: http://download.csdn.net/detail/crazyiter_com/4178657 2.软件安装 a)  Apache安装路径为:E:\ide\apache\Apache2 (具体可以根据自己的盘符而定) b) Tomcat放置位置和名称注意:

apache + tomcat 负载均衡分布式集群配置

Tomcat集群配置学习篇-----分布式应用 现目前基于javaWeb开发的应用系统已经比比皆是,尤其是电子商务网站,要想网站发展壮大,那么必然就得能够承受住庞大的网站访问量:大家知道如果服务器访问量过大,就会出现服应用务器崩溃的情况,这个时候怎么办,难道就只能去重启服务器吗?好,如果是一般的小型公益网站到也无所谓,但如果是比如像大型航空公司售票等电子商务网站,每天每小时都有大量的订单业务,如果这些售票系统一旦崩溃后,再去重启,这些时间和客户的损失就直接会影响到航空公司的利益,这些损失如何去避

使用apache和nginx代理实现tomcat负载均衡及集群配置详解

实验环境: 1.nginx的代理功能 nginx proxy: eth0: 192.168.8.48 vmnet2 eth1: 192.168.10.10 tomcat server1: vmnet2 eth0: 192.168.10.20 tomcat server2: vmnet2 eth0: 192.168.10.30 # yum install -y nginx-1.8.1-1.el6.ngx.x86_64.rpm # vim /etc/nginx/conf.d/default.conf

基于mod_proxy+Apache 2.2.16+Tomcat 7的负载均衡与集群配置

第一章. 背景简介 对于大多数企业应用,都希望能做到7*24小时不间断运行.要保持如此高的可用性并非易事,比较常见的做法是将系统部署到多台机器上,每台机器都对外提供同样的功能,这就是集群.系统变为集群时,除了要求系统能够支持水平伸缩外,还要解决两个问题: 1, 如何均衡地访问到提供业务功能的机器. 2, 如何保证当机器出现问题时,用户能自动跳转到另外的机器,不影响使用. 常用的负载均衡技术有硬件和软件两种,本示例常用软件的技术实现.软件也有很多实现技术,如基于apache的mod_jk以及mod

linux下apache+tomcat负载均衡和集群

先说下我的环境 一台ubuntu的虚拟机, 一个apache2.2的实例 两个tomcat1.7的实例 1.安装apache服务器 sudo apt-get install apache2 如果要重启的话,运行命令: sudo /etc/init.d/apache2 restart ubuntu下的apache会默认创建路径/var/www,apache默认加载的时候,就是加载的这个路径下面的 2.安装两个tomcat实例 去官网下载一个 然后在本地在cp一下, 此时目录结构为: /home/h

Apache + Tomcat + JK 实现负载均衡和集群(状态复制)

原文请见http://www.cnblogs.com/dennisit/p/3370220.html 本文介绍了集群和负载均衡的基本开源实现,实现了用Apache分发请求到多个Tomcat里面对应的应用. 模块介绍 - Apache作为Web服务器,用于处理静态Http请求: - Tomcat作为应用服务器(Servlet容器),处理动态请求: - JK 作为Apache与Tomcat之间的桥梁,实现了Apache与Tomcat一对多的对应,使后端Tomcat负载均衡. 开发环境 - Windo

Apache + Tomcat + JK 实现负载均衡和集群

本文介绍了集群和负载均衡的基本开源实现,实现了用Apache分发请求到多个Tomcat里面对应的应用. 模块介绍 - Apache作为Web服务器,用于处理静态Http请求: - Tomcat作为应用服务器(Servlet容器),处理动态请求: - JK 作为Apache与Tomcat之间的桥梁,实现了Apache与Tomcat一对多的对应,使后端Tomcat负载均衡. 开发环境 - Windows 7操作系统 - Java SE8 - Apache 2.2.14    (本地安装路径:D:\A