`
beyond429
  • 浏览: 96103 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Memcached学习——(一)

    博客分类:
  • java
阅读更多

原文地址: http://snowolf.iteye.com/blog/1447348

 

08年的时候接触过Memcached,当时还对它的客户端产品嗤之以鼻,毕竟手工代码没有各种ORM原生XML配置方便。尽管如此,Memcached现在已经成了服务器架构里不可或缺的一部分! 

相关链接: 
Memcached笔记——(一)安装&常规错误&监控 
Memcached笔记——(二)XMemcached&Spring集成 
Memcached笔记——(三)Memcached使用总结 
Memcached笔记——(四)应对高并发攻击 


一、下载 
1.Libevent 
简单的说就是一个事件触发的网络库,Memcached离不开它。 

Shell代码  收藏代码
  1. wget http://cloud.github.com/downloads/libevent/libevent/libevent-2.0.17-stable.tar.gz  

2.Memcached 
今天的主角 
Shell代码  收藏代码
  1. wget http://memcached.googlecode.com/files/memcached-1.4.13.tar.gz  

二、安装 
1.Libevent 
解压缩 
Shell代码  收藏代码
  1. tar zxvf libevent-2.0.17-stable.tar.gz  

编译、安装 
Shell代码  收藏代码
  1. ./configure --prefix=/usr && make && make install   

这里一定要注意指定--prefix,后面配置memcached的时候就有必要用到。 
2.Memcached 
解压 
Shell代码  收藏代码
  1. tar zxvf memcached-1.4.13.tar.gz  

编译、安装 
Shell代码  收藏代码
  1. ./configure --with-libevent=/usr/lib && make && make install  

这里一定要指定libevent的路径,否则启动的时候就有找不到libevent的so文件的错误! 
启动 
Shell代码  收藏代码
  1. memcached -d -m 512 -p 11211 -u root -c 256 -P /var/run/memcached.pid  

参数 
引用

-p <num>      TCP port number to listen on (default: 11211) 
-U <num>      UDP port number to listen on (default: 11211, 0 is off) 
-l <addr>     interface to listen on (default: INADDR_ANY, all addresses) 
              <addr> may be specified as host:port. If you don't specify 
              a port number, the value you specified with -p or -U is 
              used. You may specify multiple addresses separated by comma 
              or by using -l multiple times 
-d            run as a daemon 
-u <username> assume identity of <username> (only when run as root) 
-m <num>      max memory to use for items in megabytes (default: 64 MB) 
-M            return error on memory exhausted (rather than removing items) 
-c <num>      max simultaneous connections (default: 1024) 
-v            verbose (print errors/warnings while in event loop) 
-P <file>     save PID in <file>, only used with -d option 

要关掉memcached 
Shell代码  收藏代码
  1. kill -9 `cat /var/run/memcached.pid`    

是否正常?Telnet上去看看 
Shell代码  收藏代码
  1. telnet xxx.xxx.xxx.xxx 11211  

然后输入
Shell代码  收藏代码
  1. stats  

接着就能看到: 
引用

STAT pid 3021 
STAT uptime 3621 
STAT time 1331261509 
STAT version 1.4.13 
STAT libevent 2.0.17-stable 
STAT pointer_size 64 
STAT rusage_user 0.000000 
STAT rusage_system 0.000999 
STAT curr_connections 6 
STAT total_connections 7 
STAT connection_structures 7 
STAT reserved_fds 20 
STAT cmd_get 0 
STAT cmd_set 0 
STAT cmd_flush 0 
STAT cmd_touch 0 
STAT get_hits 0 
STAT get_misses 0 
STAT delete_misses 0 
STAT delete_hits 0 
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 72 
STAT bytes_written 1038 
STAT limit_maxbytes 52428800 
STAT accepting_conns 1 
STAT listen_disabled_num 0 
STAT threads 4 
STAT conn_yields 0 
STAT hash_power_level 16 
STAT hash_bytes 524288 
STAT hash_is_expanding 0 
STAT expired_unfetched 0 
STAT evicted_unfetched 0 
STAT bytes 0 
STAT curr_items 0 
STAT total_items 0 
STAT evictions 0 
STAT reclaimed 0 
END 

上面状况说明Memcached服务正常。 
还可以试试get、set、delete、replace 
引用
set foo 0 0 3     (保存命令) 
bar               (数据) 
STORED            (结果) 
get foo           (取得命令) 
VALUE foo 0 3     (数据) 
bar               (数据)


输入
Shell代码  收藏代码
  1. quit  
退出。 

三、系统服务 
参照Nginx的系统服务,自己写了一个Memcached的系统服务脚本。 
先构建/etc/init.d/memcahed这个文件,然后赋予其可执行权限: 
Shell代码  收藏代码
  1. touch /etc/init.d/memcached  
  2. chmod +x /etc/init.d/memcached  

memcached脚本如下: 
Shell代码  收藏代码
  1. #!/bin/bash  
  2. # v.0.0.1  
  3. # create by snowolf at 2012.5.25  
  4. #  
  5. # memcached  - This shell script takes care of starting and stopping memcached.  
  6. #  
  7. # chkconfig: - 90 10  
  8. # description: Memcache provides fast memory based storage.  
  9. # processname: memcached  
  10.   
  11. memcached_path="/usr/local/bin/memcached"  
  12. memcached_pid="/var/run/memcached.pid"  
  13. memcached_memory="1024"  
  14.   
  15. # Source function library.  
  16. . /etc/rc.d/init.d/functions  
  17.   
  18. [ -x $memcached_path ] || exit 0  
  19.   
  20. RETVAL=0  
  21. prog="memcached"  
  22.   
  23. # Start daemons.  
  24. start() {  
  25.     if [ -e $memcached_pid -a ! -z $memcached_pid ];then  
  26.         echo $prog" already running...."  
  27.         exit 1  
  28.     fi  
  29.   
  30.     echo -n $"Starting $prog "  
  31.     # Single instance for all caches  
  32.     $memcached_path -m $memcached_memory -l 0.0.0.0 -p 11211 -u root -d -P $memcached_pid  
  33.     RETVAL=$?  
  34.     [ $RETVAL -eq 0 ] && {  
  35.         touch /var/lock/subsys/$prog  
  36.         success $"$prog"  
  37.     }  
  38.     echo  
  39.     return $RETVAL  
  40. }  
  41.   
  42.   
  43. # Stop daemons.  
  44. stop() {  
  45.     echo -n $"Stopping $prog "  
  46.     killproc -d 10 $memcached_path  
  47.     echo  
  48.     [ $RETVAL = 0 ] && rm -f $memcached_pid /var/lock/subsys/$prog  
  49.   
  50.     RETVAL=$?  
  51.     return $RETVAL  
  52. }  
  53.   
  54. # See how we were called.  
  55. case "$1" in  
  56.         start)  
  57.             start  
  58.             ;;  
  59.         stop)  
  60.             stop  
  61.             ;;  
  62.         status)  
  63.             status $prog  
  64.             RETVAL=$?  
  65.             ;;  
  66.         restart)  
  67.             stop  
  68.             start  
  69.             ;;  
  70.         *)  
  71.             echo $"Usage: $0 {start|stop|status|restart}"  
  72.             exit 1  
  73. esac  
  74. exit $RETVAL  

注意这几行配置,请根据实际情况配置memcached执行文件路径,以及Memcached使用内存大小: 
引用
memcached_path="/usr/local/bin/memcached" 
memcached_memory="1024"


追加为系统服务: 
Shell代码  收藏代码
  1. chkconfig --add memcached  
  2. chkconfig memcached on  


然后就可以通过service memcached start|stop|status|restart控制memcached了! 

四、常规错误 
一开始没有指定libevent路径安装memcached的时候,启动memcached就报这个错误: 
引用
memcached: error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory 

其实这个文件就在/usr/lib下。错就错在Linux是64bit系统,如果没有指定libevent路径,memcached就会去/usr/lib64下去找。 
找到这个文件 
Shell代码  收藏代码
  1. whereis libevent-2.0.so.5  

引用
libevent-2.0.so: /usr/lib/libevent-2.0.so.5

Shell代码  收藏代码
  1. ldd /usr/local/bin/memcached  

提示找不到libevent-2.0.so.5 
引用
        linux-vdso.so.1 =>  (0x00007fff41dfd000) 
        libevent-2.0.so.5 => not found 
        librt.so.1 => /lib64/librt.so.1 (0x0000003c94a00000) 
        libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003c93a00000) 
        libc.so.6 => /lib64/libc.so.6 (0x0000003c92e00000) 
        /lib64/ld-linux-x86-64.so.2 (0x0000003c92a00000)

定位 
Shell代码  收藏代码
  1. LD_DEBUG=libs /usr/local/bin/memcached -v  

引用
     19905:     find library=libevent-2.0.so.5 [0]; searching 
     19905:      search path=/usr/lib/lib/tls/x86_64:/usr/lib/lib/tls:/usr/lib/lib/x86_64:/usr/lib/lib          (RPATH from file /usr/local/bin/memcached) 
     19905:       trying file=/usr/lib/lib/tls/x86_64/libevent-2.0.so.5 
     19905:       trying file=/usr/lib/lib/tls/libevent-2.0.so.5 
     19905:       trying file=/usr/lib/lib/x86_64/libevent-2.0.so.5 
     19905:       trying file=/usr/lib/lib/libevent-2.0.so.5 
     19905:      search cache=/etc/ld.so.cache 
     19905:      search path=/lib64/tls/x86_64:/lib64/tls:/lib64/x86_64:/lib64:/usr/lib64/tls/x86_64:/usr/lib64/tls:/usr/lib64/x86_64:/usr/lib64            (system search path) 
     19905:       trying file=/lib64/tls/x86_64/libevent-2.0.so.5 
     19905:       trying file=/lib64/tls/libevent-2.0.so.5 
     19905:       trying file=/lib64/x86_64/libevent-2.0.so.5 
     19905:       trying file=/lib64/libevent-2.0.so.5 
     19905:       trying file=/usr/lib64/tls/x86_64/libevent-2.0.so.5 
     19905:       trying file=/usr/lib64/tls/libevent-2.0.so.5 
     19905:       trying file=/usr/lib64/x86_64/libevent-2.0.so.5 
     19905:       trying file=/usr/lib64/libevent-2.0.so.5 
     19905: 
/usr/local/bin/memcached: error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory 

注意这句: 
引用
19905: trying file=/usr/lib64/libevent-2.0.so.5


做个软连接 
Shell代码  收藏代码
  1. ln -s /usr/lib/libevent-2.0.so.5 /usr/lib64/libevent-2.0.so.5  

再试试: 
Shell代码  收藏代码
  1. ldd /usr/local/bin/memcached  

这回找到了! 
引用
        linux-vdso.so.1 =>  (0x00007fffffef6000) 
        libevent-2.0.so.5 => /usr/lib64/libevent-2.0.so.5 (0x00002b5608a26000) 
        librt.so.1 => /lib64/librt.so.1 (0x0000003c94a00000) 
        libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003c93a00000) 
        libc.so.6 => /lib64/libc.so.6 (0x0000003c92e00000) 
        /lib64/ld-linux-x86-64.so.2 (0x0000003c92a00000)


五、监控 
可以在服务器上配置一个PHP页面来监测Memcached的情况, 
下载MemcachePHP 



配置也比较简单,主要包括账户配置,以及Memcached Server地址配置。 
Php代码  收藏代码
  1. define('ADMIN_USERNAME','memcache');    // Admin Username  
  2. define('ADMIN_PASSWORD','password');    // Admin Password  
  3. define('DATE_FORMAT','Y/m/d H:i:s');  
  4. define('GRAPH_SIZE',200);  
  5. define('MAX_ITEM_DUMP',50);  
  6.   
  7. $MEMCACHE_SERVERS[] = 'mymemcache-server1:11211'// add more as an array  
  8. $MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'// add more as an array  

如果不方便搭建PHP服务,可以使用Perl脚本memcache-top 
修改@default_instances或使用--instances参数: 
Shell代码  收藏代码
  1. perl memcache-top-v0.6 --instances 10.11.155.26 10.11.155.41  


 

先到这里,后续做压力测试,Java客户端开发,Spring系统集成等。 
分享到:
评论

相关推荐

    memcached函数的学习程序

    《深入理解Memcached函数——基于D语言的实践与解析》 Memcached,作为一个高性能的分布式内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库负载,提高数据访问速度。本篇文章将围绕“memcached函数的学习...

    memcached-笔记资料

    【标题】"memcached-笔记资料"涉及到的核心知识点是分布式内存缓存系统——Memcached,它是一个高性能、轻量级的缓存解决方案,主要用于减轻数据库的负载,提高Web应用的性能。 【描述】"memcached-笔记资料"暗示了...

    memcached安装及java应用使用memcached

    “memcached安装及java应用使用memcached”这一标题暗示了我们要讨论的是一个关于分布式内存缓存系统——memcached的安装过程以及如何在Java应用程序中使用它。Memcached是一个高性能、轻量级的分布式内存对象缓存...

    hibernate-memcached-1.1.0-sources.zip

    《Hibernate与Memcached整合详解——基于hibernate-memcached-1.1.0源码分析》 在当今的Web开发领域,数据持久化是一个必不可少的环节,而Hibernate作为Java领域广泛使用的对象关系映射(ORM)框架,极大地简化了...

    memcached完全剖析ehcache memcached redis 缓存技术总结

    标题“memcached完全剖析ehcache memcached redis 缓存技术总结”表明,这篇内容将深入探讨三种流行的缓存技术——Memcached、Ehcache和Redis。缓存是IT行业中用于提高系统性能的关键技术,尤其是在大数据量和高并发...

    Java全能学习面试手册——Java面试题库.zip

    Java全能学习面试手册——Java面试题库.zip 01 7道消息队列ActiveMQ面试题!.pdf 02 10道Java高级必备的Netty面试题!.pdf 03 10道Java面试必备的设计模式面试题!.pdf 04 10个Java经典的List面试题!.pdf 05 10个...

    基于内存的K-V数据平台(Memcached)

    **基于内存的K-V数据平台——Memcached** Memcached是一款高性能、分布式内存对象缓存系统,主要用于加速动态Web应用,通过将数据存储在内存中,减少数据库的访问次数,从而提高应用性能。它是一个轻量级的服务,...

    memcached的学习过程

    前段时间,我们实验室的师姐过来给我们来讲了现在公司所有到的新技术———memcached,感觉很强大本来下来就要按着师姐的例子给走一遍呢,结果杂事太多给耽搁了。上次新浪网院的老师上课是也讲到了这个memcached,...

    java学习进阶之路,如果从一个菜鸟进阶成大神(csdn)————程序.pdf

    Java学习进阶是一个系统的过程,涉及多个层面的知识和技能。以下是一个详细的指南,帮助你从初学者逐步成长为Java开发的大神。 1. **编程基础** - **数据结构与算法**:这是所有程序员的基石。熟悉数组、链表、...

    SSM实战项目——Java高并发秒杀API,详细流程+学习笔记

    SSM实战项目——Java高并发秒杀API是一个深入学习Java后端开发的重要实践,它涵盖了Spring、SpringMVC和MyBatis三大框架的整合应用,以及如何处理高并发下的秒杀场景。在这个项目中,我们将深入理解如何设计并实现一...

    Java全能学习面试手册——Java架构师进阶资料面试资料.zip

    Java全能学习面试手册——Java架构师进阶资料面试资料.zip 01 7道消息队列ActiveMQ面试题!.pdf 02 10道Java高级必备的Netty面试题!.pdf 03 10道Java面试必备的设计模式面试题!.pdf 04 10个Java经典的List面试题!...

    【MyBatis学习笔记八】——MyBatis缓存.zip

    2. 分布式环境:在分布式环境中,单纯依赖MyBatis的二级缓存可能无法满足需求,此时可以结合Redis、Memcached等分布式缓存工具来实现更高效的缓存策略。 3. 缓存穿透:防止大量不存在的查询请求导致缓存被击穿,可以...

    PHP实例开发源码——QQ空间说说自动抢一楼源码.zip

    【PHP实例开发源码——QQ空间说说自动抢一楼源码】 PHP是一种广泛使用的开源脚本语言,尤其在Web开发领域中占据着重要的地位。这个实例源码是关于如何使用PHP编写一个程序,以实现自动在QQ空间的说说下面抢到第一条...

    PHP实例开发源码——BMForum Myna PHP论坛程序.zip

    【标题】"PHP实例开发源码——BMForum Myna PHP论坛程序" 提供了一个深入了解PHP编程和论坛系统构建的机会。BMForum Myna是一款基于PHP语言的开源论坛软件,旨在为用户搭建互动性强、功能丰富的社区平台。通过研究其...

    PHP实例开发源码——php熊海个人网站.zip

    【PHP实例开发源码——php熊海个人网站.zip】是一个包含PHP编程语言实际应用的源代码包,由知名开发者“php熊海”创建。这个压缩文件可能是他的个人网站的源代码,供学习者研究和参考,以理解PHP在构建动态网站中的...

    Linux的Web程序设计——PHP网站开发.rar

    在IT领域,Linux系统常被用于构建...通过"Linux的Web程序设计——PHP网站开发"的学习,你可以掌握从零开始构建一个完整的PHP Web应用的能力,从服务器配置、数据库设计到代码编写、安全防护,全面提升你的IT专业技能。

    up_795359_phpMemcachedAdmin_das0oj.rar

    【标题】"up_795359_phpMemcachedAdmin_das0oj.rar" 提供的是一个基于PHP实现的Memcached管理工具——phpMemcachedAdmin。这个工具为用户提供了图形化界面,使得管理和监控Memcached服务器变得更加直观和便捷。 ...

    永恒论坛2.0源码——做论坛参考

    永恒论坛2.0源码为开发者提供了一个很好的学习和参考平台,帮助他们快速理解和构建自己的论坛系统。这款论坛软件可能包含了用户注册登录、发帖回帖、版块管理、用户权限控制等一系列功能,是构建在线社区的基础。 ...

    ASP.NET源码——RedSoft多层分布式架构实例源码.zip

    总结来说,"ASP.NET源码——RedSoft多层分布式架构实例源码.zip"是一个宝贵的教育资源,它涵盖了ASP.NET的基础和多层分布式架构的设计理念。通过深入学习和实践,开发者可以提升自己的技能,更好地应对大型、高性能...

    ASP.NET源码——[企业]商务维基网源码.zip

    8. **缓存策略**:为了提高性能,源码可能使用了ASP.NET内置的缓存机制,如Output Cache、HttpRuntime.Cache等,或者第三方解决方案如Redis、Memcached等。 9. **单元测试与持续集成**:高质量的企业源码往往伴随有...

Global site tag (gtag.js) - Google Analytics