`
haohappy2
  • 浏览: 326361 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

PHP分布式内存共享(Memcache)

阅读更多

分布式内存共享。目前在PHP领域中能够做到分布式内存共享的只有Memcache。

1.memcached详细介绍。

引用
通常的网页缓存方式有动态缓存和静态缓存等几种,在ASP.NET中已经可以实现对页面局部进行缓存,而使用memcached的缓存比 ASP.NET的局部缓存更加灵活,可以缓存任意的对象,不管是否在页面上输出。而memcached最大的优点是可以分布式的部署,这对于大规模应用来 说也是必不可少的要求。
LiveJournal.com使用了memcached在前端进行缓存,取得了良好的效果,而像wikipedia,sourceforge等也采用了或即将采用memcached作为缓存工具。memcached可以大规模网站应用发挥巨大的作用。

Memcached是什么?
Memcached是高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。
Memcached由Danga Interactive开发,用于提升LiveJournal.com访问速度的。LJ每秒动态页面访问量几千次,用户700万。Memcached将数据库负载大幅度降低,更好的分配资源,更快速访问。

如何使用memcached-Server端?
在服务端运行:
# ./memcached -d -m 2048 -l 10.0.0.40 -p 11211
这将会启动一个占用2G内存的进程,并打开11211端口用于接收请求。由于32位系统只能处理4G内存的寻址,所以在大于4G内存使用PAE的32位服务器上可以运行2-3个进程,并在不同端口进行监听。

如何使用memcached-Client端?
在应用端包含一个用于描述Client的Class后,就可以直接使用,非常简单。
PHP Example:
$options["servers"] = array("192.168.1.41:11211", "192.168.1.42:11212");
$options["debug"] = false;
$memc = new MemCachedClient($options);
$myarr = array("one","two", 3);
$memc->set("key_one", $myarr);
$val = $memc->get("key_one");
print $val[0]."\n"; // prints 'one‘
print $val[1]."\n"; // prints 'two‘
print $val[2]."\n"; // prints 3

为什么不使用数据库做这些?

暂且不考虑使用什么样的数据库(MS-SQL, Oracle, Postgres, MysQL-InnoDB, etc..), 实现事务(ACID,Atomicity, Consistency, Isolation, and Durability )需要大量开销,特别当使用到硬盘的时候,这就意味着查询可能会阻塞。当使用不包含事务的数据库(例如Mysql-MyISAM),上面的开销不存在,但 读线程又可能会被写线程阻塞。
Memcached从不阻塞,速度非常快。

为什么不使用共享内存?
最初的缓存做法是在线程内对对象进行缓存,但这样进程间就无法共享缓存,命中率非常低,导致缓存效率极低。后来出现了共享内存的缓存,多个进程或者线程共享同一块缓存,但毕竟还是只能局限在一台机器上,多台机器做相同的缓存同样是一种资源的浪费,而且命中率也比较低。
Memcached Server和Clients共同工作,实现跨服务器分布式的全局的缓存。并且可以与Web Server共同工作,Web Server对CPU要求高,对内存要求低,Memcached Server对CPU要求低,对内存要求高,所以可以搭配使用。

Mysql 4.x的缓存怎么样?
Mysql查询缓存不是很理想,因为以下几点:
当指定的表发生更新后,查询缓存会被清空。在一个大负载的系统上这样的事情发生的非常频繁,导致查询缓存效率非常低,有的情况下甚至还不如不开,因为它对cache的管理还是会有开销。
在32位机器上,Mysql对内存的操作还是被限制在4G以内,但memcached可以分布开,内存规模理论上不受限制。
Mysql上的是查询缓存,而不是对象缓存,如果在查询后还需要大量其它操作,查询缓存就帮不上忙了。
如果要缓存的数据不大,并且查询的不是非常频繁,这样的情况下可以用Mysql 查询缓存,不然的话memcached更好。

数据库同步怎么样?
这里的数据库同步是指的类似Mysql Master-Slave模式的靠日志同步实现数据库同步的机制。
你可以分布读操作,但无法分布写操作,但写操作的同步需要消耗大量的资源,而且这个开销是随着slave服务器的增长而不断增长的。
下一步是要对数据库进行水平切分,从而让不同的数据分布到不同的数据库服务器组上,从而实现分布的读写,这需要在应用中实现根据不同的数据连接不同的数据库。
当这一模式工作后(我们也推荐这样做),更多的数据库导致更多的让人头疼的硬件错误。
Memcached可以有效的降低对数据库的访问,让数据库用主要的精力来做不频繁的写操作,而这是数据库自己控制的,很少会自己阻塞 自己。

Memcached快吗?

非常快,它使用libevent,可以应付任意数量打开的连接(使用epoll,而非poll),使用非阻塞网络IO,分布式散列对象到不同的服务器,查询复杂度是O(1)。(于敦德)

参考资料:
Distributed Caching with Memcached | Linux Journal
http://www.danga.com/
http://www.linuxjournal.com/article/7451



2.memcached在freebsd下的安装:

引用
步骤1:安装memcached
代码:
# cd /usr/ports/databases/memcached/
# make install

步骤2:启动memcached
代码:
#/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd
参数解释:
-d 以守护程序(daemon)方式运行 memcached;
-m 设置 memcached 可以使用的内存大小,单位为 M;
-l 设置监听的 IP 地址,如果是本机的话,通常可以不设置此参数;
-p 设置监听的端口,默认为 11211,所以也可以不设置此参数;
-u 指定用户,如果当前为 root 的话,需要使用此参数指定用户。

以上以完成了memcached的安装及启动!
使用时按要求填上IP与端口既可



3.memcached 的工作原理
首先 memcached 是以守护程序方式运行于一个或多个服务器中,随时接受客户端的连接操作,客户端可以由各种语言编写,目前已知的客户端 API 包括 Perl/PHP/Python/Ruby/Java/C#/C 等等。PHP 等客户端在与 memcached 服务建立连接之后,接下来的事情就是存取对象了,每个被存取的对象都有一个唯一的标识符 key,存取操作均通过这个 key 进行,保存到 memcached 中的对象实际上是放置内存中的,并不是保存在 cache 文件中的,这也是为什么 memcached 能够如此高效快速的原因。注意,这些对象并不是持久的,服务停止之后,里边的数据就会丢失。
点击在新窗口中浏览此图片

 

 

 

 

 

 

 

4.安装php对memcache支持模块
有两种方法可以使 PHP 作为 memcached 客户端,调用 memcached 的服务进行对象存取操作。

第一种,PHP 有一个叫做 memcache 的扩展,Linux 下编译时需要带上 –enable-memcache[=DIR] 选项,Window 下则在 php.ini 中去掉 php_memcache.dll 前边的注释符,使其可用。
http://pecl.php.net/package/memcache

除此之外,还有一种方法,可以避开扩展、重新编译所带来的麻烦,那就是直接使用 php-memcached-client。
http://nio.infor96.com/wp-content/uploads/2006/04/memcached-client.zip
本文选用第二种方式,虽然效率会比扩展库稍差一些,但问题不大。

分享到:
评论

相关推荐

    PHP实现多服务器session共享之memcache共享.rar

    PHP的memcache扩展提供了一个解决方案,它是一个高性能的分布式内存对象缓存系统,常被用来作为session存储后端。通过配置php.ini文件,可以将session的存储机制从默认的文件系统改为memcache服务器集群。 具体实现...

    PHP 5.4 使用的 memcache

    安装完成后,通过启动Memcache服务,可以在多个服务器之间共享内存资源,实现数据的高速缓存。 **php_memcache.dll** `php_memcache.dll`是PHP的Memcache扩展的动态链接库,用于在PHP环境中与Memcache服务端通信。...

    memcache安装php5.2.17的php_memcache.dll

    Memcache是一种广泛使用的分布式内存对象缓存系统,它可以在服务器集群间通过网络共享小块内存,从而提升应用程序的性能,减少数据库负载。在PHP中,我们通常使用php_memcache.dll扩展来与Memcache服务器进行交互。...

    PHP 实现多服务器session共享之memcache共享

    总结,通过memcache实现PHP的多服务器session共享,可以有效解决分布式系统中的用户状态同步问题,提高系统的可扩展性和稳定性。然而,这也需要开发者对memcache、PHP配置以及网络通信有深入的理解,以便在实际应用...

    PHP全版本 memcache dll扩展包

    而Memcache则是一款高性能的分布式内存对象缓存系统,常用于减轻数据库负载,提升网站性能。当PHP与Memcache结合,可以实现快速存储和检索数据,优化动态内容的生成速度。 **Memcache扩展的安装与配置** 在Windows...

    memcache1.2.1 for windows

    4. **负载均衡**:在分布式环境中,多个应用服务器共享同一Memcache集群,确保数据一致性。 **注意事项** 1. **数据持久性**:Memcache不支持数据持久化,断电或重启后数据丢失,适用于临时存储。 2. **内存管理**...

    Windows_Memcache安装(XAMPP+Memcache+PHP)

    Memcache的分布式特性允许多个用户从不同主机访问同一缓存系统,解决了单机共享内存的局限性,同时显著提高了数据访问速度。 在Windows环境下,Memcache可以在XAMPP环境中进行安装。安装过程可以分为几个步骤:首先...

    pecl-memcache-php7

    Memcache是一个广泛使用的分布式内存缓存系统,它的主要目标是减轻数据库负载,通过将经常访问的数据暂存到内存中,来提高数据读取的速度。Memcache采用简单的键值对存储方式,支持多语言接口,能够在多种操作系统上...

    php5.3.5下可以使用的php_memcache.dll

    Memcache是一个高性能、分布式的内存对象缓存系统,它能够存储和检索数据,如网站动态页面生成所需的数据,以减轻数据库的负担,提高网站性能。Memcache通过在网络服务器之间共享内存来存储数据,因此访问速度非常...

    memcache.dll下载PHP5.4

    8. **memcached与memcache的区别**:虽然两者名字相似,但memcached是一个基于libevent的分布式内存缓存系统,而memcache是PHP的客户端库。memcached更常见于服务器端,memcache多用于PHP编程。 9. **调试与问题...

    php_memcache-3.0.8-5.5 32位dll扩展模块 download下载

    Memcached是一个高性能、分布式内存对象缓存系统,常用于减轻数据库负载,提高网站的响应速度。PHP Memcache扩展使得PHP应用程序能够便捷地存储和检索数据,通过减少对数据库的直接访问来优化性能。 标题中提到的...

    PHP实现多服务器session共享之memcache共享

    首先,memcached是一个高性能的分布式内存对象缓存系统,它可以临时存储数据,减少数据库负载。在PHP中,我们可以通过php_memcache扩展与memcached服务器进行交互。安装php_memcache扩展通常是通过编译源码或使用包...

    PHP5.2、5.3、5.4、5.5的memcache dll扩展下载 php_memcache.dll

    Memcache是一种广泛使用的分布式内存对象缓存系统,它可以临时存储数据,减少数据库的负载。Memcache扩展使得PHP应用程序能够轻松地与Memcached服务器进行通信,执行诸如添加、删除、检索缓存数据等操作。 描述中的...

    session共享之memcache Redis

    memcache和Redis是两种常见的内存缓存系统,它们都可以被用来存储和共享Session数据。 1. **memcache**:它是一个高性能、分布式的内存对象缓存系统,用于临时存储低访问频率的数据。将Session数据存储在memcache中...

    memcache dll扩展满足各版本PHP

    Memcache是一个广泛使用的分布式内存对象缓存系统,它可以存储和检索数据(包括字符串、对象)以减少对数据库的访问,从而提高了Web应用的响应速度。PHP的memcache扩展允许开发者通过PHP代码与memcached服务器进行...

    php 5.3/5.4/5.5 windows 32/64位memcache.dll扩展

    Memcache是一款高性能的分布式内存对象缓存系统,它能够通过在内存中存储数据来减少数据库负载,提升Web应用的性能。在PHP中,通过安装并配置`memcache.dll`扩展,可以实现对Memcache服务的接口调用。 1. **PHP版本...

    php memcache php_apc php_file 缓存插件

    Memcache是一个高性能的分布式内存对象缓存系统,可以用于存储各种格式的数据,如字符串、整数和对象。PHP通过`memcache`扩展与Memcache服务器通信,提供了一套API用于存取数据。使用Memcache,可以显著提升网站的...

    PHP7.x memcache dll ts nts x86x64

    Memcache是PHP的一个流行扩展,用于实现分布式内存对象缓存系统。它能够存储临时数据,提高网站的响应速度,减轻数据库的压力。Memcache扩展允许PHP应用程序与Memcached服务器进行通信,存储和检索数据。在PHP7.x中...

    memcache_php使用测试

    **memcache**模块作为高效内存缓存的守护进程,提供了程序式和面向对象的接口,尤其在设计动态Web程序时,它能够显著减少对数据库的直接访问,从而提升应用性能。此外,memcache还支持通信对话(session_handler)的...

Global site tag (gtag.js) - Google Analytics