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这两个基础库,欢迎大家下载使用,建议已有用户尽快升级到最新版本。