`

Memcached笔记——(一)安装&常规错误&监控

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

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


一、下载
1.Libevent
简单的说就是一个事件触发的网络库,Memcached离不开它。
wget http://cloud.github.com/downloads/libevent/libevent/libevent-2.0.17-stable.tar.gz

2.Memcached
今天的主角
wget http://memcached.googlecode.com/files/memcached-1.4.13.tar.gz

二、安装
1.Libevent
解压缩
tar zxvf libevent-2.0.17-stable.tar.gz

编译、安装
./configure --prefix=/usr && make && make install 

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

编译、安装
./configure --with-libevent=/usr/lib && make && make install

这里一定要指定libevent的路径,否则启动的时候就有找不到libevent的so文件的错误!
启动
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
kill -9 `cat /var/run/memcached.pid`  

是否正常?Telnet上去看看
telnet xxx.xxx.xxx.xxx 11211

然后输入
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               (数据)


输入
quit
退出。

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

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"


追加为系统服务:
chkconfig --add memcached
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下去找。
找到这个文件
whereis libevent-2.0.so.5

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

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)

定位
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


做个软连接
ln -s /usr/lib/libevent-2.0.so.5 /usr/lib64/libevent-2.0.so.5

再试试:
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地址配置。
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


常见错误:
引用
Warning: date(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone 'UTC' for now, but please set date.timezone to select your timezone. in /home/usr/local/apache.../memcache.php on line 726

在memcache.php顶端加上“date_default_timezone_set('Asia/Hong_Kong');”即可,具体地域设置参考:http://www.php.net/manual/zh/datetime.configuration.php#ini.date.timezone

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




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

相关链接:
Memcached笔记——(一)安装&常规错误&监控
Memcached笔记——(二)XMemcached&Spring集成
Memcached笔记——(三)Memcached使用总结
Memcached笔记——(四)应对高并发攻击
  • 大小: 8.3 KB
  • 大小: 62.1 KB
分享到:
评论
6 楼 Zorla 2016-06-03  
难得的好文章
5 楼 Zorla 2016-06-03  
楼主功力深厚,在下佩服!
4 楼 wzf7065 2014-08-06  
mark,再慢慢看,楼主好文章
3 楼 songtaoying 2014-05-06  
非常不错。按照您的步聚做成功了
2 楼 sunshine_bean 2014-04-30  
好文章,谢谢
1 楼 di1984HIT 2014-04-14  
写的真好,学习了

相关推荐

    memcached监控模板

    Zabbix,一个强大的网络监控工具,提供了低级别发现(LLD)功能,可以自动发现并配置memcached服务的监控项。本文将深入探讨如何利用Zabbix的LLD来监控memcached。 ### 1. memcached简介 Memcached是一个高性能、...

    监控memcached运行情况

    标题中的“监控memcached运行情况”指的是在IT环境中,如何管理和跟踪Memcached缓存服务的性能和状态。Memcached是一款广泛使用的开源分布式内存对象缓存系统,它能提高Web应用程序的响应速度,通过将数据存储在内存...

    memcached-笔记资料

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

    memcached安装软件 libevent magent memcached

    安装magent可以帮助我们更好地管理和监控memcached服务的状态,包括查看缓存统计、设置内存限制等。安装过程类似: 1. 解压magent:`tar -zxvf magent.tar.gz` 2. 进入解压后的目录:`cd magent` 3. 编译和安装:`...

    memcached安装错误解决文件

    本篇文章将针对“memcached安装错误”这一主题,详细解析可能出现的问题及解决方案。 首先,msvcr71.dll是一个微软Visual C++运行库文件,对于某些基于VC++编译的程序(包括memcached)来说是必不可少的。如果你在...

    php-memcached-3.1.3.tar.gz

    安装php-memcached扩展 https://github.com/php-memcached-dev/php-memcached tar -zxvf php-memcached-3.1.3.tar.gz && cd /root/php-memcached-3.1.3 && /usr/local/php7/bin/phpize && ./configure --with-...

    memcached之客户端memadmin安装

    "memcached之客户端memadmin安装" 这个标题涉及到的是关于`memcached`的一个客户端工具——`memadmin`的安装过程。`memcached`是一种高性能的分布式内存对象缓存系统,常用于减轻数据库负载,提高Web应用性能。而`...

    memcached部署监控培训文档基于java

    公司要求组织一个基于Java的memcached培训,整理了这个文档。里面有4个文件,包括memcached部署,memcached培训,监控工具memcache-top安装和daemontools安装。文档是基于word2013的,打不开的话,右键--属性--解锁

    memcached_1.4.13(win64&32)_client2.12

    在Windows环境下,通过提供的可执行文件,我们可以方便地安装和管理memcached服务,这对于那些依赖于Windows服务器的开发者来说是一个福音。服务端支持多线程处理和TCP/IP通信协议,可以跨网络快速地存储和检索数据...

    Memcached 统计与监控

    ### Memcached统计与监控 #### 一、Memcached简介 Memcached是一款高性能的分布式内存对象缓存系统,通过减轻数据库负载来加速动态Web应用,提高网站的浏览速度。其通过在内存里维护一个统一的大型缓存,允许...

    PHP安装memcached

    - `./configure --prefix=/usr/local/libmemcached --with-memcached=/usr/local/memcached/bin/memcached`:配置编译参数,指定安装路径为`/usr/local/libmemcached`,并指定了`memcached`的路径。 - `make && ...

    memcached安装及java应用使用memcached

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

    memcached32位&64位

    -d install 安装memcached服务 -d uninstall 卸载memcached服务 -u 以的身份运行 (仅在以root运行的时候有效) -m 最大内存使用,单位MB。默认64MB -M 内存耗尽时返回错误,而不是删除项 -c 最大同时连接数,默认是...

    memcached安装

    **一、安装memcached服务** 1. **下载memcached服务**:首先,你需要从官方网站或可靠的第三方源下载适用于Windows的memcached服务。确保选择与你的操作系统架构匹配的版本,通常是32位或64位。 2. **安装服务**:...

    memcached 安装教程

    在安装完成后尝试启动 memcached,可能会遇到找不到 libevent 库的错误,如: ``` memcached: error while loading shared libraries: libevent-1.3b.so.1: cannot open shared object file: No such file or ...

    Memcached进程监控

    在这个"Memcached进程监控"项目中,我们有一个winform版的监控程序,其主要功能是确保Memcached服务的稳定运行。 该程序的核心功能包括: 1. **进程监控**:监控Memcached服务的运行状态,实时检测进程是否存活。...

Global site tag (gtag.js) - Google Analytics