服务器程序动态加载自定义jar包的过程

需求:

用过hive的都知道,可以自定义hive的一个udf jar,然后将这个jar add到hive服务端,就会加载这个jar实现用户自定义逻辑。现在的需求就是实现这么一个服务端所做的事情!

场景:

用户自定义一些逻辑,主要是实现一个公共的接口,每个用户自定义自己的实现。然后服务端加载这些jar包以实现服务端的定制化.

结构图如下

 

pf4j开源工具说明

搜索了一大把,发现 pf4j 这个开源工具可以满足需求,所以就决定用它了https://github.com/decebals/pf4j。但是这个工具使用起来有点绕,所以这里记录下,主要是参考这个工程的run-domo.sh

  • pf4j-demo-api  

     这里定义了公用接口

  • pf4j-demo-plugins  

这里可以对接口自定义实现。这里重点说明:如果定义了多个plugins,需要各个打包以后,将生成的jar包或者zip包放到一个 公共目录  "/a/b",这个目录会在下面的

主函数中使用这个公共目录

PluginManager pluginManager = new DefaultPluginManager(new File("/a/b").toPath());

  • pf4j-demo-app

这里就是主函数了

转载于:https://www.cnblogs.com/amazement/p/7526938.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值