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


 

对于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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM