zoukankan      html  css  js  c++  java
  • 服务器程序动态加载自定义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

    这里就是主函数了

  • 相关阅读:
    DAY 57 django12
    韦东山网课https://edu.csdn.net/course/play/207/1117
    关于初始化
    软件——机器学习与Python,Python3的输出与输入
    关于python中数组的问题,序列格式转换
    偏最小二乘法
    数据标准化
    SD卡与tf卡引脚转换
    程序心得
    牛客网 python 求解立方根
  • 原文地址:https://www.cnblogs.com/amazement/p/7526938.html
Copyright © 2011-2022 走看看