A Python implementation of Nacos OpenAPI.
see: https://nacos.io/zh-cn/docs/open-API.html
Python 2.7 Python 3.6 Python 3.7
Nacos 0.8.0
pip install nacos-sdk-python
import nacos
SERVER_ADDRESSES = "server addresses split by comma"
NAMESPACE = "***"
client = nacos.NacosClient(SERVER_ADDRESSES, namespace=NAMESPACE)
# get config
data_id = "config.nacos"
group = "group"
print(client.get_config(data_id, group))
client = NacosClient(server_addresses, namespace=your_ns)
- server_addresses - required - Nacos server address, comma separated if more than 1.
- namespace - Namespace. | default:
None
Extra option can be set by set_options
, as following:
client.set_options({key}={value})
Configurable options are:
- default_timeout - Default timeout for get config from server in seconds.
- pulling_timeout - Long polling timeout in seconds.
- pulling_config_size - Max config items number listened by one polling process.
- callback_thread_num - Concurrency for invoking callback.
- failover_base - Dir to store failover config files.
- snapshot_base - Dir to store snapshot config files.
- no_snapshot - To disable default snapshot behavior, this can be overridden by param no_snapshot in get method.
NacosClient.get_config(data_id, group, timeout, no_snapshot)
-
param
data_id Data id. -
param
group Group, useDEFAULT_GROUP
if no group specified. -
param
timeout Timeout for requesting server in seconds. -
param
no_snapshot Whether to use local snapshot while server is unavailable. -
return
W Get value of one config item following priority: -
Step 1 - Get from local failover dir(default:
${cwd}/nacos-data/data
).- Failover dir can be manually copied from snapshot dir(default:
${cwd}/nacos-data/snapshot
) in advance. - This helps to suppress the effect of known server failure.
- Failover dir can be manually copied from snapshot dir(default:
-
Step 2 - Get from one server until value is got or all servers tried.
- Content will be save to snapshot dir after got from server.
-
Step 3 - Get from snapshot dir.
NacosClient.add_config_watchers(data_id, group, cb_list)
param
data_id Data id.param
group Group, useDEFAULT_GROUP
if no group specified.param
cb_list List of callback functions to add.return
Add watchers to a specified config item.
- Once changes or deletion of the item happened, callback functions will be invoked.
- If the item is already exists in server, callback functions will be invoked for once.
- Multiple callbacks on one item is allowed and all callback functions are invoked concurrently by
threading.Thread
. - Callback functions are invoked from current process.
NacosClient.remove_config_watcher(data_id, group, cb, remove_all)
param
data_id Data id.param
group Group, use "DEFAULT_GROUP" if no group specified.param
cb Callback function to delete.param
remove_all Whether to remove all occurrence of the callback or just once.return
Remove watcher from specified key.
NacosClient.publish_config(data_id, group, content, timeout)
param
data_id Data id.param
group Group, use "DEFAULT_GROUP" if no group specified.param
content Config value.param
timeout Timeout for requesting server in seconds.return
True if success or an exception will be raised.
Publish one data item to Nacos.
- If the data key is not exist, create one first.
- If the data key is exist, update to the content specified.
- Content can not be set to None, if there is need to delete config item, use function remove instead.
NacosClient.remove_config(data_id, group, timeout)
param
data_id Data id.param
group Group, use "DEFAULT_GROUP" if no group specified.param
timeout Timeout for requesting server in seconds.return
True if success or an exception will be raised.
Remove one data item from Nacos.
NacosClient.add_naming_instance(service_name, ip, port, cluster_name, weight, metadata, enable, healthy)
param
service_name required Service name to register to.param
ip required IP of the instance.param
port required Port of the instance.param
cluster_name Cluster to register to.param
weight A float number for load balancing weight.param
metadata Extra info in JSON string format.param
enable A bool value to determine whether instance is enabled or not.param
healthy A bool value to determine whether instance is healthy or not.return
True if success or an exception will be raised.
NacosClient.remove_naming_instance(service_name, ip, port, cluster_name)
param
service_name required Service name to deregister from.param
ip required IP of the instance.param
port required Port of the instance.param
cluster_name Cluster to deregister from.return
True if success or an exception will be raised.
NacosClient.modify_naming_instance(service_name, ip, port, cluster_name, weight, metadata, enable)
param
service_name required Service name.param
ip required IP of the instance.param
port required Port of the instance.param
cluster_name Cluster name.param
weight A float number for load balancing weight.param
metadata Extra info in JSON string format.param
enable A bool value to determine whether instance is enabled or not.return
True if success or an exception will be raised.
NacosClient.list_naming_instance(service_name, clusters, healthy_only)
param
service_name required Service name to query.param
clusters Cluster names separated by comma.param
healthy_only A bool value for querying healthy instances or not.return
Instance info list if success or an exception will be raised.
NacosClient.get_naming_instance(service_name, ip, port, cluster_name)
param
service_name required Service name.param
ip required IP of the instance.param
port required Port of the instance.param
cluster_name Cluster name.return
Instance info if success or an exception will be raised.
NacosClient.send_heartbeat(service_name, ip, port, cluster_name, weight, metadata)
param
service_name required Service name.param
ip required IP of the instance.param
port required Port of the instance.param
cluster_name Cluster to register to.param
weight A float number for load balancing weight.param
metadata Extra info in JSON string format.return
A JSON object include server recommended beat interval if success or an exception will be raised.
Debugging mode if useful for getting more detailed log on console.
Debugging mode can be set by:
NacosClient.set_debugging()
# only effective within the current process