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