milvus/internal/datacoord
congqixia 8cf2cf5c94
enhance: Add `go-deadlock` as unittest only dependency (#33063)
See also #33062

This PR:

- Add `lock.RWMutex` & `lock.Mutex` alias to switch implementation based
  on build flags
- When build flags has `test` in it, use `go-deadlock` to detect
  possible deadlocks
- Replace all `sync.RWMutex` & `sync.Mutex` in datacoord pkg

Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>

Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
2024-05-15 16:33:34 +08:00
..
broker enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
OWNERS [skip ci]Update OWNERS files (#11898) 2021-11-16 15:41:11 +08:00
README.md [skip ci]Change etcd to lowercase (#9983) 2021-10-15 18:58:37 +08:00
allocator.go feat: Add import scheduler and manager (#29367) 2024-03-01 18:31:02 +08:00
allocator_test.go Decoupling client and server API in types interface (#27186) 2023-09-26 09:57:25 +08:00
build_index_policy.go Format the code (#27275) 2023-09-21 09:45:27 +08:00
channel.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_checker.go Format the code (#27275) 2023-09-21 09:45:27 +08:00
channel_checker_test.go Format the code (#27275) 2023-09-21 09:45:27 +08:00
channel_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
channel_manager_factory.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_manager_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_manager_v2.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
channel_manager_v2_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_store.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_store_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_store_v2.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
channel_store_v2_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
cluster.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
cluster_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
compaction.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
compaction_l0_view.go fix: Trigger l0 compaction when l0 views don't change (#30729) 2024-03-05 16:37:00 +08:00
compaction_l0_view_test.go enhance: Add force trigger (#30641) 2024-02-19 18:40:50 +08:00
compaction_scheduler.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
compaction_scheduler_test.go enhance: Add CompactionTaskNum metrics (#29518) 2023-12-28 15:46:55 +08:00
compaction_test.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
compaction_trigger.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
compaction_trigger_test.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00
compaction_trigger_v2.go fix: Skip to submit l0 tasks when scheduler full (#31270) 2024-03-15 10:21:12 +08:00
compaction_trigger_v2_test.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
compaction_view.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00
compaction_view_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
compaction_view_manager_test.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00
const.go enhance: pass partition key scalar info if enabled when build vector index (#29931) 2024-01-24 00:04:55 +08:00
errors.go Refine DataCoord status (#27262) 2023-09-26 17:15:27 +08:00
errors_test.go Format the code (#27275) 2023-09-21 09:45:27 +08:00
garbage_collector.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
garbage_collector_test.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
handler.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
import_checker.go enhance: Ensure ImportV2 waits for the index to be built and refine some logic (#31629) 2024-04-01 20:09:13 +08:00
import_checker_test.go enhance: Ensure ImportV2 waits for the index to be built and refine some logic (#31629) 2024-04-01 20:09:13 +08:00
import_job.go enhance: Return more fields in import progress response (#31539) 2024-03-24 21:57:06 +08:00
import_meta.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
import_meta_test.go feat: Add import scheduler and manager (#29367) 2024-03-01 18:31:02 +08:00
import_scheduler.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
import_scheduler_test.go enhance: Ensure ImportV2 waits for the index to be built and refine some logic (#31629) 2024-04-01 20:09:13 +08:00
import_task.go enhance: Enhance and modify the return content of ImportV2 (#31192) 2024-03-13 19:51:03 +08:00
import_util.go enhance: use WalkWithPrefix api for oss, enable piplined file gc (#31740) 2024-04-25 20:41:27 +08:00
import_util_test.go enhance: use WalkWithPrefix api for oss, enable piplined file gc (#31740) 2024-04-25 20:41:27 +08:00
index_builder.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
index_builder_test.go enhance: Add metrics for segment index files size (#32979) 2024-05-13 17:59:32 +08:00
index_engine_version_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
index_engine_version_manager_test.go Optimize the codec code of session (#27360) 2023-10-01 10:33:30 +08:00
index_meta.go enhance: speed up minor functions calls in datacoord (#32389) 2024-04-20 07:55:21 +08:00
index_meta_test.go enhance: speed up minor functions calls in datacoord (#32389) 2024-04-20 07:55:21 +08:00
index_service.go enhance: Reduce the frequency of index ralted logs (#33050) 2024-05-15 14:37:34 +08:00
index_service_test.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
indexnode_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
indexnode_manager_test.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
meta.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
meta_test.go enhance: Add metrics for segment index files size (#32979) 2024-05-13 17:59:32 +08:00
meta_util.go Make VChannelInfo read compatible with 2.0.2 (#17995) 2022-07-07 21:58:22 +08:00
metrics_info.go enhance: Add metrics for segment index files size (#32979) 2024-05-13 17:59:32 +08:00
metrics_info_test.go enhance: Use channel manager interface in server_test (#31621) 2024-04-12 14:59:20 +08:00
mock_allocator_test.go enhance: index meta use independent rather than global meta lock (#30869) 2024-03-04 16:56:59 +08:00
mock_channel_store.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
mock_channelmanager.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
mock_cluster.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
mock_compaction_meta.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
mock_compaction_plan_context.go fix: Separate schedule and check results loop (#28692) 2023-11-29 10:50:29 +08:00
mock_handler.go fix: fix collectionInfo leak in datacoord (#32175) 2024-04-15 16:33:19 +08:00
mock_index_engine_version_manager.go feat: trigger compaction to handle index version (#28442) 2023-11-21 09:26:22 +08:00
mock_scheduler.go enhance: Add CompactionTaskNum metrics (#29518) 2023-12-28 15:46:55 +08:00
mock_segment_manager.go enhance: index meta use independent rather than global meta lock (#30869) 2024-03-04 16:56:59 +08:00
mock_session_manager.go fix: add lazy load field to mark segment load type (#31591) 2024-03-28 11:23:10 +08:00
mock_subcluster.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
mock_test.go enhance: Enable alter database props in rootcoord (#32458) 2024-04-25 10:53:25 +08:00
mock_trigger_manager.go feat: Add Compaction views and triggers (#27906) 2023-11-23 17:30:25 +08:00
policy.go fix: Enable to balance released standby channel (#32986) 2024-05-14 11:51:32 +08:00
policy_test.go fix: Enable to balance released standby channel (#32986) 2024-05-14 11:51:32 +08:00
segment_allocation_policy.go fix: Decoupling importing segment from flush process (#30402) 2024-02-03 13:01:12 +08:00
segment_allocation_policy_test.go Adjust datacoord for L0 Delta (#28021) 2023-11-06 15:26:16 +08:00
segment_info.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00
segment_info_test.go enhance: use WalkWithPrefix api for oss, enable piplined file gc (#31740) 2024-04-25 20:41:27 +08:00
segment_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
segment_manager_test.go feat: add more operation detail info for better allocation (#30438) 2024-03-28 06:33:11 +08:00
segment_operator.go enhance: Improve datacoord segment filtering with collection (#32831) 2024-05-08 21:37:29 +08:00
segment_operator_test.go fix: Prevent clone when selecting segments from meta (#30928) 2024-03-01 13:59:02 +08:00
server.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
server_test.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
services.go fix: Fix segments lost in flush response (#33061) 2024-05-15 13:49:34 +08:00
services_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
session.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
session_manager.go enhance: Add `go-deadlock` as unittest only dependency (#33063) 2024-05-15 16:33:34 +08:00
session_manager_test.go feat: datacoord/node watch based on rpc (#32036) 2024-05-07 15:49:30 +08:00
util.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00
util_test.go enhance: Add memory size for binlog (#33025) 2024-05-15 12:59:34 +08:00

README.md

Data Coordinator

Data cooridnator(datacoord for short) is the component to organize DataNodes and segments allocations.

Dependency

  • KV store: a kv store has all the meta info datacoord needs to operate. (etcd)
  • Message stream: a message stream to communicate statistics information with data nodes. (Pulsar)
  • Root Coordinator: timestamp, id and meta source.
  • Data Node(s): could be an instance or a cluster, actual worker group handles data modification operations.