简单实现web服务器负载均衡
来源:互联网 发布:embase数据库 编辑:程序博客网 时间:2024/05/18 00:41
负载均衡建立在现有网络结构之上,提供了一种有效方式扩展服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
本篇讲述如何利用反向代理来实现web服务器负载均衡。
以上负载均衡架构图,优点是架构较简单,缺点是没有根据业务权重设计负载。
以上负载均衡是通过均衡服务器的实际承载,响应请求数量,传输数据流量,来实现负载均衡。
各负载服务器通过svn服务器实现同步,这样他们也必须处理同步可能带来的问题。
数据库作读写分离,合理加上内存数据库。
一、下面以apache为例,简单说明负载均衡的实现。
Apache加载以下三个模块
LoadModule proxy_module modules/mod_proxy.soLoadModule proxy_balancer_module modules/mod_proxy_balancer.soLoadModule proxy_http_module modules/mod_proxy_http.so
添加以下内容:
Listen 192.168.1.30:80<VirtualHost 192.168.1.30:80>ProxyRequests OffProxypass / balancer://proxy/ <Proxy balancer://proxy>ProxySet lbmethod=byrequestsOrder Deny,AllowAllow from allBalancerMember http://192.168.1.31BalancerMember http://192.168.1.32BalancerMember http://192.168.1.33</Proxy></VirtualHost>
这里你还可以通过不同的算法实现负载均衡,比方说按照请求次数,或者按照流量均衡,这里用到的指令是lbmethod
lbmethod可能的取值有:
lbmethod=byrequests 按请求数均衡(默认值)
lbmethod=bytraffic 按流量均衡
lbmethod=bybusyness 按繁忙程度均衡
Apache还有其他策略,本篇就不多描述,当然你还可以使用nginx等等
二、服务器内容同步,可以利用svn来实现。
首先在一个服务器建立一个svn库,用于存放最新的程序,具体步骤可以参考《windows 搭建本地svn服务器》。
以后每次更新都将最新的文件发布到svn库中。
然后在负载服务器上更新即可。
因为每个负载服务器都是独立开来的,这里需要注意几个问题:
1、内容同步
主要是数据库,还好大都数据库有读写锁机制。另外一个就是上传的文件,如果是用户上传可以考虑放到一个公共的资源服务器。后台文件可以考虑svn同步更新。
2、会话同步
因为是不同服务器,一般session都以文件或者内存形式保存在本地。考虑使用memcached来共享session。
下面以php为例:
;修改php设置文件:session.save_handler = memcachesession.save_path = "tcp://192.168.1.33:11211"
三、数据库作读写分离,合理利用内存数据库。
web服务器访问的瓶颈的很大原因在于数据库读写上,这时候可以除了做数据库查询优化,索引优化等,还可以考虑将数据库读写分离,如果内容更新太快且保存的价值不大,或者内容长时间不更新,而且经常都要读取等等,都可以考虑使用内存数据库,如memcached。
- 简单实现web服务器负载均衡
- web服务器负载均衡实现
- HAProxy+Keepalived实现Web服务器负载均衡
- Nginx+Keepalived实现Web服务器负载均衡
- HAProxy+Keepalived实现Web服务器负载均衡
- HAProxy+Keepalived实现Web服务器负载均衡
- HAProxy+Keepalived实现Web服务器负载均衡
- Nginx+Keepalived实现Web服务器负载均衡
- Nginx+Keepalived实现Web服务器负载均衡
- Web服务器负载均衡
- 实现服务器负载均衡
- 简单实现负载均衡
- 实现四台Web服务器的负载均衡
- 实现四台Web服务器的负载均衡
- 实现四台Web服务器的负载均衡
- 实现四台Web服务器的负载均衡
- 实现四台Web服务器的负载均衡
- 利用集群技术实现Web服务器负载均衡
- hdu 1312 Red and Black
- Ubuntu 13.04编译boost1.54
- 解函数方程
- Flex之旅--AdvancedDataGrid 修改树节点图标
- WP7-常用控件简介
- 简单实现web服务器负载均衡
- Java单例对象同步问题探讨
- Oracle Data Guard Switchover 切换
- zoj 3689 Digging (dp)
- jQuery重复绑定事件
- 去跨国公司还是去创业公司?
- ruby 性感的迭代操作
- http 405在servlet中的出现原因和解决方法
- 通过主对话框向其他(子)对话框发送消息