mac下安装memcached

mac下安装memcached

更多memcached信息可以参考http://www.ibm.com/developerworks/cn/java/j-memcached1/

memcached是由DangaInteractive开发并使用BSD许可的一种通用的分布式内存缓存系统。

DangaInteractive开发memcached的目的是创建一个内存缓存系统来处理其网站LiveJournal.com的巨大流量。每天超过2000万的页面访问量给LiveJournal的数据库施加了巨大的压力,因此Danga的BradFitzpatrick便着手设计了memcached。memcached不仅减少了网站数据库的负载,还成为如今世界上大多数高流量网站所使用的缓存解决方案。

如何将memcached融入到您的环境中。虽然在任何地方都可以使用memcached,但我发现需要在数据库层中执行几个经常性查询时,memcached往往能发挥最大的效用。我经常会在数据库和应用服务器之间设置一系列memcached实例,并采用一种简单的模式来读取和写入这些服务器。

使用memcached的示例应用程序体系结构示意图

体系结构相当容易理解。我建立了一个Web层,其中包括一些Apache实例。下一层是应用程序本身。这一层通常运行于ApacheTomcat或其他开源应用服务器之上。再下面一层是配置memcached实例的地方—即应用服务器与数据库服务器之间。在使用这种配置时,需要采用稍微不同的方式来执行数据库的读取和写入操作。

读取

我执行读取操作的顺序是从Web层获取请求(需要执行一次数据库查询)并检查之前在缓存中存储的查询结果。如果我找到所需的值,则返回它。如果未找到,则执行查询并将结果存储在缓存中,然后再将结果返回给Web层。

写入

将数据写入到数据库中时,首先需要执行数据库写入操作,然后将之前缓存的任何受此写入操作影响的结果设定为无效。此过程有助于防止缓存和数据库之间出现数据不一致性。

libevent是安装memcached的唯一前提条件。它是memcached所依赖的异步事件通知库。您可以在monkey.org上找到关于libevent的源文件。

libeven安装包下载地址http://libevent.org/

memcached安装包下载地址http://memcached.org/

libeven目前比较新的版本是libevent-2.0.21-stable.tar.gz

memcached目前比较新的版本是memcached-1.4.17.tar.gz

安装libeven

解压下载的安装包libevent-2.0.21-stable.tar.gz得到目录libevent-2.0.21-stable

Java代码收藏代码

cdlibevent-2.0.21-stable

sudo./configure--prefix=/usr/local/libevent-2.0.21

sudomake

sudomakeinstall

安装memcached

解压下载的安装包memcached-1.4.17.tar.gz得到目录memcached-1.4.17

Ruby代码收藏代码

cdmemcached-1.4.17

sudo./configure--prefix=/usr/local/memcached-1.4.17--with-libevent=/usr/local/libevent-2.0.21

sudomake

sudomakeinstall

运行memcached

-vv参数调式模式

Ruby代码收藏代码

sudo./memcached-p11211-m64-uroot-vv

-d守护进程模式

Ruby代码收藏代码

sudo./memcached-p11211-m64-uroot-d

摘录自网友文章内容:

#/usr/local/bin/memcached-d-m200-uroot-l192.168.1.91-p12301-c1000-P/tmp/memcached.pid

相关解释如下:

-d选项是启动一个守护进程,

-m是分配给Memcache使用的内存数量,单位是MB,这里是200MB

-u是运行Memcache的用户,如果当前为root的话,需要使用此参数指定用户。

-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.1.91

-p是设置Memcache监听的端口,我这里设置了12301,最好是1024以上的端口

-c选项是最大运行的并发连接数,默认是1024,这里设置了256

-P是设置保存Memcache的pid文件,我这里是保存在/tmp/memcached.pid

停止Memcache进程:

#kill`cat/tmp/memcached.pid`

也可以启动多个守护进程,但是端口不能重复

-------------------------------

一开始说的“-d”参数需要进行进一步的解释

-dinstall安装memcached

-duninstall卸载memcached

-dstart启动memcached服务

-drestart重启memcached服务

-dstop停止memcached服务

-dshutdown停止memcached服务

-------------------------------

附加功能:

1、查看启动的memcache服务:

netstat-lp|grepmemcached

2、查看memcache的进程号(根据进程号,可以结束memcache服务:“kill-9进程号”)

ps-ef|grepmemcached

相关推荐