在192.168.80.100要联网
关闭防火墙及SElinux
systemctl stop firewalld //关闭防火墙
setenforce 0 //关闭监控
memcached服务器:
上传源码包和插件包:
yum install lrz* -y
把 memcached-1.5.6.tar.gz
libevent-2.1.8-stable.tar.gz 软件包拉入
解压
tar xf memcached-1.5.6.tar.gz -C /opt/
tar xf libevent-2.1.8-stable.tar.gz -C /opt/
cd /opt/libevent-2.1.8-stable
yum install gcc gcc-c++ make -y
./configure \
--prefix=/usr/local/libevent
make && make install
安装memcached:
cd /opt/memcached-1.5.6
./configure \
--prefix=/usr/local/memcached \
--with-libevent=/usr/local/libevent/
make && make install
ln -s /usr/local/libevent/lib/libevent-2.1.so.6.0.2 /usr/lib64/libevent-2.1.so.6 //软链接 不可缺少
cd /usr/local/memcached/bin/
./memcached -d -m 32m -p 11211 -u root //以守护进程的方式分配32MB内存指定端口指定用户账号位root运行Memcached服务
以上选项说明如下:
-p:使用的tcp端口,默认为11211
-m:最大内存大小,默认为64M
-vv:以very vrebose模式启动,将调试信息和错误输出到控制台
-d:作为守护进程的后台运行
-c:最大运行的并发连接数,默认是1024,一般按照服务器的负载量来设置
-P:设置保存Memcached的pid文件
-l:监听的服务器IP地址,若有多个地址
-u:运行Memcached的用户,默认不能用root启动,若使用需要-u来指定root用户
设置Memcached 服务脚本:
vi /etc/init.d/memcached
#!/bin/bash
# chkconfig: 35 99 20
# description: memcached Service Control Script
PROG="/usr/local/memcached/bin/memcached"
case "$1" in
start)
$PROG -d -m 32 -p 11211 -u root
;;
stop)
pkill -9 memcached &> /dev/null
;;
restart)
$0 stop
$0 start
;;
*)
echo "Usage: $0 {start|stop|restart}"
exit 1
esac
exit 0
chmod +x /etc/init.d/memcached //添加运行权限
chkconfig --add memcached //添加到service管理器
service memcached start //启动
netstat -anpt | grep memcached
yum install -y telnet //安装telnet
telnet 127.0.0.1 11211 //连接登录
set userid 0 0 5 //不进行压缩和序列化标识 数据过期时间为永不过期 标识号是5就需要输入5位数。
12345 //输入数据以 . 结束。
get userid //获取数据
stats //显示状态信息
quit //退出
键值对语法如下:
command <key> <flags> <expiration time> <bytes>
<value>
memcached修改命令参数
参数 用法
key key用于查找缓存值
flags 可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息
expiration time 在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes 在缓存中存储的字节点
value 存储的值(始终位于第二行)
memcached基本操作命令
1.set
set命令用于向缓存添加新的键值对,如果已经存在,则之前的值将被替换,响应STORED
2.add
当缓存中不存在键时,add命令才会向缓存中添加一个键值对,如果缓存中已经存在该键,则之前的值将仍将保持不变,并返回响应NOT_STORED
3.append user 0 0 4 //键值后追加4个字节
4.prepend username 0 0 2 //键值前追加2个字节
5.replace
仅当键已经存在时,replace命令才会替换缓存中的键,如果缓存中不存在该键,则返回响应NOT_STORED
6.get
用于检索与之前添加的键值对相关的值
7.delete
用于删除memcached中的任何现有值,将使用一个键调用delete,如果该键存在于缓存中,则删除该值。如果不存在,则返回一条NOT_FOUND消息。
8.stats
转储所连接的 memcached 实例的当前统计数据。
9.flush_all
仅用于清理缓存中的所有名称/值对。如果需要将缓存重置到干净的状态,则 flush_all 能提供很大的用处。
10.quit //退出
例子:
set mykey 0 60 11
hello world
get mykey
append mykey 0 60 1
a
get mykey
prepend mykey 0 60 3
hi
get mykey
delete mykey