|
| 1 | +from pymilvus import ( |
| 2 | + MilvusClient, |
| 3 | + DataType, |
| 4 | +) |
| 5 | +from pymilvus.client.constants import DEFAULT_RESOURCE_GROUP |
| 6 | + |
| 7 | +from pymilvus.client.types import ( |
| 8 | + ResourceGroupConfig, |
| 9 | +) |
| 10 | + |
| 11 | +fmt = "\n=== {:30} ===\n" |
| 12 | +dim = 8 |
| 13 | +collection_name = "hello_milvus" |
| 14 | +milvus_client = MilvusClient("http://localhost:19530") |
| 15 | + |
| 16 | + |
| 17 | +## create collection and load collection |
| 18 | +print("create collection and load collection") |
| 19 | +collection_name = "hello_milvus" |
| 20 | +has_collection = milvus_client.has_collection(collection_name, timeout=5) |
| 21 | +if has_collection: |
| 22 | + milvus_client.drop_collection(collection_name) |
| 23 | + |
| 24 | +schema = milvus_client.create_schema(enable_dynamic_field=True) |
| 25 | +schema.add_field("id", DataType.INT64, is_primary=True) |
| 26 | +schema.add_field("embeddings", DataType.FLOAT_VECTOR, dim=dim) |
| 27 | +schema.add_field("title", DataType.VARCHAR, max_length=64) |
| 28 | +milvus_client.create_collection(collection_name, schema=schema, consistency_level="Strong") |
| 29 | +index_params = milvus_client.prepare_index_params() |
| 30 | +index_params.add_index(field_name = "embeddings", metric_type="L2") |
| 31 | +index_params.add_index(field_name = "title", index_type = "Trie", index_name="my_trie") |
| 32 | +milvus_client.create_index(collection_name, index_params) |
| 33 | +milvus_client.load_collection(collection_name) |
| 34 | + |
| 35 | + |
| 36 | +## create resource group |
| 37 | +print("create resource group") |
| 38 | +milvus_client.create_resource_group("rg1") |
| 39 | +milvus_client.create_resource_group("rg2") |
| 40 | + |
| 41 | +## update resource group |
| 42 | +configs = { |
| 43 | + "rg1": ResourceGroupConfig( |
| 44 | + requests={"node_num": 1}, |
| 45 | + limits={"node_num": 5}, |
| 46 | + transfer_from=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 47 | + transfer_to=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 48 | + ), |
| 49 | + "rg2": ResourceGroupConfig( |
| 50 | + requests={"node_num": 4}, |
| 51 | + limits={"node_num": 4}, |
| 52 | + transfer_from=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 53 | + transfer_to=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 54 | + ), |
| 55 | + } |
| 56 | +milvus_client.update_resource_groups(configs) |
| 57 | + |
| 58 | +## describe resource group |
| 59 | +print("describe rg1") |
| 60 | +result = milvus_client.describe_resource_group("rg1") |
| 61 | +print(result) |
| 62 | + |
| 63 | +print("describe rg2") |
| 64 | +result = milvus_client.describe_resource_group("rg2") |
| 65 | +print(result) |
| 66 | + |
| 67 | +## list resource group |
| 68 | +print("list resource group") |
| 69 | +result = milvus_client.list_resource_groups() |
| 70 | +print(result) |
| 71 | + |
| 72 | +## transfer replica |
| 73 | +print("transfer replica to rg1") |
| 74 | +milvus_client.transfer_replica(DEFAULT_RESOURCE_GROUP, "rg1", collection_name, 1) |
| 75 | +print("describe rg1 after transfer replica in") |
| 76 | +result = milvus_client.describe_resource_group("rg1") |
| 77 | +print(result) |
| 78 | + |
| 79 | +milvus_client.transfer_replica("rg1", DEFAULT_RESOURCE_GROUP, collection_name, 1) |
| 80 | +print("describe rg1 after transfer replica out") |
| 81 | +result = milvus_client.describe_resource_group("rg1") |
| 82 | +print(result) |
| 83 | + |
| 84 | +## drop resource group |
| 85 | +print("drop resource group") |
| 86 | +# create resource group |
| 87 | +configs = { |
| 88 | + "rg1": ResourceGroupConfig( |
| 89 | + requests={"node_num": 0}, |
| 90 | + limits={"node_num": 0}, |
| 91 | + transfer_from=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 92 | + transfer_to=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 93 | + ), |
| 94 | + "rg2": ResourceGroupConfig( |
| 95 | + requests={"node_num": 0}, |
| 96 | + limits={"node_num": 0}, |
| 97 | + transfer_from=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 98 | + transfer_to=[{"resource_group": DEFAULT_RESOURCE_GROUP}], |
| 99 | + ), |
| 100 | + } |
| 101 | +milvus_client.update_resource_groups(configs) |
| 102 | +milvus_client.drop_resource_group("rg1") |
| 103 | +milvus_client.drop_resource_group("rg2") |
| 104 | + |
| 105 | + |
0 commit comments