</configuration>
</execution>
</executions>
</plugin>
- 程序入口是DisconfDemoMain类 , 里面的main方法初始化spring环境 , 启动一个while死循环 , 每隔五秒将JedisConfig实例的host和port属性打印到终端;
- JedisConfig的host和port属性 , 是被disconf的runtime环境控制 , 可以实时被设置成最新的配置值 , 对应的远程配置和具体的属性字段 , 都是通过注解来完成的:

文章插图
如上图所示:
红框中的DisconfFile注解将该类和disconf服务端的redis.properties配置绑定;
黄框中的DisconfFileItem注解将host和port属性与redis.properties配置的host , port属性绑定;
紫框中的DisconfUpdateService注解向disconf运行时注册了配置变化的实时广播监听 , 当配置发生变化时 , 蓝框中的reload方法会被disconf运行时调用;
- SimpleRedisServiceUpdateCallback类的作用也是注册广播监听 , 当配置发生变化时 , 蓝框中的reload方法会被disconf运行时调用;
- 除了代码 , 还要关注disconf.properties文件:
# true(默认)会从远程获取配置 false则直接获取本地配置
disconf.enable.remote.conf=true
#
# 配置服务器的 HOST,用逗号分隔 127.0.0.1:8004,127.0.0.1:8004
#
disconf.conf_server_host=Nginxhost:80
#disconf.conf_server_host=127.0.0.1:80
# 版本, 请采用 X_X_X_X 格式
disconf.version=1_0_0_0
# APP 请采用 产品线_服务名 格式
disconf.app=disconf_demo
# 环境disco
disconf.env=rd
# 忽略哪些分布式配置 , 用逗号分隔
disconf.ignore=
# 获取远程配置 重试次数 , 默认是3次
disconf.conf_server_url_retry_times=1
# 获取远程配置 重试时休眠时间 , 默认是5秒
disconf.conf_server_url_retry_sleep_seconds=1
# 用户指定的下载文件夹, 远程文件下载后会放在这里
disconf.user_define_download_dir=./disconf/download2
# 下载的文件会被迁移到classpath根路径下 , 强烈建议将此选项置为 true(默认是true)
disconf.enable_local_download_dir_in_class_path=true
confserverhost的值在此处配置成nginxhost,这个和docker容器启动时配置的nginx的link别名一致 , 这样demo就能访问到disconf服务器了;
- disconf在demo上的运行时环境 , 是通过spring配置来实现的 , 如下:
<aop:aspectj-autoproxy proxy-target-class="true"/>
<!-- 使用disconf必须添加以下配置 -->
<bean id="disconfMgrBean" class="com.baidu.disconf.client.DisconfMgrBean"
destroy-method="destroy">
<property name="scanPackage" value=https://www.isolves.com/it/cxkf/rongqi/2020-09-22/"com.example.disconf.demo"/>
</bean>
<bean id="disconfMgrBean2" class="com.baidu.disconf.client.DisconfMgrBeanSecond"
init-method="init" destroy-method="destroy">
</bean>
disconfMgrBean复制核心管理 , disconfMgrBean2负责启动定时扫描和实现销毁时的回调 。
- 配置好这些 , 打开控制台 , 在pom.xml文件所在目录下执行 , 即可完成打包 , 这时候进入target目录 , 可以看到执行结果如下图:

文章插图
- 打开上图中的starter-run文件夹中的start.sh文件 , 最下面一行内容如下:
这个命令会启动java进程 , 并且把输出信息重定向到日志文件中 , 这样就不便于我们观察demo的运行效果 , 动手把这一行修改如下:
java $JAVA_OPTS -jar ${CUR_BUNDLE_NAME}
这样所有的日志都会在控制台打印出来 , 便于我们观察运行状态;
- 打包完成了 , 现在可以开始制作镜像了 , 这里的基础镜像我选用的是 , 是为了图个方便 , 不用安装jdk和配置java环境了 , dockerfile内容非常简单 , 创建一个工作目录 , 把前面打包时生成的starter-run文件夹下的所有东西都复制到这个工作目录中去:
推荐阅读
- 怎样用加密狗保护我们的程序?加密狗使用原理的一点了解
- python如何使用HanLP,LTP,jieba中文分词库
- CentOS7下部署Cobbler实现PXE+KS自动化安装
- 电脑发送的信息是如何到达目的地的?简单了解下网络传输原理过程
- 为什么没人写方腊起义 方腊宋江起义
- 雀斑怎么去除 8款食疗方让你提前“下斑”
- 清朝灭亡后的皇亲贵族去哪了 清朝灭亡后满清贵族下场
- 清朝八大铁帽子王都有谁?大多下场悲惨 清朝最后一个铁帽子王
- 描写楚汉战争在亥下最后决战的一首名曲是 项羽亥下悲歌
- 什么叫巫蛊之术 真的有巫蛊之术吗
