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