JavaAgent如何实现http接口发布
导读:本文共6366.5字符,通常情况下阅读需要21分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 需求公司运维系统想要监控服务是否正常启动,这些服务是k8s部署的,运维人员的要求业务服务提供一个http接口用于监控服务健康监测,要求所有的接口请求的URL,参数等都是相同的,这么做的目的是不需要通过规范来约束开发人员去开一个服务健康监测的接口。使用服务接口来检测服务我觉得相比较监控进程启动,端口监听等方式更准确一些。所以,为了满足运维同学的要求,起初想到的方案... ...
目录
(为您整理了一些要点),点击可以直达。公司运维系统想要监控服务是否正常启动,这些服务是k8s部署的,运维人员的要求业务服务提供一个http接口用于监控服务健康监测,要求所有的接口请求的URL,参数等都是相同的,这么做的目的是不需要通过规范来约束开发人员去开一个服务健康监测的接口。
使用服务接口来检测服务我觉得相比较监控进程启动,端口监听等方式更准确一些。所以,为了满足运维同学的要求,起初想到的方案是提供一个jar,专门集成到项目中用于发布监控接口,但是想了一下,这么做需要涉及到服务的改造,我理想的方式是对应用无侵入的方式实现。
说到对应用无入侵,首先想到的就是javaagent
技术,此前使用该技术实现了无入侵增强程序日志的工具,所以对使用javaagent
已经没有问题,此时需要考虑的是如何发布接口了。
基础技术 JavaAgent
支持的技术 SpringBoot和DubboX发布的rest服务
公司服务大致分为两类,一个是使用springboot
发布的Spring MVC rest接口,另一种是基于DubboX
发布的rest接口,因为公司在向服务网格转,所以按要求是去dubbo化的,没办法还是有其他小组由于一些其他原因没有或者说短期内不想进行服务改造的项目,这些项目比较老,不是springboot的,是使用spring+DubboX发布的rest服务。所以这个agent要至少能支持这两种技术。
支持SpringBoot
想要支持SpringBoot很简单,因为SpringBoot支持自动装配,所以,我要写一个spring.factories
来进行自动装配。
支持DubboX
业务系统是传统spring+DubboX实现的,并不支持自动装配,这是个问题点,还有个问题点就是如何也发布一个DubboX的rest接口,这两个问题实际上就需要对SpringBean生命周期和Dubbo接口发布的流程有一定的了解了,这个一会儿再说。
实现一个JavaAgent很容易,以下三步就可以了,这里不细说了。
定义JavaAgent入口
Maven打包配置
MANIFEST.MF编写
注:该文件在resource/META-INF/
目录下
Manifest-Version: 1.0
Can-Redefine-Classes: true
Can-Retransform-Classes: true
Premain-Class: com.ruubypay.agent.PreAgent
编写Controller
接口很简单就发布一个get
接口,响应pong
即可。
创建spring.factories
通过这个配置文件可以实现SpringBoot自动装配,这里不细说SpringBoot自动装配的原理了,该文件的配置内容就是要自动装配的Bean
的全路径,代码如下:
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.ruubypay.config.WebConfiguration
WebConfiguration配置类
这个配置配置类很简单,@Configuration
声明这是个配置类,@ComponentScan
扫描包。
定义API
使用的是DubboX
发布rest接口
需要javax.ws.rs
包的注解,@Produces({ContentType.APPLICATION_JSON_UTF_8})
声明序列化方式,@Path
rest接口的路径,@GET
声明为get接口。
编写API实现类
实现发布Dubbo接口
如何实现发布接口是实现的难点;首先程序并不支持自动装配了,我们就要考虑如何获取到Spring
上下文,如果能够注册Bean
到Spring容器
中,如何触发发布Dubbo接口
等问题。
Spring上下文获取及注册Bean到Spring容器中
触发Bean注册,获取Spring上下文我们通过Spring的Aware接口可以实现,我这里使用的是ApplicationContextAware
;注册Bean
到Spring容器
中可以使用BeanDefinition
先创建Bean然后使用DefaultListableBeanFactory
的registerBeanDefinition
将BeanDefinition
注册到Spring上下文中。
发布Dubbo接口
通过ApplicationContextAware
我们已经能够获取Spring上下文了,也就是说应用程序的Dubbo注册中心,发布接口协议,Dubbo Application等配置都已经存在Spring容器中了,我们只要拿过来使用即可,拿过来使用没问题,我们接下来就需要考虑,如何发布接口,这需要对Dubbo服务发布的流程有一定的了解,这里我不细说了,感兴趣的可以自己了解下,或者看我以前发布的文章;
首先Dubbo接口的Provider端的核心Bean是com.alibaba.dubbo.config.spring.ServiceBean
,使用Spring配置文件中的标签<dubbo:service
标签生成的Bean就是ServiceBean
,所以,这里我们只需要创建ServiceBean
对象并且初始化对象中的必要数据,然后调用ServiceBean#export()
方法就可以发布Dubbo服务了。
这里需要的对象直接通过依赖查找的方式从Spring容器获取就可以了 ApplicationConfig
,ProtocolConfig
,RegistryConfig
,IPingService
。
DubboX: java -javaagent:ruubypay-ping-agent.jar=1 -jar 服务jar包
springboot的http接口:java -javaagent:ruubypay-ping-agent.jar -jar 服务jar包
JavaAgent如何实现http接口发布的详细内容,希望对您有所帮助,信息来源于网络。