Memcache介绍
1、特点
内置存储方式----------为了提高性能,memcached中保存的数据都存储在memcache内置的内存存储空间中。由于数据仅存在于内存中,重启操作系统会导致全部数据消失
简单key/value存储--------------服务器不关心数据本身的意义及结构,只要是可序列化数据即可。存储项由“键、过期时间、可选的标志及数据”四个部分组成;
不互相通信的分布式------------- memcached尽管是“分布式”缓存服务器,但服务器端并没有分布式功能。 各个memcached不会互相通信以共享信息。那么,怎样进行分布式呢? 这完全取决于客户端的实现。
2.服务框架
原理:
1.检查客户端的请求数据是否存在在mamcache中,如果存在。直接把请求数据返回,不在对数据库进行任何操作,路径为1237。
2.如果请求数据不在memcached中,就去查数据库,把从数据库中获取的数据返沪给客户端,同时缓存一份数据在memcached中,路径为1234576.
3.保持缓存的“新鲜性”,每次数据发生变化时(数据库被修改,或者删除的情况下),要同步更新数据,确保用户不会取到旧的数据。
3、Memcached的部署安装
#安装
yum -y install memcached
#启动服务
systemctl start memcached
#修改配置文件
vim /etc/sysconfig/memcached
PORT="11211" # 监听端口
USER="memcached" # 用户
MAXCONN="1024" # 最大并发数
CACHESIZE="64" # 分配内存大小
OPTIONS="" # 监听网络地址
然后把ip地址发给开发人员,开发的会使用api接口连接memcached.
测试
yum install -y telnet #安装telent,探测端口
Trying 192.168.20.141...
Connected to 192.168.20.141.
Escape character is '^]'.
set name 0 60 9 #设置名称为name的key
zhangxiao #name的值
STORED #出现stored表示存储成功
get name #查询名称为key的值
VALUE name 0 9
zhangxiao
END
quit #退出
Connection closed by foreign host.
参数解释:
name:key的名字 自己定义
0:key的id号,需要和其他的key不一样
60:缓存过期时间,单位为秒,0为永远
9:字符串最大长度