在不同版本号hdfs集群之间转移数据
在不同版本号hdfs集群之间转移数据
只是这有几个问题:
- 效率减少
- 占用本地磁盘空间
- 不能应付实时导数据需求
- 两个进程须要协调,复杂度添加
更好的办法是在同一个进程内一边读src数据,一边写des集群。只是这相当于在同一个进程空间内载入两个版本号的hadoop jar包。这就须要在程序中使用两个classloader来实现。
下面代码能够实现classloader载入自己定义的jar包,并生成须要的Configuration对象:
- URL[] jarUrls = new URL[1];
- jarUrls[0]=new File(des_jar_path).toURI().toURL();
- ClassLoader jarloader = new URLClassLoader(jarUrls, null);
- Class Proxy = Class.forName("yourclass", true, jarloader);
- Configuration conf = (Configuration)Proxy.newInstance();
可是因为在生成HTable对象时。须要使用这个conf对象,而载入这个conf对象的代码本身是由默认的classloader载入的,也就是0.19.2的jar包。
所以在以上代码最后一行所强制转换的Configuration对象仍然是0.19.2版本号的。
那怎么办呢?
琢磨了一会,发现假设要实现以上功能,必须将生成HTable对象,以及以后的全部hbase操作都使用这个新的classloader。因此这个新的classloader必须载入除了0.19.2的jar包外全部须要用到的jar包,然后把全部操作都封装进去。在外面用反射来调用。
这种话。通常构造函数都不为空了。因此须要用到Constructor来构造一个自己定义的构造函数
代码段例如以下:
- main.java
- void init(){
- ClassLoader jarloader = generateJarLoader();
- Class Proxy = Class.forName("test.writer.hbasewriter.HBaseProxy", true, jarloader);
- Constructor con = Proxy.getConstructor(new Class[]{String.class, String.class, boolean.class});
- Boolean autoflush = param.getBoolValue(ParamsKey.HbaseWriter.autoFlush, true);
- proxy = con.newInstance(new Object[]{path, tablename, autoflush});
- }
- void put(){
- ...
- while((line = getLine()) != null) {
- proxy.getClass().getMethod("generatePut",String.class).invoke(proxy, line.getField(rowkey));
- Method addPut = proxy.getClass().getMethod("addPut",
- new Class[]{String.class, String.class, String.class});
- addPut.invoke(proxy, new Object[]{field, column, encode});
- proxy.getClass().getMethod("putLine").invoke(proxy);
- }
- }
- ClassLoader generateJarLoader() throws IOException {
- String libPath = System.getProperty("java.ext.dirs");
- FileFilter filter = new FileFilter() {
- @Override
- public boolean accept(File pathname) {
- if(pathname.getName().startsWith("hadoop-0.19.2"))
- return false;
- else
- return pathname.getName().endsWith(".jar");
- }
- };
- File[] jars = new File(libPath).listFiles(filter);
- URL[] jarUrls = new URL[jars.length+1];
- int k = 0;
- for (int i = 0; i < jars.length; i++) {
- jarUrls[k++] = jars.toURI().toURL();
- }
- jarUrls[k] = new File("hadoop-0.20.205.jar")
- ClassLoader jarloader = new URLClassLoader(jarUrls, null);
- return jarloader;
- }
- HBaseProxy.java
- public HBaseProxy(String hbase_conf, String tableName, boolean autoflush)
- throws IOException{
- Configuration conf = new Configuration();
- conf.addResource(new Path(hbase_conf));
- config = new Configuration(conf);
- htable = new HTable(config, tableName);
- admin = new HBaseAdmin(config);
- htable.setAutoFlush(autoflush);
- }
- public void addPut(String field, String column, String encode) throws IOException {
- try {
- p.add(column.split(":")[0].getBytes(), column.split(":")[1].getBytes(),
- field.getBytes(encode));
- } catch (UnsupportedEncodingException e) {
- p.add(column.split(":")[0].getBytes(), column.split(":")[1].getBytes(),
- field.getBytes());
- }
- }
- public void generatePut(String rowkey){
- p = new Put(rowkey.getBytes());
- }
- public void putLine() throws IOException{
- htable.put(p);
- }
总之,在同一个进程中载入多个classloader时一定要注意,classloader A所载入的对象是不能转换成classloader B的对象的,当然也不能使用。
两个空间的相互调用仅仅能用java的基本类型或是反射。
很多其它精彩内容请关注:http://bbs.superwu.cn
关注超人学院微信二维码:
关注超人学院java免费学习交流群:
在不同版本号hdfs集群之间转移数据的更多相关文章
- Hadoop(四)HDFS集群详解
前言 前面几篇简单介绍了什么是大数据和Hadoop,也说了怎么搭建最简单的伪分布式和全分布式的hadoop集群.接下来这篇我详细的分享一下HDFS. HDFS前言: 设计思想:(分而治之)将大文件.大 ...
- adoop(四)HDFS集群详解
阅读目录(Content) 一.HDFS概述 1.1.HDFS概述 1.2.HDFS的概念和特性 1.3.HDFS的局限性 1.4.HDFS保证可靠性的措施 二.HDFS基本概念 2.1.HDFS主从 ...
- HDFS集群优化篇
HDFS集群优化篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作系统级别优化 1>.优化文件系统(推荐使用EXT4和XFS文件系统,相比较而言,更推荐后者,因为XF ...
- HDFS集群PB级数据迁移方案-DistCp生产环境实操篇
HDFS集群PB级数据迁移方案-DistCp生产环境实操篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 用了接近2个星期的时间,终于把公司的需要的大数据组建部署完毕了,当然,在部 ...
- sqoop将oracle数据导入hdfs集群
使用sqoop将oracle数据导入hdfs集群 集群环境: hadoop1.0.0 hbase0.92.1 zookeeper3.4.3 hive0.8.1 sqoop-1.4.1-incubati ...
- HDFS集群中DataNode的上线与下线
在HDFS集群的运维过程中,肯定会遇到DataNode的新增和删除,即上线与下线.这篇文章就详细讲解下DataNode的上线和下线的过程. 背景 在我们的微职位视频课程中,我们已经安装了3个节点的HD ...
- vivo 万台规模 HDFS 集群升级 HDFS 3.x 实践
vivo 互联网大数据团队-Lv Jia Hadoop 3.x的第一个稳定版本在2017年底就已经发布了,有很多重大的改进. 在HDFS方面,支持了Erasure Coding.More than 2 ...
- 【Redis】集群故障转移
集群故障转移 节点下线 在集群定时任务clusterCron中,会遍历集群中的节点,对每个节点进行检查,判断节点是否下线.与节点下线相关的状态有两个,分别为CLUSTER_NODE_PFAIL和CLU ...
- HDFS集群balance(2)-- 架构概览
转载请注明博客地址:http://blog.csdn.net/suileisl HDFS集群balance,对应版本balance design 6 如需word版本,请QQ522173163联系索要 ...
随机推荐
- protected的一些功能
java的访问限制有private.protected.public.这里只想进一步认识一下protected. 我对protected有4个疑问: 1,在相同包中,是否可以调用其它类的protect ...
- android ListView和GridView拖拽移位实现代码
关于ListView拖拽移动位置,想必大家并不陌生,比较不错的软件都用到如此功能了.如:搜狐,网易,百度等,但是相比来说还是百度的用户体验较好,不偏心了,下面看几个示例: 首先 ...
- shell telnet 路由器
#!/usr/bin/expect -f spawn telnet 172.16.1.80 expect "login" { send "admin\n" ex ...
- tomcat7 启动报错(转)
不加载任何自己的项目启动即报错: 严重: Error deploying web application directory D:\tomcat7.0.30\webapps\docs java.l ...
- Eclipse无提示的解决办法 和 内容辅助技巧
Eclipse无提示的解决办法 和 内容辅助技巧 一.若发现内容辅助失效没有提示 下面是解决办法,现贴出来与大家共享: 1.菜单window->Preferences->Jav ...
- 禁用win7自己主动配置ipv4地址
现象 一台新电脑,连了网线,没有dhcp,须要手动配置Ip. 配置了一个Ip后,发现ping网关不通. ipconfig 发现有2 个IP: 自己主动配置 IPv4 地址 . . . . . . ...
- Raspberry pi raspbain系统下使用vim
一开始 apt-get install vim不好用. 在putty中执行这条命令就可以了. sudo apt-get update && sudo apt-get install v ...
- No matching code signing identity found
真机调试过程中弹出这个问题,网上找到的解决的方法,记录一下. .... 弄完这些步骤之后,上面多出一个 IOS disturbution.所以出现这个问题的解决办法应该是设置的证书没有刷新到本地所致.
- UVa11183 Teen Girl Squad, 最小树形图,朱刘算法
Teen Girl Squad Input: Standard Input Output: Standard Output You are part of a group of n teenage ...
- 熬之滴水穿石:JSP--HTML中的JAVA代码(6)
39--JSTL 在JSP编码中需考虑的一种方法,因为这种方法可以 ...