发文章
发文工具
撰写
网文摘手
文档
视频
思维导图
随笔
相册
原创同步助手
其他工具
图片转文字
文件清理
AI助手
留言交流
项目做了很多,虽然用memcached的项目也有很多。但是没有太关注安装memcached细节问题
最近做了一个项目,把很多东西都放到memcached缓存中,进行缓存。
因为内容可能较多,可能会有200M~500M的样子。
这样就要在安装memcached的时候。把最大内存使用提高,不然只能使用默认的64M
所以下载了memcached文件1.2.6版本
然后用命令行进行安装
memcached -d install -m 500
本想以为这样安装就万事大吉了。因为看到所有的文章都是说这样安装-m参数是用来修改最大使用内存
但是用telnet 127.0.0.1 11211
stats
去查看memcached状态的时候。发现最大使用内存还是STAT limit_maxbytes 67108864 (64M)
我不是明明加上了-m参数吗。为什么这个值还是64M呢。
这不是我想要的。所以这次安装没有成功,把这个服务删除
然后直接用memcached -m 500直接这样在命令行运行,这样发现竟然成功的把最大使用内存提高到了500M
但是又有问题。我这样运行的方式命令行不能关闭。要一直开着才可以。如果把命令行关了。memcached就没有运行了
虽然这样运行的方式不是以服务的方式运行,而是以当前用户进行运行,但确实是把最大使用内存提高了。
虽然修改可以。但是如果命令行不能关闭,要一直运行。这是在服务器上是行的。
最终还是得以服务的方式运行,所以这种方式还是放弃了。
最后。还是用第一次的方式安装,然后打开服务去看
发现一个问题,上图片
我明明是有用-m 500 而在服务属性那里。还是只有-d runservice,没有我们用的-m 500的参数
所以在我们启动的时候。还是以默认的64M最大使用内存来用。找到问题就好解决,
开始我还想用sc create服务的方式。来创建,按理说是可以加上-m参数。这个没有做实验。
我是直接修改注册表的方式,打开注册表,查找"memecached Server"的键
我们可以找到
修改ImagePath,在-d runserver前面加上-m 500保存
然后你再看看服务属性,发现已经有了-m 500参数
然后启动服务,现在就可以看到最大使用内存已经修改到500M了
事情到止已经OK,为了这破问题,花了我半天的时间。然后在博客园发布了一个博问,
事情还是没有解决。我还以为我设置了-m参数,用stats去看还是64M,
还专门写了一个测试库来测试到是不是显示问题
1 static void Main(string[] args) 2 { 3 MemcachedClient cacheClient = new MemcachedClient(); 4 long count = default(long); 5 string val = "abceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefgabceefg"; 6 for (int i = 0; i < 5; i++) { 7 val = val + val; 8 } 9 long MaxKey = default(long); 10 if (cacheClient.Get("MaxKey") != null) MaxKey = cacheClient.Get<long>("MaxKey"); 11 string key = "Key" + MaxKey.ToString(); 12 while (cacheClient.Store(StoreMode.Add, key, MaxKey.ToString() + val, new TimeSpan(1, 0, 0))) 13 { 14 string cacheVal = cacheClient.Get<string>(key); 15 cacheClient.Store(StoreMode.Set, "MaxKey", count); 16 MaxKey += 1; 17 key = "Key" + MaxKey.ToString(); 18 Console.WriteLine(MaxKey.ToString()); 19 if ((MaxKey % 5000) == 0) Console.ReadKey(); 20 } 21 Console.ReadKey(); 22 }
下面是测试用代码的配置文件
1 <?xml version="1.0" encoding="utf-8" ?> 2 <configuration> 3 <configSections> 4 <sectionGroup name="enyim.com"> 5 <section name="memcached" type="Enyim.Caching.Configuration.MemcachedClientSection, Enyim.Caching" /> 6 </sectionGroup> 7 <section name="memcached" type="Enyim.Caching.Configuration.MemcachedClientSection, Enyim.Caching" /> 8 </configSections> 9 <enyim.com> 10 <memcached> 11 <servers> 12 <add address="127.0.0.1" port="11211" /> 13 </servers> 14 <socketPool minPoolSize="10" maxPoolSize="100" connectionTimeout="00:00:10" deadTimeout="00:02:00" /> 15 </memcached> 16 </enyim.com> 17 <memcached keyTransformer="Enyim.Caching.TigerHashTransformer, Enyim.Caching"> 18 <servers> 19 <add address="127.0.0.1" port="11211" /> 20 </servers> 21 <socketPool minPoolSize="2" maxPoolSize="100" connectionTimeout="00:00:10" deadTimeout="00:02:00" /> 22 </memcached> 23 </configuration>
问题解决。花了我半天的时候。在打算放弃的时候。发现了服务启去方面的问题。
心情很happy啊。
来自: 昵称10504424 > 《工作》
0条评论
发表
请遵守用户 评论公约
为什么memcached会堵车
为什么memcached会堵车。我们来看看应用程序中对memcached的操作情况,使用memcached的地方都是这么操作的——根据key从memcached中取数据,如果取到,直接返回;<enyim.com> <memcached prot...
使用memcached进行内存缓存: 一个藏袍
使用memcached进行内存缓存。通常的网页缓存方式有动态缓存和静态缓存等几种,在ASP.NET中已经可以实现对页面局部进行缓存,而使用memcached的缓存比ASP.NET的局部缓存更加灵活,可以缓存任意的对象,...
精选 21道 Redis 最常问面试题!收藏一波 !
6、redis适用于的场景?7、redis的缓存失效策略和主键失效机制8、为什么redis需要把所有数据放到内存中?9、Redis是单进程单线程的10、redis的并发竞争问题如何解决?11、redis常见性能问题和解决方案12、...
集群架构实践 - 初试Memcached
这里我们为了在演示中看到缓存的效果,故新建了两个网站,每一个网站都可以设置和读取缓存内容,如在webA中设置了缓存,可以在webB中获取由webA设置的缓存内容。这里可能你不太明白的是为什么在appSett...
Discuz!NT中集成Memcached分布式缓存
NT中集成Memcached分布式缓存。/// <summary> /// 添加指定ID的对象(关联指定键值组) /// </summary> /// <par...
网站架构之缓存应用
这篇来讲如何利用memcached实现一级缓存,以及如何让一级缓存组件支持在企业库,memcached或者其它第三方实施方案之间的切换。MyWebCach...
00Memcached 教程
Memcached教程Memcached是一个自由开源的,高性能,分布式内存对象缓存系统。Memcached官网:http://memcached.org/。特征memcached作为高速运行的分布式缓存服务器,具有以下的特点。协议简单基于libe...
在redis使用过程遇到的一些问题的总结
分析了一下,问题还是处在redis内存上:虽然可以通过定期重启redis来释放内存,但是redis内存的增加的速度是不可预期的,我们并不能每次...
memcached for windows 修改端口和最大内存 - BearRui(AK-...
memcached for windows 修改端口和最大内存 - BearRui(AK-...要想在windows中使用memcached,必须先下载memcached for win32安装。于是...
微信扫码,在手机上查看选中内容