转】Apache解决高并发和高可用
原博主于: http://www.ha97.com/5803.html 感谢!
服务器集群
Apache 和 nginx(web服务器)
1、 多台集群机器联合处理一个任务。
2、 一台机器处理不同的多个任务。
特点:
处理静态数据速度快(自动html静态数据的缓存)
并发数一般要比J2EE服务器要高。
安装apache:

1、简单安装:yum install httpd
2、源码安装
1、安装apr
- 解压
- ./configure --prefix=/usr/local/apr 指定安装目录
- Make && make install
ii. 安装apr-util
- 解压
- ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
- Make && make install
iii. 源码安装apache
- 解压
./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=most --with-mpm=event
3.Make && make install
b) Apache和tomcat的连接
apache 连接tomcat
连接方法:两种
基于ajp协议方式连接,基于二进制
基于HTTP协议连接
两种连接工具:
Proxy:mod_proxy.so
Connectors:mod_jk.so
1、mod_jk :使用的是ajp连接器。
mod_jk 1x
mod_jk 2x :丢弃
ajp协议:
基于二进制,速度快,兼容。安全。
1、下载mod_jk
a、tomcat-conentors ,需要安装之后才能得到mod_jk.so
b、mod_jk.so
2、mod_jk.so放到apache目录下mudules目录
3、编辑apache配置文件
LoadModule jk_module modules/mod_jk.so
JkWorkersFile conf/workers.properties
JkLogFile logs/mod_jk.log
JkLogLevel info
JkMount /* controller
新建一个workers.properties
worker.list=controller
worker.tomcat1.port=8009
worker.tomcat1.host=192.168.197.128
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor=1
worker.tomcat2.port=8009
worker.tomcat2.host=192.168.197.129
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor=1
worker.controller.type=lb #lb:表示负载均衡器
worker.controller.balance_workers=tomcat2,tomcat1
worker.controller.sticky_session=0 # 表示apache不处理session,每次传入sessionID
worker.controller.sticky_session_force=0
2、proxy_mod:支持ajp和http连接器。 (官方推荐)
是apache自带的一个模块。
1、检查Proxy_mod是否开启。
2、编辑apache配置文件:httpd.cnf
ProxyVia Off #设置响应时是否出现主机信息。
ProxyRequests Off #:是否开启apache的正向代理功能,正反向不能同时使用
ProxyPreserveHost Off #:是否在反向代理中支持虚拟主机
ProxyPass / ajp://localhost:8009/
ProxyPassReverse / ajp://localhost:8009/ #表示用户响应是可能使用重定向也需要经过代理服务器
3、负载均衡器
1、硬件负载均衡
2、软件负载均衡
在apache配置文件中
<Proxy balancer://mybl>
BalancerMember ajp://192.168.197.128:8009 loadfactor=1 route=tomcat1
BalancerMember ajp://192.168.197.129:8009 loadfactor=1 route=tomcat2
ProxySet lbmethod=byrequests
</Proxy>
ProxyPass / balancer://mybl/ 使用负载均衡器
ProxyPassReverse / balancer://mybl/
mybl:表示负载均衡器的名字
BalancerMember:代表一个后端应用服务器
loadfactor=权重 ,决定节点压力大小。
route:后端应用服务器的名字(负载均衡时必须要)
在tomcat的配置文件中定义名字
server.xml
ProxySet lbmethod=byrequests ,根据请求的数量进行负责均衡
lbmethod=byrequests 按照请求次数均衡(默认)
lbmethod=bytraffic 按照流量均衡
lbmethod=bybusyness 按照繁忙程度均衡(总是分配给活跃请求数最少的服务器)
stickysession=JSESSIONID|jsessionid nofailover=On
apache虚拟主机
1、 一台机器运行多个项目。
a) 项目a –》tomcat1:8080和项目 b ---》tomcat2:8081
b) 使用apache配置虚拟主机
<VirtualHost *:80> * :任意的客户端
DocumentRoot "/usr/local/apache/docs/dummy-host2.example.com" 静态资源路径
ServerName peiyou.com(该项目访问的域名,每个虚拟主机要不同)
ErrorLog "logs/dummy-host2.example.com-error_log"
CustomLog "logs/dummy-host2.example.com-access_log" common
#ProxyVia Off
#ProxyPreserveHost Off
#ProxyRequests Off
#ProxyPass / ajp://h1:8009/
#ProxyPassReverse / ajp://h1:8009/
</VirtualHost>
session:的处理
1、session复制
tomcat 本身带有复制session的功能。(不讲)
2、共享session
需要专门管理session的软件,
memcached 缓存服务,可以和tomcat整合,帮助tomcat共享管理session。
安装memcached
1、安装libevent
2、安装memcached
3、启动memcached
memcached -d -m 128m -p 11211 -l 192.168.197.128 -u root -P /temp/
-d:后台启动服务 http://www.ha97.com/5803.html
-m:缓存大小
-p:端口
-l:IP
-P:服务器启动后的系统进程ID,存储的文件
-u:服务器启动是以哪个用户名作为管理用户
3、拷贝jar到tomcat的lib下
4、配置tomcat,每个tomcat里面的context.xml中加入:
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:192.168.197.128:11211"
sticky="false"
lockingMode="auto"
sessionBackupAsync="false"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
sessionBackupTimeout="1000" transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:host1.yourdomain.com:11211,n1:host2.yourdomain.com:11211"
sticky="false"
sessionBackupAsync="false"
lockingMode="uriPattern:/path1|/path2"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"
/>

转】Apache解决高并发和高可用的更多相关文章
- java亿级流量电商详情页系统的大型高并发与高可用缓存架构实战视频教程
亿级流量电商详情页系统的大型高并发与高可用缓存架构实战 完整高清含源码,需要课程的联系QQ:2608609000 1[免费观看]课程介绍以及高并发高可用复杂系统中的缓存架构有哪些东西2[免费观看]基于 ...
- 【Distributed】大型网站高并发和高可用
一.DNS域名解析 二.大型网站系统应有的特点 三.网站架构演变过程 3.1 传统架构 3.2 分布式架构 3.3 SOA架构 3.4 微服务架构 四.高并发设计原则 4.1 拆分系统 4.2 服务化 ...
- 5. 支撑高并发,高可用,海量数据备份恢复的Redis重要性
商品详情页的架构实现 缓存架构 第一块儿,要掌握的很好的,就是redis架构 高并发,高可用,海量数据,备份,随时可以恢复,缓存架构如果要支撑这些要点,首先呢,redis就得支撑 redis架构,每秒 ...
- 5.如何保证 redis 的高并发和高可用?redis 的主从复制原理能介绍一下么?redis 的哨兵原理能介绍一下么?
作者:中华石杉 面试题 如何保证 redis 的高并发和高可用?redis 的主从复制原理能介绍一下么?redis 的哨兵原理能介绍一下么? 面试官心理分析 其实问这个问题,主要是考考你,redis ...
- 面试系列15 如何保证Redis的高并发和高可用
就是如果你用redis缓存技术的话,肯定要考虑如何用redis来加多台机器,保证redis是高并发的,还有就是如何让Redis保证自己不是挂掉以后就直接死掉了,redis高可用 我这里会选用我之前讲解 ...
- 优秀开源项目之三:高性能、高并发、高扩展性和可读性的网络服务器架构State Threads
译文在后面. State Threads for Internet Applications Introduction State Threads is an application library ...
- [ 高并发]Java高并发编程系列第二篇--线程同步
高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...
- tcp/udp高并发和高吐吞性能测试工具
在编写一个网络服务的时候都比较关心这个服务能达到多少并发连接,而在这连接的基础上又能达到一个怎样的交互能力.编写服务已经是一件很花力气的事情,而还要去编写一个能够体现结果的测试工具就更加消耗工作时间. ...
- 在高并发、高负载的情况下,如何给表添加字段并设置DEFAULT值?
在高并发.高负载的情况下,如何给表添加字段并设置DEFAULT值? 在Oracle 12c之前,当Oracle表数据量上亿时,对表执行“ALTER TABLE XXX ADD COLUMN_XX VA ...
- Nginx和Tengine解决高并发和高可用,而非推荐Apache
什么是Nginx 什么是Tengine 看看国内大公司在用Nginx和Tengine吗? 步骤一:进入 https://www.taobao.com/,按F12.可看到 有很多APP对淘宝进行请求. ...
随机推荐
- 【原创】Kmeans算法 优缺点分析
优点: 原理简单(靠近中心点),实现容易(1.2 天),聚类效果中上(依赖K的选择) 缺点: 1. 无法确定K的个数 (根据什么指标确定K) 2. 对离群点敏感 (容易导致中心点偏移) 3. 算法复杂 ...
- jsp获取struts2查询到的数据
1.在struts2的方法中利用查询语句查询到结果,然后再对结果进行封装,jsp根据封装获取相关信息 struts2的查询和封装方法: private List<FreeMarkerDetail ...
- JAVA文件中获取路径及WEB应用程序获取路径方法
JAVA文件中获取路径及WEB应用程序获取路径方法 1. 基本概念的理解 `绝对路径`:你应用上的文件或目录在硬盘上真正的路径,如:URL.物理路径 例如: c:/xyz/test.txt代表了tes ...
- [Codeforces667A]Pouring Rain(数学,几何)
题目链接:http://codeforces.com/contest/667/problem/A 题意:一个杯子里有水,一个人在喝并且同时在往里倒.问这个人能不能喝完,多久能喝完. 把相关变量都量化成 ...
- poj 1703 Find them, Catch them(并查集)
题目:http://poj.org/problem?id=1703 题意:一个地方有两个帮派, 每个罪犯只属于其中一个帮派,D 后输入的是两个人属于不同的帮派, A后询问 两个人是否属于 同一个帮派. ...
- bzoj1296: [SCOI2009]粉刷匠
dp. 用到俩次dp,用1和0代表俩种颜色,首先对于每块木板我们进行一次dp,g[i][j]代表前j个格子刷i次最多能涂到几个格子. 则 g[i][j]=max(g[i-1][k],max(cnt[j ...
- HTTPS通信机制
概述 使用HTTP协议进行通信时,由于传输的是明文所以很容易遭到窃听,就算是加密过的信息也容易在传输中遭受到篡改,因此需要在HTTP协议基础上添加加密处理,认证处理等,有了这些处理机制的HTTP成为H ...
- UVa 11235 (RMQ) Frequent values
范围最值问题,O(nlogn)的预处理,O(1)的查询. 这个题就是先对这些数列进行游程编码,重复的元素只记录下重复的次数. 对于所查询的[L, R]如果它完全覆盖了某些连续的重复片段,那么查询的就是 ...
- HDU 1686 (KMP模式串出现的次数) Oulipo
题意: 求模式串W在母串T中出现的次数,各个匹配串中允许有重叠的部分. 分析: 一开始想不清楚当一次匹配完成时该怎么办,我还SB地让i回溯到某个位置上去. 后来仔细想想,完全不用,直接让模式串向前滑动 ...
- 继承在WCF中的问题和解决办法
1. 问题 假设有代码如下: [ServiceContract] public interface IA { [OperationContract] string M1(); } [ServiceCo ...