memcached命令使用以及集群

memcached命令参数详解:以上安装配置后才可使用

指令格式:

<命令><键><标记><有效期><数据长度>

<命令> - command name

主要是三个储存数据的三个命令, set, add, replace

set 命令是保存一个叫做key的数据到服务器上

add 命令是添加一个数据到服务器,但是服务器必须保证这个key是不存在的,能够保证数据不会被覆盖

replace 命令是替换一个已经存在的数据,如果数据不存在,就是类似set功能

<键> - key

就是保存在服务器上唯一的一个表示符,必须是跟其他的key不冲突,否则会覆盖掉原来的数据,这个key是为了能够准确的存取一个数据项目

<标记> - flag

标记是一个16位的无符号整形数据,用来设置服务器端跟客户端一些交互的操作

<有效期> - expiration time

是数据在服务器上的有效期限,如果是0,则数据永远有效,单位是秒,Memcache服务器端会把一个数据的有效期

设置为当前Unix时间+设置的有效时间

<数据长度> - bytes

数据的长度,block data 块数据的长度,一般在这个个长度结束以后下一行跟着block data数据内容,发送完数据以后,客户端一般等待服务器端的返回。

数据保存成功

STORED

数据保存失败,一般是因为服务器端这个数据key已经存在了

END

证明没有不存在这个key,没有任何数据,如果存在数据,则返回指定格式:

<数据块>

返回的数据是以VALUE开始的,后面跟着key和flags,以及数据长度,第二行跟着数据块

<键> -key

是发送过来指令的key内容

<标记> - flags

是调用set指令保存数据时候的flags标记

<数据长度> - bytes

是保存数据时候定位的长度

<数据块> - data block

数据长度下一行就是提取的数据块内容

[ 数据删除指令]

数据删除指令也是比较简单的,使用delete指令,格式是:

delete <键><超时时间>

NOT_FOUND

这个key没有在服务器上找到

如果要删除所有服务器上的数据,可以使用flush_all指令,格式:

flush_all

这个指令执行后,服务器上所有缓存的数据都被删除,并且返回:

OK

注意:这个指令一般不要轻易使,除非你确实想把所有数据都干掉,删除完以后可以无法恢复的。

stats

服务器将返回每行按照 STAT开始的状态信息,包括20行,20项左右的信息,包括守护进程的pid、版本、保存的项目数量、内存占用、最大内存限制等等信息。

如果只是想获取部分项目的信息,可以指定参数,格式:

stats <参数>

这个指令将只返回指定参数的项目状态信息。

如果只是想单独了解当前版本信息,可以使用version指令,格式:

version

将返回以 VERSION 开头的版本信息

如果想结束当前连接,使用quit指令,格式:

quit

将断开当前连接

    Memcached 连接

我们可以通过 telnet 命令并指定主机ip和端口来连接 Memcached 服务。

语法

telnet HOST PORT

命令中的 HOST 和 PORT 为运行 Memcached 服务的 IP 和 端口。

实例

以下实例演示了如何连接到 Memcached 服务并执行简单的 set 和 get 命令。

本实例的 Memcached 服务运行的主机为 127.0.0.1(本机) 、端口为 11211。

telnet 127.0.0.1 11211

Trying 127.0.0.1...

Connected to 127.0.0.1.

Escape character is '^]'. 

    Memcached set 命令

Memcached set 命令用于将 value(数据值) 存储在指定的 key(键) 中。

如果set的key已经存在,该命令可以更新该key所对应的原来的数据,也就是实现更新的作用。

语法:

set 命令的基本语法格式如下:

set key flags exptime bytes [noreply] value

参数说明如下:

如果数据设置成功,则输出:

STORED

输出信息说明

    Memcached add 命令

Memcached add 命令用于将 value(数据值) 存储在指定的 key(键) 中。

如果 add 的 key 已经存在,则不会更新数据(过期的 key 会更新),之前的值将仍然保持相同,并且您将获得响应 NOT_STORED

语法:

add 命令的基本语法格式如下:

add key flags exptime bytes [noreply] value

参数说明如下:

输出

如果数据添加成功,则输出:

STORED

输出信息说明:

    Memcached replace 命令

Memcached replace 命令用于替换已存在的 key(键) 的 value(数据值)

如果 key 不存在,则替换失败,并且您将获得响应 NOT_STORED

语法:

replace 命令的基本语法格式如下:

replace key flags exptime bytes [noreply] value

参数说明如下:

输出

如果数据添加成功,则输出:

STORED

输出信息说明:

    Memcached append 命令

Memcached append 命令用于向已存在 key(键) 的 value(数据值) 后面追加数据 。

语法:

append 命令的基本语法格式如下:

append key flags exptime bytes [noreply] value

参数说明如下:

输出

如果数据添加成功,则输出:

STORED

输出信息说明:

    Memcached prepend 命令

Memcached prepend 命令用于向已存在 key(键) 的 value(数据值) 前面追加数据 。

语法:

prepend 命令的基本语法格式如下:

prepend key flags exptime bytes [noreply] value

参数说明如下:

 

输出

如果数据添加成功,则输出:

STORED

输出信息说明:

      memcached get 命令

Memcached get 命令获取存储在 key(键) 中的 value(数据值) ,如果 key 不存在,则返回空。

语法:

get 命令的基本语法格式如下:

get key

多个 key 使用空格隔开,如下:

get key1 key2 key3

参数说明如下:

              key:键值 key-value 结构中的 key,用于查找缓存值。

        Memcached gets 命令

Memcached gets 命令获取带有 CAS 令牌存 的 value(数据值) ,如果 key 不存在,则返回空。

语法:

gets 命令的基本语法格式如下:

gets key

多个 key 使用空格隔开,如下:

gets key1 key2 key3

参数说明如下:

        • key:键值 key-value 结构中的 key,用于查找缓存值。

 

使用 gets 命令的输出结果中,在最后一列的数字 1 代表了 key 为 test 的 CAS 令牌。

      Memcached delete 命令

Memcached delete 命令用于删除已存在的 key(键)。

语法:

delete 命令的基本语法格式如下:

delete key [noreply]

参数说明如下:

 

        • key:键值 key-value 结构中的 key,用于查找缓存值。
        • noreply(可选): 该参数告知服务器不需要返回数据

 

输出

输出信息说明:

 

      Memcached incr 与 decr 命令

 

Memcached incr 与 decr 命令用于对已存在的 key(键) 的数字值进行自增或自减操作。

 

incr 与 decr 命令操作的数据必须是十进制的32位无符号整数。

 

如果 key 不存在返回 NOT_FOUND,如果键的值不为数字,则返回 CLIENT_ERROR,其他错误返回 ERROR

 

 

incr 命令

 

语法:

 

incr 命令的基本语法格式如下:

 

incr key increment_value 

 

 

参数说明如下:

 

        • key:键值 key-value 结构中的 key,用于查找缓存值。
        • increment_value: 增加的数值。

 

输出

输出信息说明:

 

decr 命令

 

decr 命令的基本语法格式如下:

 

decr key decrement_value

 

参数说明如下:

 

 

        • key:键值 key-value 结构中的 key,用于查找缓存值。
        • decrement_value: 减少的数值。

 

在以下实例中,我们使用 test 作为 key,初始值为 15,之后进行减 10 操作。

输出

输出信息说明:

        • NOT_FOUND:key 不存在。
        • CLIENT_ERROR:自增值不是对象。

         ERROR其他错误,如语法错误等。

 

统计命令

 

 

Memcached stats 命令

 

Memcached stats 命令用于返回统计信息例如 PID(进程号)、版本号、连接数等。

 

语法:

 

stats 命令的基本语法格式如下:

 

stats

 

 

在以下实例中,我们使用了 stats 命令来输出 Memcached 服务信息。

 

stats

 

这里显示了很多状态信息,下边详细解释每个状态项:

 

 

  • pid: memcache服务器进程ID
  • uptime:服务器已运行秒数
  • time:服务器当前Unix时间戳
  • version:memcache版本
  • pointer_size:操作系统指针大小
  • rusage_user:进程累计用户时间
  • rusage_system:进程累计系统时间
  • curr_connections:当前连接数量
  • total_connections:Memcached运行以来连接总数
  • connection_structures:Memcached分配的连接结构数量
  • cmd_get:get命令请求次数
  • cmd_set:set命令请求次数
  • cmd_flush:flush命令请求次数
  • get_hits:get命令命中次数
  • get_misses:get命令未命中次数
  • delete_misses:delete命令未命中次数
  • delete_hits:delete命令命中次数
  • incr_misses:incr命令未命中次数
  • incr_hits:incr命令命中次数
  • decr_misses:decr命令未命中次数
  • decr_hits:decr命令命中次数
  • cas_misses:cas命令未命中次数
  • cas_hits:cas命令命中次数
  • cas_badval:使用擦拭次数
  • auth_cmds:认证命令处理的次数
  • auth_errors:认证失败数目
  • bytes_read:读取总字节数
  • bytes_written:发送总字节数
  • limit_maxbytes:分配的内存总大小(字节)
  • accepting_conns:服务器是否达到过最大连接(0/1)
  • listen_disabled_num:失效的监听数
  • threads:当前线程数
  • conn_yields:连接操作主动放弃数目
  • bytes:当前存储占用的字节数
  • curr_items:当前存储的数据总数
  • total_items:启动以来存储的数据总数
  • evictions:LRU释放的对象数目
  • reclaimed:已过期的数据条目来存储新数据的数目

 

 

      Memcached stats items 命令

 

Memcached stats items 命令用于显示各个 slab 中 item 的数目和存储时长(最后一次访问距离现在的秒数)。

 

语法:

 

stats items 命令的基本语法格式如下:

 

stats items

 

 

      Memcached stats slabs 命令

 

Memcached stats slabs 命令用于显示各个slab的信息,包括chunk的大小、数目、使用情况等。

 

语法:

 

stats slabs 命令的基本语法格式如下:

 

stats slabs

 

 

      Memcached stats sizes 命令

 

Memcached stats sizes 命令用于显示所有item的大小和个数。

 

该信息返回两列,第一列是 item 的大小,第二列是 item 的个数。

 

语法:

 

stats sizes 命令的基本语法格式如下:

 

stats sizes 

 

 

      Memcached flush_all 命令

 

Memcached flush_all 命令用于用于清理缓存中的所有 key=>value(键=>值) 对。

 

该命令提供了一个可选参数 time,用于在制定的时间后执行清理缓存操作。

 

语法:

 

flush_all 命令的基本语法格式如下:

 

flush_all [time] [noreply] 

 

 

 

Memcache群集

 

 

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态、数据库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信。

实验:

1、安装libevent软件(四台)

[root@localhost ~]# tar -zxvf libevent-2.0.22-stable.tar.gz -C /usr/src/

[root@localhost ~]# cd /usr/src/libevent-2.0.22-stabl

[root@localhost libevent-2.0.21-stable]# ./configure --prefix=/usr/

[root@localhost libevent-2.0.21-stable]# make && make install

2、安装memcached软件(Memcached服务器 2台)

[root@localhost ~]# tar -zxvf memcached-1.4.31.tar.gz -C /usr/src/

[root@localhost ~]# cd /usr/src/memcached-1.4.31/

[root@localhost memcached-1.4.31]# ./configure --enable-memcache --with-libevent=/usr/

[root@localhost memcached-1.4.31]# make && make install

主缓存:

[root@localhost ~]# memcached -d -m 1024 -u root -l 192.168.1.201 -p 11211

