本文整理汇总了C++中FileInfo::GetChunkPath方法的典型用法代码示例。如果您正苦于以下问题:C++ FileInfo::GetChunkPath方法的具体用法?C++ FileInfo::GetChunkPath怎么用?C++ FileInfo::GetChunkPath使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类FileInfo
的用法示例。
在下文中一共展示了FileInfo::GetChunkPath方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: SaveFile
bool File::SaveFile(FileInfo &file_info, string &local_file)
{
string fid;
int retry_time = 0;
if(!SHA1::hash(local_file, fid))
{
LOG_ERROR(logger, "get fid failed. file="<<local_file);
return false;
}
LOG_DEBUG(logger, "get fid: file="<<local_file<<",fid="<<fid);
while(true)
{
if(!_get_file_info(fid, true, file_info))
{
LOG_DEBUG(logger, "query master error.");
return false;
}
switch(file_info.result)
{
case FileInfo::RESULT_FAILED: //失败
{
LOG_DEBUG(logger, "get file info failed. fid="<<fid);
return true;
}
case FileInfo::RESULT_SUCC: //已经保存过
{
LOG_DEBUG(logger, "file already exist. fid="<<file_info.fid<<",name="<<file_info.name<<",size="<<file_info.size);
return true;
}
case FileInfo::RESULT_CHUNK: //分配chunk成功
{
int i;
for(i=0; i<file_info.GetChunkPathCount(); ++i)
{
ChunkPath &chunk_path = file_info.GetChunkPath(i);
LOG_INFO(logger, "request chunk to store file. fid="<<fid<<",chunk_ip="<<chunk_path.ip<<",chunk_port="<<chunk_path.port);
FileInfo temp_file_info;
if(!_send_file_to_chunk(local_file, fid, chunk_path.ip, chunk_path.port, temp_file_info))
{
file_info.result = FileInfo::RESULT_FAILED;
break;
}
else
file_info = temp_file_info;
}
return true;
}
case FileInfo::RESULT_SAVING: //正在保存
{
++retry_time;
if(retry_time > 3)
{
LOG_DEBUG(logger, "fid="<<fid<<" is saving. reach the max retry_times="<<retry_time);
return true;
}
LOG_DEBUG(logger, "fid="<<fid<<" is saving, waiting for file_info. retry_time="<<retry_time);
sleep(2); //等1s后重新请求master获取文件信息
break;
}
default:
{
LOG_WARN(logger, "unknown result value:result="<<file_info.result);
return false;
}
}
}
return true;
}