linux重启memcache_Linux下的Memcache安装,启动

一、linux安装memcache

如果通过apt-get方式安装,则无需下载。

2. 进行memcache的安装:

1).下载源码,进行编译安装

Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent,libevent的最新版本是https://github.com/downloads/libevent/libevent/libevent-2.0.19-stable.tar.gz,如果你的系统已经安装了libevent,则不需要安装。

# cd /tmp

# wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz

# wgethttp://www.monkey.org/~provos/libevent-1.2.tar.gz

2.先安装libevent:

# tar zxvf libevent-1.2.tar.gz

# cd libevent-1.2

# ./configure --prefix=/usr

# make

# make install

测试libevent是否已经安装。

# ls -al /usr/lib | grep libevent

lrwxrwxrwx 1 root root 21 11?? 12 17:38libevent-1.2.so.1 -> libevent-1.2.so.1.0.3

-rwxr-xr-x 1 root root 263546 11?? 12 17:38libevent-1.2.so.1.0.3

-rw-r--r-- 1 root root 454156 11?? 12 17:38 libevent.a

-rwxr-xr-x 1 root root 811 11?? 12 17:38 libevent.la

lrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent.so-> libevent-1.2.so.1.0.3

安装memcache

安装memcached,同时需要安装中指定libevent的安装位置:

# cd /tmp

# tar zxvf memcached-1.2.0.tar.gz

# cd memcached-1.2.0

# ./configure --with-libevent=/usr

# make

# make install

如果中间出现报错,请仔细检查错误信息,按照错误信息来配置或者增加相应的库或者路径。

安装完成后会把memcached放到 /usr/local/bin/memcached 。

测试是否成功安装memcached:

# ls -al /usr/local/bin/mem*

-rwxr-xr-x 1 root root 137986 11?? 12 17:39/usr/local/bin/memcached

-rwxr-xr-x 1 rootroot 140179 11?? 12 17:39 /usr/local/bin/memcached-debug

2)通过apt-get进行安装:

sudo apt-get install memcached,推荐通过该方式进行安装,比较简单,不容易出现错误。

启动memcache服务器:

memcached -d -m 50 -p 11211 -u root

memcached常用启动参数描述:

-d:启动一个守护进程,-m:分配给Memcache使用的内存数量,单位是MB,默认是64MB,-u:运行Memcache的用户-l:监听的服务器IP地址-p:设置Memcache监听的端口,默认是11211注:-p(p为小写)-c:设置最大并发连接数,默认是1024-P:设置保存Memcache的pid文件注:-P(P为大写)-h 显示帮助

二、命令行访问memcached

3.1 memcached Telnet Interface

CommandDescriptionExample

get

Reads a value

get mykey

set

Set a key unconditionally

set mykey 0 60 5

add

Add a new key

add newkey 0 60 5

replace

Overwrite existing key

replace key 0 60 5

append

Append data to existing key

append key 0 60 15

prepend

Prepend data to existing key

prepend key 0 60 15

incr

Increments numerical key value by given number

incr mykey 2

decr

Decrements numerical key value by given number

decr mykey 5

delete

Deletes an existing key

delete mykey

flush_all

Invalidate specific items immediately

flush_all

Invalidate all items in n seconds

flush_all 900

stats

Prints general statistics

stats

Prints memory statistics

stats slabs

Prints memory statistics

stats malloc

Print higher level allocation statistics

stats items

stats detail

stats sizes

Resets statistics

stats reset

version

Prints server version.

version

verbosity

Increases log level

verbosity

quit

Terminate telnet session

quit

3.2 telnet请求命令格式

\r\n \r\n

a) 可以是”set”, “add”, “replace”。

“set”表示按照相应的存储该数据,没有的时候增加,有的覆盖。

“add”表示按照相应的添加该数据,但是如果该已经存在则会操作失败。

“replace”表示按照相应的替换数据,但是如果该不存在则操作失败

b) 客户端需要保存数据的key。

c) 是一个16位的无符号的整数(以十进制的方式表示)。

该标志将和需要存储的数据一起存储,并在客户端get数据时返回。

客户可以将此标志用做特殊用途,此标志对服务器来说是不透明的。

d) 过期的时间。

若为0表示存储的数据永远不过时(但可被服务器算法:LRU 等替换)。

如果非0(unix时间或者距离此时的秒数),当过期后,服务器可以保证用户得不到该数据(以服务器时间为标准)。

e) 需要存储的字节数(不包含最后的”\r\n”),当用户希望存储空数据时,可以为0

f) 最后客户端需要加上”\r\n”作为”命令头”的结束标志。

\r\n

紧接着”命令头”结束之后就要发送数据块(即希望存储的数据内容),最后加上”\r\n”作为此次通讯的结束。

3.3 telnet响应命令

结果响应:reply

当以上数据发送结束之后,服务器将返回一个应答。可能有如下的情况:

a) “STORED\r\n”:表示存储成功

b) “NOT_STORED\r\n” : 表示存储失败,但是该失败不是由于错误。

通常这是由于”add”或者”replace”命令本身的要求所引起的,或者该项在删除队列之中。

如: set key 33 0 4\r\n

ffff\r\n

4、获取/检查KeyValue

get *\r\n

a) * 表示一个或者多个key(以空格分开)

b) “\r\n” 命令头的结束

结果响应:reply

服务器端将返回0个或者多个的数据项。每个数据项都是由一个文本行和一个数据块组成。当所有的数据项都接收完毕将收到”END\r\n”

每一项的数据结构:

VALUE \r\n

\r\n

a) 希望得到存储数据的key

b) 发送set命令时设置的标志项

c) 发送数据块的长度(不包含”\r\n”)

d) “\r\n” 文本行的结束标志

e) 希望接收的数据项。

f) “\r\n” 接收一个数据项的结束标志。

如果有些key出现在get命令行中但是没有返回相应的数据,这意味着服务器中不存在这些项,这些项过时了,或者被删除了

如:get aa

VALUE aa 33 4

ffff

END

5、删除KeyValue:

delete \r\n

a) 需要被删除数据的key

b) 客户端希望服务器将该数据删除的时间(unix时间或者从现在开始的秒数)

c) “\r\n” 命令头的结束

6、检查Memcache服务器状态:

stats\r\n

在这里可以看到memcache的获取次数,当前连接数,写入次数,已经命中率等;

pid : 进程id

uptime :总的运行时间,秒数

time : 当前时间

version : 版本号

……

curr_items : 当前缓存中的KeyValue数量

total_items : 曾经总共经过缓存的KeyValue数量

bytes : 所有的缓存使用的内存量

curr_connections 当前连接数

….

cmd_get : 总获取次数

cmd_set : 总的写入次数

get_hits : 总的命中次数

miss_hits :  获取失败次数

…..

bytes_read : 总共读取的流量字节数

bytes_written : 总的写入流量字节

limit_maxbytes : 最大允许使用的内存量,字节

7、高级缓存细节查看方法:

stats reset

清空统计数据

stats malloc

显示内存分配数据

stats cachedump slab_id limit_num

显示某个slab中的前limit_num个key列表,显示格式如下

ITEM key_name [ value_length b; expire_time|access_time s]

其中,memcached 1.2.2及以前版本显示的是  访问时间(timestamp)

1.2.4以上版本,包括1.2.4显示 过期时间(timestamp)

如果是永不过期的key,expire_time会显示为服务器启动的时间

stats cachedump 7 2

ITEM copy_test1 [250 b; 1207795754 s]

ITEM copy_test [248 b; 1207793649 s]

stats slabs

显示各个slab的信息,包括chunk的大小、数目、使用情况等

stats items

显示各个slab中item的数目和最老item的年龄(最后一次访问距离现在的秒数)

stats detail [on|off|dump]

设置或者显示详细操作记录

参数为on,打开详细操作记录

参数为off,关闭详细操作记录

参数为dump,显示详细操作记录(每一个键值get、set、hit、del的次数)

8、清空所有键值

flush_all

注:flush并不会将items删除,只是将所有的items标记为expired,因此这时memcache依旧占用所有内存。

9、退出

quit\r\n

10 示例:

下面假设memcached 启动时的-p 参数为11311,命令操作在启动memcached

本机首先telnet 连接到memcached 服务器

telnet 127.0.0.1 11311

telnet 成功之后,大概会显示下面的信息

Trying 127.0.0.1...

Connected to localhost.localdomain (127.0.0.1).

Escape character is'^]'.

各种状态(stats) STAT

如:stats命令,则返回以下信息:

stats

返回:

STAT pid 4217STATuptime 542326STATtime 1453378174STAT version1.4.15STAT libevent2.0.21-stable

STAT pointer_size64STAT rusage_user14.114854STAT rusage_system7.409873STAT curr_connections17STAT total_connections111STAT connection_structures18STAT reserved_fds20STAT cmd_get8447STAT cmd_set645STAT cmd_flush0STAT cmd_touch0STAT get_hits7162STAT get_misses1285STAT delete_misses23STAT delete_hits88STAT incr_misses0STAT incr_hits0STAT decr_misses0STAT decr_hits0STAT cas_misses0STAT cas_hits0STAT cas_badval0STAT touch_hits0STAT touch_misses0STAT auth_cmds0STAT auth_errors0STAT bytes_read988228STAT bytes_written4834410STAT limit_maxbytes67108864#  分配给memcache的内存大小(字节)STAT accepting_conns1STAT listen_disabled_num0STAT threads4STAT conn_yields1STAT hash_power_level16STAT hash_bytes524288STAT hash_is_expanding0STAT bytes7858 # 当前服务器存储items占用的字节数STAT curr_items23 # 服务器当前存储的items数量STAT total_items645STAT expired_unfetched38STAT evicted_unfetched0STAT evictions0 # 分配给memcache的空间用满后需要删除旧的items数,踢出。STAT reclaimed226 #回收再利用,已过期的数据条目来存储新数据。END

存储命令(set ,add ,replace)

客户端会发送一行像这样的命令:

如:

set key1 0 60 5

value

STORED

add key2 0 500 2

STORED

replace key1 0 600 6

value1

NOT_STORED

详细的命令说明,可以见附录的memcached 中英文协议内容

读取命令(get)

命令如下:get *\r\n

- * 表示一个或多个键值,由空格隔开的字串

如:

get key1

VALUE key1 0 7

value12

删除命令(delete)

命令如:delete \r\n

是客户端希望服务器删除的内容的键名

- 是一个单位为秒的时间(或代表直到某一刻的Unix时间),在该时间内服务器会拒绝对于此键名的“add”和“replace”命令。此时内容被放入delete队列,无法再通过“get”得到该内容,也无法是用“add”和“replace”命令(但是“set”命令可用)。直到指定时间,这些内容被最终从服务器的内存中彻底清除

参数是可选的,缺省为0(表示内容会立刻清除,并且随后的存储命令均可用

如:delete key1

退出命令(quit)

如:quit

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值