mirror of https://github.com/milvus-io/milvus.git
related: #35184 Signed-off-by: MrPresent-Han <chun.han@gmail.com> Co-authored-by: MrPresent-Han <chun.han@gmail.com>pull/35383/head^2
parent
14ef88f423
commit
337e065902
|
@ -53,18 +53,37 @@ ChunkCache::Read(const std::string& filepath,
|
||||||
|
|
||||||
// release lock and perform download and decode
|
// release lock and perform download and decode
|
||||||
// other thread request same path shall get the future.
|
// other thread request same path shall get the future.
|
||||||
auto field_data = DownloadAndDecodeRemoteFile(cm_.get(), filepath);
|
std::unique_ptr<DataCodec> field_data;
|
||||||
auto column = Mmap(field_data->GetFieldData(), descriptor);
|
std::shared_ptr<ColumnBase> column;
|
||||||
|
bool allocate_success = false;
|
||||||
// set promise value to notify the future
|
ErrorCode err_code = Success;
|
||||||
lck.lock();
|
std::string err_msg = "";
|
||||||
|
try {
|
||||||
|
field_data = DownloadAndDecodeRemoteFile(cm_.get(), filepath);
|
||||||
|
column = Mmap(field_data->GetFieldData(), descriptor);
|
||||||
|
allocate_success = true;
|
||||||
|
} catch (const SegcoreError& e) {
|
||||||
|
err_code = e.get_error_code();
|
||||||
|
err_msg = fmt::format("failed to read for chunkCache, seg_core_err:{}",
|
||||||
|
e.what());
|
||||||
|
}
|
||||||
|
std::unique_lock mmap_lck(mutex_);
|
||||||
it = columns_.find(filepath);
|
it = columns_.find(filepath);
|
||||||
if (it != columns_.end()) {
|
if (it != columns_.end()) {
|
||||||
// check pair exists then set value
|
// check pair exists then set value
|
||||||
it->second.first.set_value(column);
|
it->second.first.set_value(column);
|
||||||
|
if (allocate_success) {
|
||||||
|
AssertInfo(column, "unexpected null column, file={}", filepath);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
PanicInfo(UnexpectedError,
|
||||||
|
"Wrong code, the thread to download for cache should get the "
|
||||||
|
"target entry");
|
||||||
|
}
|
||||||
|
if (err_code != Success) {
|
||||||
|
columns_.erase(filepath);
|
||||||
|
throw SegcoreError(err_code, err_msg);
|
||||||
}
|
}
|
||||||
lck.unlock();
|
|
||||||
AssertInfo(column, "unexpected null column, file={}", filepath);
|
|
||||||
return column;
|
return column;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue