FastDFS V6.09 发布,主要改进:引入网络框架库 libserverframe,替换原有的 tracker nio 和 storage nio 两个模块。 2015 年 libserverframe 从 FastDFS 的 nio 模块抽取出来,现在 FastDFS 使用 libserverframe,使得代码更加简洁高效,并解决了由来已久的一个 bug:网络线程接收到客户端请求,把文件读写交给磁盘 IO 线程后,在磁盘线程处理过程中如果客户端断开连接,对应的网络线程将空转导致 CPU 跑满。解决方法是 task 对象使用引用计数器,网络线程和磁盘线程分别持有 task 对象(引用计数加一),各自处理完成后释放该 task 对象(引用计数减一),当引用计数为零时,才能将该 task 放回对象池。
V6.09 另外两点改进:
1)tracker server 和 storage server 均支持 -N 选项,表示程序在前台运行,而不采用传统的 daemon 运行方式,以方便和其他运维工具整合;
2)文件上传次数、文件下载次数等计数器不再采用线程锁,而是使用原子操作,这样代码更加简洁且性能更高。
FastDFS V6.09 依赖 libfastcommon 和 libserverframe 这两个基础库,欢迎大家下载使用,建议已有用户尽快升级到最新版本。