- 依赖libcurl
yum -y install libcurl libcurl-devel
- 依赖json-c
yum -y install json-c json-c-devel
源代码安装libcurl和json-c请参考其他教程。
window环境下使用cygwin编译,进入源代码根目录
make -C ./cygwin all
安装到cygwin
make -C ./cygwin install
其他指令
- uninstall 卸载安装。
- clean 清空源代码生成的库文件缓存。
linux环境直接使用gcc,进入源代码根目录
make all
安装到系统中
make install
其他指令
- uninstall 卸载安装。ls
- clean 清空源代码生成的库文件缓存。
引用头文件。
#include <apollo/apolloclient.h>
获取某个apollo上namespace对应的键值对
apollo_env apolloEnv={
meta:"192.168.1.65:16001",
appId:"ms-apigateway",
clusterName:"default",
namespaceName:"application.yml"
};
Properties properties;
getNoCacheProperty(apolloEnv,&properties);
其中Properties封装了返回键值对信息。
typedef struct {
size_t len; /**键值对个数**/
String* keys; /**键数组**/
String* values; /**值数组**/
} Properties;
注意一下几点:
- property类型配置,返回多个对应键值对结果。
- json和yaml类型配置返回唯一键值对,keys 固定为content。
应用注册后,当配置中心发生变化后自动推送更新到回调函数。
apollo_env apolloEnv={
meta:"192.168.1.65:16001",
appId:"ms-apigateway",
clusterName:"default",
namespaceName:NULL
};
notification notifications={
namespaceName:"application.yml",
notificationId:-1
};
//参数3表示异步线程是否继续运行,可定义指针 int* 当该值为0时,long pooling将停止。
submitNotificationsAsync(apolloEnv,notifications,1,updateConfig);
定义回调函数updateConfig
/**
old表示此次更新旧配置,new表示新配置。
第一次回调old是NULL。
**/
void updateConfig(Properties* old,Properties* new){
//对应的处理逻辑
}