备缓存:

[root@localhost ~]# memcached -d -m 1024 -u root -l 192.168.1.202 -p 11211

[root@localhost ~]# netstat -anpt | grep memcached

3、安装magent 软件(Magent 服务器 2台)

[root@localhost ~]# mkdir /usr/magent

[root@localhost ~]# tar -zxvf magent-0.6.tar.gz -C /usr/magent/

[root@localhost ~]# cd /usr/magent/

[root@localhost magent]# vim ketama.h

添加(头部添加):

#ifndef SSIZE_MAX

#define SSIZE_MAX 32767

#endif

[root@localhost magent]# ln -s /usr/lib64/libm.so /usr/lib64/libm.a

[root@localhost magent]# ln -s /usr/lib64/libevent-2.0.so.5 /usr/lib64/libevent.a

无法make的时候需要安装libevent-2.0.so.5

[root@localhost magent]# /sbin/ldconfig

[root@localhost magent]# make

[root@localhost magent]# cp magent /usr/bin/

主缓存和备缓存一样的启动命令(-l 是漂移IP 还没有搭建Keepalived服务 暂时不要启动Magent服务)

4、安装keepalived 软件(Magent 服务器 2台)

[root@localhost ~]# yum -y install kernel-devel openssl-devel popt-devel

[root@localhost ~]# tar -zxvf   keepalived-1.3.9.tar.gz  -C /usr/src/

[root@localhost ~]# cd /usr/src/ keepalived-1.3.9/

[root@localhost keepalived-1.3.9]#  ./configure --prefix=/ && make && make install

[root@localhost keepalived-1.3.9]# cp keepalived/etc/init.d/keepalived /etc/init.d/

[root@localhost keepalived-1.3.9]# chkconfig --add keepalived

[root@localhost keepalived-1.3.9]# chkconfig keepalived on

配置主缓存服务器

[root@localhost ~]# vim /etc/keepalived/keepalived.conf

修改:

global_defs {

router_id LVS_DEVEL_R1

}

vrrp_instance VI_1 {

state MASTER

interface eth0

virtual_router_id 51

priority 100

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.1.10

}

}

[root@localhost ~]# magent -u root -n 51200 -l 192.168.1.10 -p 12000 -s 192.168.1.201:11211 -b 192.168.1.202:11211

[root@localhost ~]# magent -u root -n 51200 -l 192.168.1.10 -p 12000 -s 192.168.1.201:11211 -b 192.168.1.202:11211

-u:用户

-n:最大连接数

-l:magent 对外监听IP 地址

-p:magent 对外监听端口

-s:magent 主缓存IP 地址和端口

-b:magent 备缓存IP 地址和端口

[root@localhost ~]# ps -elf | grep magent

[root@localhost ~]# service keepalived restart

[root@localhost ~]# ip add show dev eth0

验证:

客户端ping 192.168.1.10 查看VIP的变化情况。

5、验证:

1)用主缓存节点连接上主缓存的1200端口插入数据

[root@localhost ~]# telnet 192.168.1.10 12000

Trying 192.168.1.10...

Connected to 192.168.1.10.

Escape character is '^]'.

set key 33 0 5

ggggg

STORED

quit

Connection closed by foreign host.

 

2)查看插入的数据

[root@localhost ~]# telnet 192.168.1.10 12000

Trying 192.168.1.10...

Connected to 192.168.1.10.

Escape character is '^]'.

get key

VALUE key 33 5

ggggg

END

quit

Connection closed by foreign host.

3)连接主缓存节点的11211端口进行查看

[root@localhost ~]# telnet 192.168.1.201 11211

Trying 192.168.1.100...

Connected to 192.168.1.100.

Escape character is '^]'.

get key

VALUE key 33 5

ggggg

END

quit

Connection closed by foreign host.

 

posted @ 2018-09-03 10:41  别人放弃,我努力  阅读(209)  评论(0编辑  收藏  举报