首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java插件化编程(动态加载)

java插件化编程(动态加载)

作者头像
shengjk1
发布2018-10-24 15:17:25
6.5K0
发布2018-10-24 15:17:25
举报
文章被收录于专栏:码字搬砖码字搬砖码字搬砖

对于java程序员来说,插件化是一件很酷的功能,小二有幸在工作中实现了此功能。

背景:

这里写图片描述
这里写图片描述

需要将mysql的数据通过canal同步至kafka/mysql/hdfs等

实现 直接上代码

/**
 * Created by shengjk1 on 2017/12/11
 */
public class PluginManager {
    private final static Logger logger = LoggerFactory.getLogger(SendMessageFactory.class);

    private URLClassLoader urlClassLoader;

    public PluginManager(List<Plugin> plugins) throws MalformedURLException {
        init(plugins);
    }
    //将所有插件动态加载至JVM中
    private void init(List<Plugin> plugins) throws MalformedURLException {
        int size = plugins.size();
        URL[] urls = new URL[size];
        for (int i = 0; i < size; i++) {
            Plugin plugin = plugins.get(i);
            String filePath = plugin.getJar();
            urls[i] = new URL("file:" + filePath);
        }
        urlClassLoader = new URLClassLoader(urls);
    }

    public PluginService getInstance(String className) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
        // 插件实例化对象,得到每一个插件具体的对象
        Class<?> clazz = urlClassLoader.loadClass(className);
        Object instance = clazz.newInstance();
        return (PluginService) instance;
    }
}

然后就可以进行插件的调用了。 有一点需要注意,那就是效率。反射真的降低效率吗?请移步

http://blog.csdn.net/jsjsjs1789/article/details/78719605

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年02月04日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档