网站负载均衡解决方案

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

网站负载均衡解决方案

Web负载均衡(Load Balancing),简单地说就是给我们的服务器集群分配“工作任务”,而采用恰当的分配方式,对于保护处于后端的Web服务器来说,非常重要。

反向代理负载均衡

反向代理服务的核心工作主要是转发HTTP请求,扮演了浏览器端和后台Web 服务器中转的角色。因为它工作在HTTP层(应用层),也就是网络七层结构中的第七层,因此也被称为“七层负载均衡”。可以做反向代理的软件很多,比较常见的一种是Nginx。

Nginx 是一种非常灵活的反向代理软件,可以自由定制化转发策略,分配服务器流量的权重等。反向代理中,常见的一个问题,就是Web服务器存储的session 数据,因为一般负载均衡的策略都是随机分配请求的。同一个登录用户的请求,无法保证一定分配到相同的Web机器上,会导致无法找到session的问题。

解决方案主要有两种:

配置反向代理的转发规则,让同一个用户的请求一定落到同一台机器上(通过分析cookie),复杂的转发规则将会消耗更多的CPU,也增加了代理服务器的负担。

将session这类的信息,专门用某个独立服务来存储,例如redis/memchache,这个方案是比较推荐的。

反向代理服务,也是可以开启缓存的,如果开启了,会增加反向代理的负担,需要谨慎使用。这种负载均衡策略实现和部署非常简单,而且性能表现也比较好。但是,它有“单点故障”的问题,如果挂了,会带来很多的麻烦。而且,到了后期Web服务器继续增加,它本身可能成为系统的瓶颈。

配置文件样本:

#user nobody;

worker_processes 1; #pid logs/nginx.pid;

events {

worker_connections 1024; }

http {

include mime.types;

default_type application/octet-stream;

sendfile on;

keepalive_timeout 65;

upstream {

server 192.168.1.188:80 weight=5;

server 192.168.1.158:80;

}

server {

listen 80;

server_name ;

location / {

proxy_pass ;

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }

使用memcache同步session并协调缓存

一旦使用了负载均衡,session就会存在同步问题,使用memcache同步session 是个不错的解决方案。

需要准备一个相对强大的memcache服务器,安装memcache服务。代码层将其他几个主机的seesion都指定到这台memcache服务器。

相关文章阅读(提供了memcache的详细讲解涵盖:介绍、安装、使用等说明):《memcache缓存与session》

地址:/books/read_10090.html

memcache是什么?

memcached 是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 为首开发的一款软件。现在已成为mixi、hatena、Facebook、Vox、LiveJournal 等众多服务中提高Web

应用扩展性的重要因素。许多Web 应用都将数据保存到RDBMS 中,应用服务器从中读取数据并在浏览器中显示。但随着数据量的增大、访问的集中,就会出现RDBMS 的负担加重、数据库响应恶化、网站显示延迟等重大影响。这时就该memcached 大显身手了。memcached 是高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web 应用的速度、提高可扩展性。

memcached 与php结合原理

memcache 缓存数据形式

memcache以键值对形式进行数据的保存,通过与php的结合memcahe可以将变量、数组、对象等数据保存到内存中。极大的提升了服务器缓存的效率。

为了提高性能,memcached 中保存的数据都存储在memcached 内置的内存存储空间中。由于数据仅存在于内存中,因此重启memcached、重启操作系统会导致全部数据消失。另外,内容容量达到指定值之后,就基于LRU(Least Recently Used)算法自动删除不使用的缓存。memcached 本身是为缓存而设计的服务器,因此并没有过多考虑数据的永久性问题。

开启php的memcache扩展

php默认情况下并没有开启的memcache扩展,下面将详细讲解memcache扩展的安装。

windows下安装memcache扩展

访问php官网/package/memcache

点击DLL 下载对应windows版本的dll

将dll复制到php/ext/

修改php.ini

extension=php_memcache.dll

重启web访问即可开启

linux下安装memcache扩展

centOs :

yum install php-pecl-memcache 从启php即可。

或者在linux下编译安装php的扩展,下载地址同上

php操作memcache缓存

安装好了memcache服务和php的扩展,我们就可以使用php去操作memcache 来实现缓存啦!

PHP的Memcache客户端所有方法总结

memcache 类所有的方法列表如下:

Memcache::add –添加一个值,如果已经存在,则返回false Memcache::addServer –添加一个可供使用的服务器地址 Memcache::close –关闭一个Memcache对象 Memcache::connect –创建一个Memcache对象memcache_debug –控制调试功能 Memcache::decrement –对保存的某个key中的值进行减法操作 Memcache::delete –删除一个key值Memcache::flush –清除所有缓存的数据 Memcache::get –获取一个key值不存在则返回falseMemcache::getExtendedStats –获取进程池中所有进程的运行系统统计 Memcache::getServerStatus –获取运行服务器的参数Memcache::getStats –返回服务器的一些运行统计信息

Memcache::getVersion –返回运行的Memcache的版本信息

Memcache::increment –对保存的某个key中的值进行加法操作Memcache::pconnect –创建一个Memcache的持久连接对象

Memcache::replace -对一个已有的key进行覆写操作 Memcache::set –添加一个值,如果已经存在,则覆写 Memcache::setCompressThreshold –对大于某一大小的数据进行压缩 Memcache::setServerParams –在运行时修改服务器的参数

读取并设置缓存代码实例

$memObj = new Memcache();//连接memcache服务器参数地址,端口(memcache 的默认端口为 11211)

$memObj->connect('127.0.0.1', 11211);//获取某个变量的值如果存在在返回变量的值否则返回false

相关文档
最新文档