免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: linux_c_py_php
打印 上一主题 下一主题

[其他] 【讲讲我的编程生涯 - 章1】 [复制链接]

论坛徽章:
3
15-16赛季CBA联赛之山东
日期:2016-10-30 08:47:3015-16赛季CBA联赛之佛山
日期:2016-12-17 00:06:31CU十四周年纪念徽章
日期:2017-12-03 01:04:02
21 [报告]
发表于 2013-02-09 11:32 |只看该作者
回复 21# zylthinking


    一天...... 膜拜下

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
22 [报告]
发表于 2013-02-09 13:05 |只看该作者
本帖最后由 linux_c_py_php 于 2013-02-09 13:06 编辑

一天, 话说slab+hash+lru的缓存懒惰淘汰机制还是很巧妙的, 好夸张的一天.

zylthinking 发表于 2013-02-09 09:39
居然是memcached, 07年的时候我用了一天就看懂了, 顺便还发现了它一个bug , 不知现在怎样了, 当时不过一 ...

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
23 [报告]
发表于 2013-02-09 13:08 |只看该作者
嗯, 现在已经在百度当码农了, 不知道自己的码农观念在这里怎么样.

coderit 发表于 2013-02-09 09:16
这是种正宗的码农观念,这样的小菜,让我开了不少,腾讯允许有你这样观念的码农存在,腾讯啥样就不言而 ...

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
24 [报告]
发表于 2013-02-09 13:18 来自手机 |只看该作者
不记得有 lru, 要不是忘记了, 就是后面加上的,  一天绝对无疑, 不过把头看痛了也是真的。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
25 [报告]
发表于 2013-02-09 13:22 来自手机 |只看该作者
其实往往当官的技术比不上被开的, 你能开不少人, 你技术啥样也就。。。。。。。。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
26 [报告]
发表于 2013-02-09 13:31 |只看该作者
我印象深.

简单的说就是slab是不定长内存池(若干不同size的桶), 每个桶内有一个Lru链表, 有一个free链表, 链表每个node就是hash node, 正在被使用的Node存在于hashtable以及slab lru中.

每次set new key, 先到对应的slab桶内的lru找当前reference=0的最老的过期的Node进行重用并update到lru的头部, 找不到则从slab分配新node(或者从mempool摘一个chunk到桶里然后切一个Node出来, 或者free list有现成的), 如果这也失败, 那么试图找reference=0且最老的尚未过期的node争取重用并update到lru的头部, 如果这也失败, 就彻底失败了.

reference是一个带锁引用计数实现, 因为memcached采用libevent+one_event_per_thread的实现, 涉及到对hash表或者node的并发访问, 所以有两种加锁策略, 对于涉及哈希表node增删的处理需要加大锁, 对于访问与修改Node->data的操作, 则只需要reference+1 -> handle -> reference -1 (if reference == 0 then delete the node), 这样把锁粒度降低到只需要在reference+1/-1时才需要加锁.



zylthinking 发表于 2013-02-09 13:18
不记得有 lru, 要不是忘记了, 就是后面加上的,  一天绝对无疑, 不过把头看痛了也是真的。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
27 [报告]
发表于 2013-02-09 13:34 |只看该作者
公司业绩不好才会裁个不停, 互联网很快就开始这场腥风暴雨了

zylthinking 发表于 2013-02-09 13:22
其实往往当官的技术比不上被开的, 你能开不少人, 你技术啥样也就。。。。。。。。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
28 [报告]
发表于 2013-02-09 13:39 来自手机 |只看该作者
我的印象里却是很简单明确的实现, 谈不上巧妙, 毕竟在内存中维护键值, 增删改查询之类 对不是什么复杂任务

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
29 [报告]
发表于 2013-02-09 14:05 |只看该作者
lses vb,8741

论坛徽章:
0
30 [报告]
发表于 2013-02-09 14:17 |只看该作者
傲娇是什么意思……
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP