Linux下配置Memcache服务
memcached:http://memcached.org/
libevent:http://libevent.org/
#下载包
cd /opt
wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz
wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz
#安装libevent
tar zxvf libevent-2.0.21-stable.tar.gz
cd libevent-2.0.21-stable
./configure --prefix=/opt/libevent
make
make install
#测试
ls -al /opt/libevent/lib | grep libevent
#安装memcached
tar zxvf memcached-1.4.15.tar.gz
cd memcached-1.4.15
./configure --prefix=/opt/memcached --with-libevent=/opt/libevent/
make
make install
#测试
ls -al /opt/mem*
#启动
/opt/memcached/bin/memcached -d -u root -m 512 127.0.0.1 -p 11211
#查看memcache的进程号
ps -ef | grep memcached
#多线程
在安装的时候必须打开:./configure --enable-threads
安装完之后,启动的时候看看帮助信息有没有这条:
-t <num> number of threads to use, default 4
如果存在该选项,说明已经支持了线程,就可以在启动的时候使用 -t 选项来启动多线程
然后启动的时候必须加上你需要支持的线程数量:
/opt/memcached/bin/memcache/bin/memcached -t 1024
#memcached命令的参数
/opt/memcached/bin/memcached -d -u root -m 512 127.0.0.1 -p 11211
/opt/memcached/bin/memcached -d -m 2000 -u root -l 192.168.210.159 -p 11211 -c 1000 -P /tmp/memcached.pid
相关解释如下:
-d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,这里是2000MB
-u是运行Memcache的用户,如果当前为 root 的话,需要使用此参数指定用户。
-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.1.91
-p是设置Memcache监听的端口,我这里设置了12301,最好是1024以上的端口
-c选项是最大运行的并发连接数,默认是1024,这里设置了1000
-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid
#停止Memcache进程
# kill `cat /tmp/memcached.pid`
也可以启动多个守护进程,但是端口不能重复
#-d参数
-d install 安装memcached
-d uninstall 卸载memcached
-d start 启动memcached服务
-d restart 重启memcached服务
-d stop 停止memcached服务
#查看启动的memcache服务
netstat -lp | grep memcached
#查看memcache的进程
ps -ef | grep memcached#启动memcache守护进程:
# /usr/local/bin/memcached -d -m 200 -u root -l 192.168.1.91 -p 12301 -c 1000 -P /tmp/memcached.pid
相关解释如下:
-d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,这里是200MB
-u是运行Memcache的用户,如果当前为 root 的话,需要使用此参数指定用户。
-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.1.91
-p是设置Memcache监听的端口,我这里设置了12301,最好是1024以上的端口
-c选项是最大运行的并发连接数,默认是1024,这里设置了256
-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid
可以同时启动多个守护进程,但是端口不能重复
#查看启动的memcache服务:
netstat -lp | grep memcached
#查看memcache的进程号:
ps -ef | grep memcached
#杀死memcache进程:
kill -9 进程id 或者 kill `cat /tmp/memcached.pid`
#查看memcache运行状态:
telnet host port => telnet 127.0.0.1 11211连接上memcache,然后直接输入stats就可以得到当前memcache的状态
如何查看memcache服务器端版本: ./memcached -h
memcache的运行状态可以方便的用 stats 命令显示。
首先用telnet 127.0.0.1 11211这样的命令连接上memcache,然后直接输入stats就可以得到当前memcache的状态。
这些状态的说明如下:
pid memcache服务器的进程ID
uptime 服务器已经运行的秒数
time 服务器当前的unix时间戳
version memcache版本
pointer_size 当前操作系统的指针大小(32位系统一般是32bit)
rusage_user 进程的累计用户时间
rusage_system 进程的累计系统时间
curr_items 服务器当前存储的items数量
total_items 从服务器启动以后存储的items总数量
bytes 当前服务器存储items占用的字节数
curr_connections 当前打开着的连接数
total_connections 从服务器启动以后曾经打开过的连接数
connection_structures 服务器分配的连接构造数
cmd_get get命令(获取)总请求次数
cmd_set set命令(保存)总请求次数
get_hits 总命中次数
get_misses 总未命中次数
evictions 为获取空闲内存而删除的items数(分配给memcache的空间用满后需要删除旧的items来得到空间分配给新的items)
bytes_read 总读取字节数(请求字节数)
bytes_written 总发送字节数(结果字节数)
limit_maxbytes 分配给memcache的内存大小(字节)
threads 当前线程数