为了账号安全,请及时绑定邮箱和手机立即绑定

memadmin php展示memcahe状态信息

标签:
PHP

memcache相关知识点总结

 1)memcahe是什么

  memcache是一款开源的、高性能高并发纯内存缓存服务软件,C/S B/S架构


 2)memcache的作用

  memcache通过事先规划好的内存空间,临时缓存数据库数据,减少业务对数据库的直接高并发访问,达到提升数据库的访问性能,加速网站集群动态应用服务的能力


 3)常见缓存软件

   a. expires web配置浏览器端缓存,静态图片、JS、CSS、HTML等

   b. memcache 纯内存型,后端数据库中的数据,博文、用户信息等

   c. memcached 内存加磁盘,sina利用memcache+BDB

   d. rdis 内存加磁盘,持久化存储


 4)memcache在企业架构总应用场景

   a.完整缓存(静态缓存),如网站中商品分类信息纯静态内容

   b.热点缓存(配合前端web缓存访问频率较高的内容,还要配合数据库进行不定时更新)

   c.作为集群seesion会话共享存储


 5)memcache分布式集群

   memcache集群和web集群不太一样,所有memecache数据总和<=数据库总和

  

  a.程序端实现:程序加载所有mc的IP列表,通过对key做hash(一致性哈希)

   举个列子,假设有3个客户端1, 2, 3,3台memcached A, B, C:

 Client 1想把数据"barbaz"以key "foo"存储。Client 1首先参考节点列表(A, B, C),计算key "foo"的哈希值,假设memcached B被选中。接着,Client 1直接connect到memcached B,通过key "foo"把数据"barbaz"存储进去。Client 2使用与Client 1相同的客户端库(意味着阶段一的哈希算法相同),也拥有同样的memcached列表(A, B, C)。

 于是,经过相同的哈希计算(阶段一),Client 2计算出key "foo"在memcached B上,然后它直接请求memcached B,得到数据"barbaz"

  b.负载均衡:通过对key做hash


 6)memcache内存管理机制原理

   a.Mc早期使用的内存管理机制为malloc,malloc容易产生内存碎片,导致系统整体性能下降

   b.现在都是使用的Slab机制来管理和分配内存

   c.memcache提前将内存分配为大小为1M的若干个Slab,然后再对每个slab进行小对象的填充chunk,用于缓存真实的数据

   d.将大小相同的chunk组合成slab calss组,避免大量重复的初始化和清理,可以重复利用


 7)memcache删除机制

   a.不主动检测item对象是否过期,而是在get时才会检查item对象是否过期以及是否应该删除(懒惰删除对象机制)

   b.当删除对象是,一般不是反内存空间,而是作为标记删除,将指针放入slot回收插槽,下次分配的时候直接使用

   c.当内存空间满的时候,才会根据LRU算法把最近最少使用的item对象删除



memadmin展示memcache状态

1)memadmin

MemAdmin是一款开源、可视化的Memcached管理与监控工具

下载地址:http://www.junopen.com/memadmin/

2)部署

基于LNMP或者LAMP环境,将软件解压到站点目录即可

[root@web01 www]# tar xf memadmin-1.0.12.tar.gz

[root@web01 www]# cd memadmin

[root@web01 memadmin]# ll

总用量 36

drwxrwxrwx. 2 root root 4096 6月  19 2013 apps

-rwxrwxrwx. 1 root root 1214 6月  19 2013 config.php

drwxrwxrwx. 2 root root 4096 6月  19 2013 images

drwxrwxrwx. 6 root root 4096 6月  19 2013 include

-rwxrwxrwx. 1 root root  184 6月  19 2013 index.php

drwxrwxrwx. 2 root root 4096 6月  19 2013 langs

-rwxrwxrwx. 1 root root 1489 6月  19 2013 LICENSE.txt

-rwxrwxrwx. 1 root root 1118 6月  19 2013 README.txt

drwxrwxrwx. 2 root root 4096 6月  19 2013 views



3)登陆、初始账户和密码都为admin


4)添加memcache主机

5)查看各种memcache统计或者设置信息


6)监控命中



  监控memcache状态脚本实现

#!/bin/sh

#ip=$1

#port=$2

check_mem(){

    printf "set key1 0 0 4\r\ntest\r\n"|nc $1 $2

    if [ `printf "get key1\r\n"|nc $1 $2|wc -l` -gt 1 ];then

       echo "memcache $1 $2 ok..."

       hit=`printf "stats\r\n"|nc $1 $2|awk 'NR==14 {print $3}'`

       miss=`printf "stats\r\n"|nc $1 $2|awk 'NR==15 {print $3}'`

       echo "The hit rate is `echo "${hit} ${miss}"|awk

       '{print $1/($1+$2)*100}'`%"   

    else

       echo "memcache $1 $2 error..."

    fi

}

main(){

     [ $# -ne 2 ]&&echo "USAGE:$0 memcacheip memcacheport"&&exit 1

     check_mem $1 $2

}

main $1 $2

[root@db02 shell]# sh shell_14.sh 10.0.0.105 11211

STORED

memcache 10.0.0.105 11211 ok...

The hit rate is 92.1875%

[root@db02 shell]# sh shell_14.sh 10.0.0.105 11212

memcache 10.0.0.105 11212 error...

 


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消