Memcached 是一个高性能的分布式内存对象缓存系统。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。
最近跟版模板网也给自己的阿里云服务器安装了 Memcached,效果似乎还不错哦。
测试环境:阿里云 CentOS 6.564位,军哥的 LNMP一键安装包配置的环境 1.2。
安装 Memcached
lnmp1.2 :进入lnmp解压后的目录,执行:./addons.sh install memcached(这是军哥lnmp内置的安装脚本,其他自己配置的环境,自己google安装方法吧)
可以根据自己的需求选择php-memcache或php-memcached扩展,目前discuz x使用的是前者,功能上php-memcached更强大一些。如果要使用下文的 WordPress 插件,请选择php-memcache(也就是1),否则会有问题
输入对应的序号,回车,再次确认回车开始安装。
安装完以后,就可以正常启用了。
WordPress 开启 Memcached 缓存
下载 WordPress Memcached 插件,解压后,将 object-cache.php 上传到 wp-content 目录(不是 wp-content/plugins/),这样 WordPress 会自动检查在 wp-content 目录下是否有 object-cache.php 文件,如果有,直接调用它作为 WordPress 对象缓存机制。
注意:如果你的服务器安装了多个 WordPress,请确保每个WordPress站点使用了不同的数据库前缀,如果前缀一样,比如都是 wp_ ,就很可能造成冲突,因为每个网站的数据都通过内存进行缓存,前缀一样就会打架啦!
为你的 WordPress 站点开启了 memcached 缓存以后,就没必要安装 DB Cache Reloaded Fix 这类数据库缓存插件了。
查看 Memcached 缓存情况
我们需要使用 telnet 命令查看,首先检测一下是否已安装 telnet 包
1 | rpm -qa |grep telnet |
如果安装了,会返回相关版本
telnet-0.17-41.el5
telnet-server-0.17-41.el5
如果没有安装,运行下面的命令,注意在root下安装
1 2 3 | yum install xinetd
yum install telnet
yum install telnet-server |
特别说明:telnet服务要依靠xinetd服务启动,所以要先安装xinetd服务。所以我们要先安装xinetd,再安装telnet-server。
然后链接到 telnet 服务
1 | telnet 127.0.0.1 11211 |
如果链接成功,会返回:
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
然后输入
1 | stats |
回车,就可以看到 Memcached 的缓存情况
STAT pid 20439 —— Memcached 进程的ID
STAT uptime 179982 —— 进程运行时间
STAT time 1382361665 ——当前时间
STAT version 1.4.15 —— Memcached 版本
STAT libevent 1.4.13-stable
STAT pointer_size 32
STAT rusage_user 21.916668
STAT rusage_system 40.576831
STAT curr_connections 11
STAT total_connections 329
STAT connection_structures 23
STAT reserved_fds 20
STAT cmd_get 2363348 —— 总共获取数据的次数(等于 get_hits + get_misses )
STAT cmd_set 279971 —— 总共设置数据的次数
STAT cmd_flush 0
STAT cmd_touch 0
STAT get_hits 2286284 —— 命中了多少次数据,也就是从 Memcached 缓存中成功获取数据的次数
STAT get_misses 77064 —— 没有命中的次数
STAT delete_misses 30803
STAT delete_hits 48876
STAT incr_misses 0
STAT incr_hits 0
STAT decr_misses 0
STAT decr_hits 0
STAT cas_misses 0
STAT cas_hits 0
STAT cas_badval 0
STAT touch_hits 0
STAT touch_misses 0
STAT auth_cmds 0
STAT auth_errors 0
STAT bytes_read 574591015
STAT bytes_written 4353057466
STAT limit_maxbytes 67108864 —— 总的存储大小,默认为 64M
STAT accepting_conns 1
STAT listen_disabled_num 0
STAT threads 4
STAT conn_yields 0
STAT hash_power_level 16
STAT hash_bytes 262144
STAT hash_is_expanding 0
STAT bytes 4717345 —— 当前所用存储大小
STAT curr_items 5654
STAT total_items 58461
STAT expired_unfetched 17
STAT evicted_unfetched 0
STAT evictions 0
STAT reclaimed 49
END
以上数据的命中率:2286284/2363348 = 96.7% 说明当前命中率是比较高的。
如果你要清空现有数据,可以使用下面的命令:
1 | stats reset |
要退出 telnet,输入组合键 Ctrl+] 出现
telnet>
输入 quit 即可退出。
1.关闭Memcached
直接使用 kill 进程ID 即可,比如上面信息显示的进程ID为20439,那就使用 kill 20439
2.重新启动Memcached,并且修改内存等参数,样例如下(修改最大内存为 1024M,最大连接数为 4000):
1 | memcached -d -m 1024 -u root -l 127.0.0.1 -p 11211 -c 4000 -P /tmp/memcached.pid 11211 |
更详细的有些参数介绍如下:
-p 监听的端口
-l 连接的IP地址, 默认是本机
-d start 启动memcached服务
-d restart 重起memcached服务
-d stop|shutdown 关闭正在运行的memcached服务
-d install 安装memcached服务
-d uninstall 卸载memcached服务
-u 以的身份运行 (仅在以root运行的时候有效)
-m 最大内存使用,单位MB。默认64MB
-M 内存耗尽时返回错误,而不是删除项
-c 最大同时连接数,默认是1024
-f 块大小增长因子,默认是1.25
-n 最小分配空间,key+value+flags默认是48
-h 显示帮助