对于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;
}
}
然后就可以进行插件的调用了。 有一点需要注意,那就是效率。反射真的降低效率吗?请移步