服务器程序动态加载自定义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

这里就是主函数了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章