需求:
用过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
这里就是主函数了