当前位置: 首页 > news >正文

网站建设论文结尾项目网络技术

网站建设论文结尾,项目网络技术,网站到首页排名,php网站 关键技术原文网址#xff1a;https://lwn.net/Articles/93617 原文作者#xff1a;Corbet 原文时间#xff1a;2004年7月14日 内核提供了一种用于实现引用计数的简单机制kref#xff1b;该机制是今年3月份完成的。kref机制的核心思想是#xff0c;提供支持原子操作的计数器https://lwn.net/Articles/93617 原文作者Corbet 原文时间2004年7月14日 内核提供了一种用于实现引用计数的简单机制kref该机制是今年3月份完成的。kref机制的核心思想是提供支持原子操作的计数器用于对未决引用【outstanding references】进行计数。如果计数器数值为零内核不再需要引用对象了引用对象可以被释放掉。 kref机制的函数很简单在引用对象数据结构内直接包含一个struct kref计数器或struct kref *计数器指针在引用对象被操作之前调用kref_get函数引用计数器递增。 struct kref *kref_get(struct kref *kref) {WARN_ON(!atomic_read(kref-refcount));atomic_inc(kref-refcount);return kref; } 在对对象操作完成之后调用kref_put函数引用计数器递减如果计数器数值为零就调用回调函数释放引用对象相关资源。 void kref_put(struct kref *kref) {if (atomic_dec_and_test(kref-refcount)) {kref-release(kref); //release函数是回调函数} } 对引用计数refcount域进行原子操作使得上述两个函数可以安全地在多CPU或抢断环境下直接调用也就是说在这两个环境下引用计数器的数值总能获得正确的结果。但是如果两个内核线程在使用kref机制时存在下面情况kref机制也会出错。 内核线程1内核线程2 /* In kref_get() */ WARN_ON(!atomic_read(kref-refcount)); kref_put(kref); atomic_inc(kref-refcount); return kref; 在上面的例子中内核线程1在调用atomic_inc之前的那一刻被引用对象的相关资源很可能被释放掉了。kref代码强制要求对同一个引用对象不允许kref_get和kref_put并行运行。也就是说这种强制性要求上述两个函数都需要用锁来避免对同一个引用对象的并行访问。 但是关注高可扩展性的程序员经常会使用免锁算法。因为在线程数量比较大的时候锁往往会成为性能瓶颈因此尽可能不用锁内核的可扩展性会更好。这也是内核提供seqlock和RCU这两种技术的原因。kref机制对锁机制的需求使得seqlock和RCU很难派上用途。 Ravikiran G Thirumalai最近提交了一份题为“Refcounting of objects part of a lockfree collection”的补丁实现了一个新的锁机制refcount_t用于对象的免锁管理。并用大量篇幅介绍了和RCU一起工作时引用计数过程所有补丁构建了一种类似kref的数据类型这种数据类型不需要用锁就能避免前面提到的竞争问题。 伴随并行写的过程【as currently written】kref_get首先检查引用计数数值如果计数数值为零表示对象已经被释放了。当前的实现是检查到数值为零时仅仅是抱怨一下【我理解为信息输出而不做更多的处理】有人可能要说了这种情况下应该做进一步的处理才好。然而真正的问题是对引用计数的测试和递增如果不能在一个原子操作中实现那么在这两个操作之间就有可能插入其他操作。Ravikiran的补丁通过提供另一个XXXX_get函数来解决这个问题 static inline int refcount_get_rcu(refcount_t *rc){int c, old;c atomic_read(rc-count);while ( c (old cmpxchg(rc-count.counter, c, c1)) ! c) c old;return c;} 上面函数的核心是cmpxchg函数这是一个内联汇编函数可以直接使用CPU的cmpxchg指令。这个函数的原型是 int cmpxchg(int *location, int old, int new); cmpxchg函数实现了以下基本功能 1用原子操作实现比较location内存单元数值和old变量数值如果两者数值相等将location内存单元设置为new变量数值。 2如果上述原子操作成功即判断两者数值相等后location内存单元被修改cmpxchg函数返回old变量数值如果上述原子操作不成功cmpxchg返回location内存单元的数值。 cmpxchg指令是CPU提供的测试-设置原子指令。用cmpxchg实现的XXXX_get函数在不用锁的情况下就可以实现引用计数器的获取。 这里还是有点小问题。考虑一种情况内核线程2对引用计数对象释放后又重新使用该对象然后内核线程1才试图去获取引用计数。在这种情况下内核线程1可能看到的是一个随机的引用计数就误以为成功获取了引用计数。引入RCU机制可以避免这种情况发生。引用对象的释放是通过RCU回调函数来实现这样一来引用对象就不会被真正释放直到每一个处理器都发生了调度。只要内核线程能通过指针找到引用对象那么这个对象就一直存在即使对象的引用计数数值为零。经过一个完整静默期没有内核线程去访问这样的指针了引用对象才会被安全地删除。 另一个潜在的问题是并不是所有的体系结构都提供cmpxchg原子指令。针对这样的系统Ravikiran用到了一个从未见过但相当巧妙的方案用到了自旋锁的哈希数组如果你们好奇就自己去看补丁好了。 这些努力都是值得的这个技术已经用于文件描述符查找了tiobench测试性能提高了13% ~ 21%。内核系统里还有类似kref API一样的对象也有创建新的引用计数API。因此补丁还可能会重写。
http://www.hkea.cn/news/14577944/

相关文章:

  • 搭建网站浏览器网站大全免费
  • 网站备案帐号是什么意思wordpress+淘客代码
  • 网站会员系统怎么做模版杭州建设网考试信息网
  • 网站栏目做树形结构图aspnet网站建设
  • php创建站点百度投诉中心入口
  • 网站建设合同属于印花税的哪个税目专业团队电脑壁纸
  • 广州网站建设 推广公司哪家好微信公众号网站开发本地调试
  • 泗阳网站建设用js做自适应网站
  • 做网站首页轮播图代码我要自学网python
  • 苏州网站建设 江苏千渡vue移动端开发
  • 搭建一个网站教程网站后台要求
  • 网站开发常见毕业设计题目重庆装修公司大全
  • 做网站配置服务器建筑设计公司名字起名大全
  • 郑州做网站天强科技福田我要做网站优化比较好
  • 免费app做logo的网站石家庄企业网站制作哪家好
  • 网站开发z亿玛酷1流量订制如何避免网站模板侵权
  • 湛江建站公司模板学网页设计的课程
  • 有哪些基于网站开发的报表设计器上网站 ftp
  • 网站建设创业计划书wordpress网站网速慢
  • 网站建设外包价格河西集团网站建设
  • 电商建站价格wordpress添加首页
  • 网站发布内容是否过滤做h5的网站哪个好
  • 书店网站建设网站栏目结构企业建设网站需要什么资料
  • 建立网站的公司杭州免费wordpress搭建
  • 个人网站作业生产建设网站基坑开挖深度
  • 只做同城交易的网站小白怎么做网站
  • 网站建设所需美工画册设计流程
  • 网站建设腾讯云与阿里云网络商城是什么意思
  • 网站的push运营怎么做html网页上传到服务器
  • 加强网站基础建设网站管理系统安装