您的位置:首页 > 数据库 > Memcache

memcached-配置以及命令

2017-03-03 23:02 99 查看
memcached.exe -d install/uninstall

-m:最大内存使用,单位M,默认64

-M:内存耗尽返回错误,而不是删除项

-c:最大同时连接数,默认1024

-f:块大小增长因子,1.25

-n:最小分配空间,key+flags+value默认48

-h:帮助

启动(文件目录不能含中文):

1:memcached.exe -d start/restart/stop/shutdown

2:开启服务

netstat -an:11211端口监听,说明启动成功

netstat -anb:查看那个程序监听

netstat -a:查看外部访问主机名

启动不成功

1:管理员安装后,在启动

2:memcached.exe -p 端口号(关闭窗口后,进程也关闭)

控制面板-程序和功能-打开or关闭window功能,开启telnet

连接:telnet 127.0.0.1 11211

增加

add key1 0 30 5:add key名 是否压缩 存活时间 字符大小

hello

获取

get key1

获取多个值,最后一个值为CAS令牌

gets key key01

修改(没有则新增,有则修改):set key1 0 30 5

world

替换(没有失败,有则替换):replace key1 0 30 5

hello

删除:delete key

后面追加:append key 0 30 2

aa

前面追加:prepend

数字增加:ncr key 2

数字减少:decr key 5

清除所有:flush_all

清除900秒以内的:flush_all 900

cas命令:

通过gets获取最后一位

根据最后一位更新数据,如果期间数据被更改,令牌也会被更改,则这次更改无效

gets tp

cas tp 0 900 5 7(gets获取的token)

redis

stats:查看memcache信息, PID(进程号)、版本号、连接数

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

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

stats sizes:显示所有item的大小和个数。

———机制

基于c/s架构,使用最简单的基于文本行的协议,所以通过telnet也可执行操作

基于libevent的事件处理,进行网络并发连接的处理,已保持快速响应能力

内存放满情况下,使用LRU算法,删除最长一次没使用的数据

是分布式缓存服务器,但是服务器端并没有实现分布式,各个memcached不会互相通信,分布式取决于客户端的实现

memcached和session比较

memcached主要目的是提速,因此它是一种无状态的数据,

session与数据绑定,所以他是一种有状态的数据

使用场景

变化频繁,具有不稳定性的数据,不需要实时入库(在线人数,在线状态等)

门户新闻,
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: