FastDFS V6.09 发布,整合网络框架 libserverframe

来源: 投稿
2022-09-15 10:37:00

  FastDFS V6.09发布,主要改进:引入网络框架库libserverframe,替换原有的tracker niostorage nio两个模块。 2015libserverframeFastDFSnio模块抽取出来,现在FastDFS使用libserverframe,使得代码更加简洁高效,并解决了由来已久的一个bug:网络线程接收到客户端请求,把文件读写交给磁盘IO线程后,在磁盘线程处理过程中如果客户端断开连接,对应的网络线程将空转导致CPU跑满。解决方法是task对象使用引用计数器,网络线程和磁盘线程分别持有task对象(引用计数加一),各自处理完成后释放该task对象(引用计数减一),当引用计数为零时,才能将该task放回对象池。

  V6.09另外两点改进:

    1tracker serverstorage server均支持-N选项,表示程序在前台运行,而不采用传统的daemon运行方式,以方便和其他运维工具整合;

    2)文件上传次数、文件下载次数等计数器不再采用线程锁,而是使用原子操作,这样代码更加简洁且性能更高。

   FastDFS V6.09 依赖libfastcommonlibserverframe这两个基础库,欢迎大家下载使用,建议已有用户尽快升级到最新版本。

展开阅读全文
点击加入讨论🔥(3) 发布并加入讨论🔥
3 评论
4 收藏
分享
返回顶部
顶部