一、Why Memcached?
• 高并发访问数据库的痛楚:死锁!
• 硬盘IO之痛:本机:AspNet:HttpRuntime.Cache
• 多客户端共享缓存
• Net+Memory>>IO
• 读写性能完美 Redies:Mm,1S:读取可以1W次。写:10W
• 超简单集群搭建Cluster
• 开源Open Source
• 没有提供主从赋值功能,也没提供容灾等功能,所以所有的代码基本都只是考虑性能最佳
• 学习成本非常低,入门非常容易
• 丰富的成功的案例
二、软件从单机到分布式
1、 走向分布式第一步就是解决:多台机器共享登陆信息的问题。
例如:现在有3台机器组成了一个Web应用集群,其中一台机器登陆,然后其他另外两台机器共享登陆状态?
• 方案一:AspNet 进程外的Session
• 方案二:用数据库存储当前登录状态
• 方案三:Memcache【性能最好,类似的:Redis,NoSql】
三、Memcache基础原理
• Socket 服务器端
• 数据:键值对存储
• 内存处理的算法:
• 本质就是一个大的哈希表。key最大长度255长度
• 内存模型:Memcache预先将可支配的内存空间进行分区(Slab),每个分区里再分成多个块(Chunk)最大1MB,但同一个分区里:块的长度(bytes)是固定的。
• 插入数据,查找适合自己长度的块,然后插入,会有内存浪费。
• LRU闲置>过期>最小访问
• 惰性删除:它并没有提供监控数据过期的限制,而是惰性的,当查到某个key数据时,如果过期那么直接抛弃。
• 集群搭建原理
• Memcache服务器端并没有提供集群功能,但是通过客户端的驱动程序实现了集群配置。
• 客户端实现集群的原理:首先客户端配置多台集群机器的ip和端口的列表。然后客户端驱动程序在写入之前,首先对key做哈希处理得到哈希值后对总的机器个数进行取余然后就选择余数对应的机器。
Memcache原理图:
四、Windows下使用Memcache
• 下载Memcache:https://www.runoob.com/memcached/window-install-memcached.html
• 将服务程序拷贝到一个磁盘上的目录
• 安装服务:cmd->Memcached.exe -d install 打开服务监控窗口可以查看服务是否启动(注:Win10安装过程中64位1.4.5报错,换成64位1.4.4没报错,具体什么原因网上也没有详细介绍)
• 启动服务:cmd->Memcached.exe -d start (restart重启、stop关闭、start启动)
• 检查服务是否启动:连接到Memcache控制台:telnet ServerIp 11211 输入命令:stats检查当前服务状态
• 卸载服务:Memcached.exe -d uninstall
安装:
服务安装完成:
启动服务:在memcached上右键->启动
连接Memcache:
注:安装前确保本机电脑上已安装telnet服务
控制面板->程序->启动或关闭Windows功能
连接成功(黑丫丫的一片):
输入第一个命令:stats
参数值
SET(既可以修改,也可以添加,不存在则添加,反之也成立)
1 格式:set key flags exptime bytes [noreply] value 2 其中的含义如下: 3 key:键值 key-value 结构中的 key,用于查找缓存值。 4 flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。 5 exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远) 6 bytes:在缓存中存储的字节数 7 noreply(可选): 该参数告知服务器不需要返回数据 8 value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)
GET(获得)
1 格式: get 键
DELETE(删除)
1 格式:delete 键
有不懂的地方,下方留言,觉得对你有帮助的话,帮忙推荐一下,谢谢!明天继续更新.Net如何操作Memcache
原文地址:https://www.cnblogs.com/chenyanbin/p/11415368.html