- 浏览: 95724 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
grhglj:
能详细一点吗?都加到哪儿呀。
struts2.0中使用图形验证码 -
shingo7:
jotm哪来的2.3版
Spring引用Tomcat的 JTA事务 -
blogaaa:
这样配置完后,事务不能正常回滚,在同一个action中插入记录 ...
Spring引用Tomcat的 JTA事务
原文地址: http://snowolf.iteye.com/blog/1447348
08年的时候接触过Memcached,当时还对它的客户端产品嗤之以鼻,毕竟手工代码没有各种ORM原生XML配置方便。尽管如此,Memcached现在已经成了服务器架构里不可或缺的一部分!
相关链接:
Memcached笔记——(一)安装&常规错误&监控
Memcached笔记——(二)XMemcached&Spring集成
Memcached笔记——(三)Memcached使用总结
Memcached笔记——(四)应对高并发攻击
一、下载
1.Libevent
简单的说就是一个事件触发的网络库,Memcached离不开它。
2.Memcached
今天的主角
二、安装
1.Libevent
解压缩
编译、安装
这里一定要注意指定--prefix,后面配置memcached的时候就有必要用到。
2.Memcached
解压
编译、安装
这里一定要指定libevent的路径,否则启动的时候就有找不到libevent的so文件的错误!
启动
参数
引用
-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
是否正常?Telnet上去看看
然后输入
接着就能看到:
引用
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 (数据)
bar (数据)
STORED (结果)
get foo (取得命令)
VALUE foo 0 3 (数据)
bar (数据)
输入 退出。
三、系统服务
参照Nginx的系统服务,自己写了一个Memcached的系统服务脚本。
先构建/etc/init.d/memcahed这个文件,然后赋予其可执行权限:
memcached脚本如下:
- #!/bin/bash
- # v.0.0.1
- # create by snowolf at 2012.5.25
- #
- # memcached - This shell script takes care of starting and stopping memcached.
- #
- # chkconfig: - 90 10
- # description: Memcache provides fast memory based storage.
- # processname: memcached
- memcached_path="/usr/local/bin/memcached"
- memcached_pid="/var/run/memcached.pid"
- memcached_memory="1024"
- # Source function library.
- . /etc/rc.d/init.d/functions
- [ -x $memcached_path ] || exit 0
- RETVAL=0
- prog="memcached"
- # Start daemons.
- start() {
- if [ -e $memcached_pid -a ! -z $memcached_pid ];then
- echo $prog" already running...."
- exit 1
- fi
- echo -n $"Starting $prog "
- # Single instance for all caches
- $memcached_path -m $memcached_memory -l 0.0.0.0 -p 11211 -u root -d -P $memcached_pid
- RETVAL=$?
- [ $RETVAL -eq 0 ] && {
- touch /var/lock/subsys/$prog
- success $"$prog"
- }
- echo
- return $RETVAL
- }
- # Stop daemons.
- stop() {
- echo -n $"Stopping $prog "
- killproc -d 10 $memcached_path
- echo
- [ $RETVAL = 0 ] && rm -f $memcached_pid /var/lock/subsys/$prog
- RETVAL=$?
- return $RETVAL
- }
- # See how we were called.
- case "$1" in
- start)
- start
- ;;
- stop)
- stop
- ;;
- status)
- status $prog
- RETVAL=$?
- ;;
- restart)
- stop
- start
- ;;
- *)
- echo $"Usage: $0 {start|stop|status|restart}"
- exit 1
- esac
- exit $RETVAL
注意这几行配置,请根据实际情况配置memcached执行文件路径,以及Memcached使用内存大小:
引用
memcached_path="/usr/local/bin/memcached"
memcached_memory="1024"
memcached_memory="1024"
追加为系统服务:
然后就可以通过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下去找。
找到这个文件
引用
libevent-2.0.so: /usr/lib/libevent-2.0.so.5
提示找不到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)
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)
定位
引用
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: 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
做个软连接
再试试:
这回找到了!
引用
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)
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地址配置。
- define('ADMIN_USERNAME','memcache'); // Admin Username
- define('ADMIN_PASSWORD','password'); // Admin Password
- define('DATE_FORMAT','Y/m/d H:i:s');
- define('GRAPH_SIZE',200);
- define('MAX_ITEM_DUMP',50);
- $MEMCACHE_SERVERS[] = 'mymemcache-server1:11211'; // add more as an array
- $MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
如果不方便搭建PHP服务,可以使用Perl脚本memcache-top
修改@default_instances或使用--instances参数:
先到这里,后续做压力测试,Java客户端开发,Spring系统集成等。
发表评论
-
Drools与Spring集成 登录测试
2013-07-12 15:27 0转至: http://justsee.iteye.com/b ... -
Drools入门-----------环境搭建,分析Helloworld
2013-07-12 15:20 0转至: http://justsee.iteye.com/b ... -
H2学习
2013-07-12 15:11 0package test.h2; import ja ... -
BlockingQueue队列学习
2013-10-17 10:16 806package test; import java ... -
一个多线程计算器的实现
2013-07-12 14:56 0package test; import java.util ... -
JRobin Core学习
2012-12-04 14:29 4141原文地址: http://www.micmiu.com/ent ... -
Memcached学习——(四)
2012-11-28 17:11 0原文地址: http://snowolf.iteye.com/ ... -
Memcached学习——(三)
2012-11-28 17:10 0原文地址: http://snowolf ... -
Memcached学习——(二)
2012-11-28 17:08 1007原文地址: http://snowolf.iteye.com/ ... -
redis学习
2012-11-28 17:03 968原文地址:http://snowolf.iteye.com/b ... -
基于Spring可扩展Schema提供自定义配置支持(spring配置文件中 配置标签支持)
2012-11-28 16:55 830原文地址:http://www.cnblogs.com/jif ... -
JAI处理TIFF格式图片
2012-09-17 17:48 13330懒得多说,直接代码了。。。。 import java.awt. ... -
全面掌握Java的异常处理机制
2009-03-05 17:17 1032你觉得自己是一个Java专 ... -
java.lang包概述
2009-03-05 17:02 133464.1. 接口 java.lang.Appendab ... -
select下拉列表动态显示选择公司及部门信息——级联
2008-11-25 12:29 1329//=================公司类方法======= ... -
人民币大小写转
2008-11-25 12:26 1153String HanDigiStr[] = new Strin ... -
身份证号转换15位与18位
2008-11-25 12:24 1631//开始 15位到18位的身份证号转换 //身份证号码由 ... -
使ApplicationResources.properties支持中文
2008-11-25 12:15 1338使ApplicationResources.propertie ... -
利用XMLBean轻轻松松读写XML
2008-11-25 12:11 969一、关于XML解析 XML在Java应用程序里变得越来越 ... -
JAVA获得网卡MAC地址
2008-11-25 12:06 1148package test; import java.io.B ...
相关推荐
《深入理解Memcached函数——基于D语言的实践与解析》 Memcached,作为一个高性能的分布式内存对象缓存系统,广泛应用于Web应用中,用于减轻数据库负载,提高数据访问速度。本篇文章将围绕“memcached函数的学习...
【标题】"memcached-笔记资料"涉及到的核心知识点是分布式内存缓存系统——Memcached,它是一个高性能、轻量级的缓存解决方案,主要用于减轻数据库的负载,提高Web应用的性能。 【描述】"memcached-笔记资料"暗示了...
“memcached安装及java应用使用memcached”这一标题暗示了我们要讨论的是一个关于分布式内存缓存系统——memcached的安装过程以及如何在Java应用程序中使用它。Memcached是一个高性能、轻量级的分布式内存对象缓存...
《Hibernate与Memcached整合详解——基于hibernate-memcached-1.1.0源码分析》 在当今的Web开发领域,数据持久化是一个必不可少的环节,而Hibernate作为Java领域广泛使用的对象关系映射(ORM)框架,极大地简化了...
标题“memcached完全剖析ehcache memcached redis 缓存技术总结”表明,这篇内容将深入探讨三种流行的缓存技术——Memcached、Ehcache和Redis。缓存是IT行业中用于提高系统性能的关键技术,尤其是在大数据量和高并发...
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** Memcached是一款高性能、分布式内存对象缓存系统,主要用于加速动态Web应用,通过将数据存储在内存中,减少数据库的访问次数,从而提高应用性能。它是一个轻量级的服务,...
前段时间,我们实验室的师姐过来给我们来讲了现在公司所有到的新技术———memcached,感觉很强大本来下来就要按着师姐的例子给走一遍呢,结果杂事太多给耽搁了。上次新浪网院的老师上课是也讲到了这个memcached,...
Java学习进阶是一个系统的过程,涉及多个层面的知识和技能。以下是一个详细的指南,帮助你从初学者逐步成长为Java开发的大神。 1. **编程基础** - **数据结构与算法**:这是所有程序员的基石。熟悉数组、链表、...
SSM实战项目——Java高并发秒杀API是一个深入学习Java后端开发的重要实践,它涵盖了Spring、SpringMVC和MyBatis三大框架的整合应用,以及如何处理高并发下的秒杀场景。在这个项目中,我们将深入理解如何设计并实现一...
Java全能学习面试手册——Java架构师进阶资料面试资料.zip 01 7道消息队列ActiveMQ面试题!.pdf 02 10道Java高级必备的Netty面试题!.pdf 03 10道Java面试必备的设计模式面试题!.pdf 04 10个Java经典的List面试题!...
2. 分布式环境:在分布式环境中,单纯依赖MyBatis的二级缓存可能无法满足需求,此时可以结合Redis、Memcached等分布式缓存工具来实现更高效的缓存策略。 3. 缓存穿透:防止大量不存在的查询请求导致缓存被击穿,可以...
【PHP实例开发源码——QQ空间说说自动抢一楼源码】 PHP是一种广泛使用的开源脚本语言,尤其在Web开发领域中占据着重要的地位。这个实例源码是关于如何使用PHP编写一个程序,以实现自动在QQ空间的说说下面抢到第一条...
【标题】"PHP实例开发源码——BMForum Myna PHP论坛程序" 提供了一个深入了解PHP编程和论坛系统构建的机会。BMForum Myna是一款基于PHP语言的开源论坛软件,旨在为用户搭建互动性强、功能丰富的社区平台。通过研究其...
【PHP实例开发源码——php熊海个人网站.zip】是一个包含PHP编程语言实际应用的源代码包,由知名开发者“php熊海”创建。这个压缩文件可能是他的个人网站的源代码,供学习者研究和参考,以理解PHP在构建动态网站中的...
在IT领域,Linux系统常被用于构建...通过"Linux的Web程序设计——PHP网站开发"的学习,你可以掌握从零开始构建一个完整的PHP Web应用的能力,从服务器配置、数据库设计到代码编写、安全防护,全面提升你的IT专业技能。
【标题】"up_795359_phpMemcachedAdmin_das0oj.rar" 提供的是一个基于PHP实现的Memcached管理工具——phpMemcachedAdmin。这个工具为用户提供了图形化界面,使得管理和监控Memcached服务器变得更加直观和便捷。 ...
永恒论坛2.0源码为开发者提供了一个很好的学习和参考平台,帮助他们快速理解和构建自己的论坛系统。这款论坛软件可能包含了用户注册登录、发帖回帖、版块管理、用户权限控制等一系列功能,是构建在线社区的基础。 ...
总结来说,"ASP.NET源码——RedSoft多层分布式架构实例源码.zip"是一个宝贵的教育资源,它涵盖了ASP.NET的基础和多层分布式架构的设计理念。通过深入学习和实践,开发者可以提升自己的技能,更好地应对大型、高性能...
8. **缓存策略**:为了提高性能,源码可能使用了ASP.NET内置的缓存机制,如Output Cache、HttpRuntime.Cache等,或者第三方解决方案如Redis、Memcached等。 9. **单元测试与持续集成**:高质量的企业源码往往伴随有...