从零开始带你上手体验Sermant自定义插件开发
本文分享自华为云社区《Sermant自定义插件开发上手体验》,作者:华为云开源。
一、研究缘由
由于目前我们所处的行业是汽车行业,项目上进行云服务的迁移时使用到了Sermant中的相关插件, 为了加深对Sermant开发和运行机制的了解,我们从零开始体验Sermant自定义插件的开发。
下面我们就Sermant-example中的first-plugin-demo来进行研究说明。
二、下载Sermant-example
首先我们下载sermant-example的demo:
下载完成之后,我们从最简单的自定义插件开始,也即first-plugin-demo。
三、执行打包
对first-plugin-demo执行打包,打完包的结构:
可以看到我们的项目和对应的插件模板项目都在里面了。
四、启动项目
java -javaagent:sermant-agent.jar -jar Application.jar
然后访问controller方法
从而可以看到拦截的效果:
可以看到启动的过程中,完成了拦截的效果。
也即它走了拦截器的前置和后置方法。
五、动态配置验证
配置的动态配置里面配置的配置中心是zookeeper,因此我们在启动项目前需要启动一个zookeeper作为配置中心,同时开启动态配置开关。
完成之后,我们需要在相应的监听节点下创建一个配置项,来测试动态配置的功能:
再次进行访问,可以在控制台看到如下效果:
也即完成了动态配置的功能。而我们可以看到
其实质是创建了配置监听器,实现了配置处理的process方法,其中DynamicConfigEvent就是监听到的配置更改的事件,包含了配置的group,key,content等配置信息。实现动态配置的相关实现是调用了自己实现的process方法,基于map对配置进行存储和处理,从而实现配置切换。
六、全流程中的参数argsMap到底是什么
之前一直很好奇配置里面的信息到底是什么,最近debug之后有所发现。
我们可以看到加载的argMap里面的相关参数:
我们可以看到argsMap里面的参数基本上和上面的配置,同时会加载插件里面的配置信息。完成这些操作之后,就可以在全流程中去完成对应信息的加载了。
ConfigManager.initialize(argsMap) ,主要是解析一些配置,由于配置存在yaml和properties等不同的形式,因此这里采用策略模式来进行解析。主要的相关配置信息可以参考BaseConfig这个接口的实现。
七、插件的加载是在plugins.yaml
插件的加载是在plugins.yaml里面配置的,比如我们自定义的插件:
而实现插件的关键在于plugins.yaml中配置了哪些插件。因为这些插件正是后续进行拦截的基础。也即它告诉了程序,需要加载哪些插件,不需要加载哪些插件。有了这个基础,才会进行后面精准的转换、installOn操作。
八、拦截原理
我们可以看到上面控制台打印的拦截信息,那如何实现拦截的呢?
可以看到我们执行first-plugin-demo这个示例的时候:会发现我们执行业务方法的时候,它就会进行织入拦截器,执行对应的onMethodEnter和方法执行完后的onMethodExit方法。
这两个方法和byte-buddy中的使用实现的功能是类似的。在需要拦截的方法中执行织入的逻辑。
同时可以从控制台debug中的信息可以看到调用的情况:
完成上面的调用之后,我们便可以看到控制台输出的信息了。
这里我们以进入方法为例,来进行说明:
可以看到进入对应的织入方法之后,最终会走到我们需要进行扩展的迭代器中,来实现迭代。
可以看到进入了first-plugin-demo中的插件拦截:
完成拦截进入到业务方法中,实现拦截功能的织入。然后进入后置拦截,完成after的拦截逻辑。
参考:
官网:https://sermant.io
仓库地址:https://github.com/sermant-io/Sermant
Demo仓库:https://github.com/sermant-io/Sermant-examples

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
深度解读昇腾CANN多流并行技术,提高硬件资源利用率
本文分享自华为云社区《深度解读昇腾CANN多流并行技术,提高硬件资源利用率》,作者:昇腾CANN。 随着人工智能应用日益成熟,文本、图片、音频、视频等非结构化数据的处理需求呈指数级增长,数据处理过程从通用计算逐步向异构计算过渡。面对多样化的计算需求,昇腾AI处理器内置丰富的硬件计算资源用于处理不同的计算任务。其中,AI Core、Vector Core与AI CPU分别负责AI计算场景下的矩阵、向量与标量计算,DVPP支持图像、视频等数据的加速处理,而HCCL作为华为集合通信库,则提供单机多卡及多机多卡间的数据并行、模型并行集合通信方案。 在给定硬件算力的情况下,如何高效利用这些计算资源、提高计算效率显得尤其重要。多样化的计算任务以task的形式下发到各硬件资源执行,GE(Graph Engine)图引擎采用多流并行算法,在满足计算图任务内部依赖关系的前提下,支持高效并发执行计算任务,从而大大提高硬件资源利用率和AI计算效率。 1 多流并行技术实现 计算图编译时,GE会为计算图中的每个节点分配一个硬件资源(即对应一种执行引擎),在任务执行时按编译时分配的stream调度顺序下发到对应的...
- 下一篇
以Java项目为例,实现Jenkins对接CCE Autopilot集群
本文分享自华为云社区《Jenkins对接CCE autopilot集群实战》,作者: 可以交个朋友。 一 背景 鉴于日趋流行的serverless技术架构、以及用户经常谈及的降本的需求。考虑Jenkins主从架构的特性,slave节点可以在工作的时候部署在任意平台上执行master节点下发的任务,因此可以基于CCE Autopilot集群为Jenkins的agent节点设置运行平台。 二 简介 以java项目为例,完成java 业务从代码拉取、maven编译、构建镜像、推送镜像、修改yaml文件推送到代码仓库等一系列CI流程。 jenkins agent容器使用谷歌提供的Kaniko镜像 三 操作实践 提前安装好jenkis,并配置kubernetes插件。 3.1 配置jenkins连接autopilot集群 创建autopilot集群的连接凭据 类型: 选择secret file file: 上传autopilot集群的kubeconfig配置文件 Clouds中配置连接autopilot集群 在系统管理中选择clouds,点击新增 Cloud name: 自定义即可 Type: ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- CentOS8安装Docker,最新的服务器搭配容器使用
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Red5直播服务器,属于Java语言的直播服务器
- CentOS6,CentOS7官方镜像安装Oracle11G
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- SpringBoot2整合Redis,开启缓存,提高访问速度