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

    这里就是主函数了

  • 相关阅读:
    队列与双向队列

    linux nohup, jobs, fg, tail指令 指令前后台切换
    linux shell
    Linux学习笔记四 grep, sed, awk
    面试要求
    jenkins send files or publish
    mysql导入脚本
    第三方接口调用框架
    pdm文件name与comment互相同步
  • 原文地址:https://www.cnblogs.com/amazement/p/7526938.html
Copyright © 2011-2022 走看看