请教:请教storage状态的几个问题
fish兄,最近在学习fastdfs。在tracker_merge_servers函数上卡住了,主要原因,还是对storage的状态不是很了解。我看了几个版本,你对这段代码有较大的改动。 FDFS_STORAGE_STATUS_NONE这个状态一直很不解,到底是什么意思。在论坛中没找到相关说明,也没有相关的注释,能否说明下
又:能否有个状态迁移图,代码里的if else 太多了,本来想自己整理下,奈何,程序还不是很熟
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
回复 1# ckittterl
tracker/tracker_types.h中定义storage server的状态值如下:
#define FDFS_STORAGE_STATUS_INIT 0
#define FDFS_STORAGE_STATUS_WAIT_SYNC 1
#define FDFS_STORAGE_STATUS_SYNCING 2
#define FDFS_STORAGE_STATUS_IP_CHANGED 3
#define FDFS_STORAGE_STATUS_DELETED 4
#define FDFS_STORAGE_STATUS_OFFLINE 5
#define FDFS_STORAGE_STATUS_ONLINE 6
#define FDFS_STORAGE_STATUS_ACTIVE 7
#define FDFS_STORAGE_STATUS_NONE 99
各个状态,应该可以见文知意。
着重说一下FDFS_STORAGE_STATUS_NONE这个状态。这个状态值仅保存在storage server的内存中,是一个临时状态。
当一台同步目标storage server的状态是FDFS_STORAGE_STATUS_IP_CHANGED或FDFS_STORAGE_STATUS_DELETED时,同步线程会退出。
同步线程退出前,会将其状态更改为FDFS_STORAGE_STATUS_NONE。