• 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.

  • 相关阅读:
    python+requests+re匹配抓取猫眼上映电影信息
    Qt 5.12 LTS 部署
    Apache 日志记录相关设置
    php curl 相关知识
    Apache缓存相关配置
    Apache开启GZIP 压缩网页
    Apache 相关 mod_rewrite ,RewriteCond,{HTTP_HOST}
    Andriod you must restart adb and eclipse
    JDK 环境变量的配置
    http 协议详解
  • 原文地址:https://www.cnblogs.com/ljl1366136/p/9569547.html
Copyright © 2020-2023  润新知