hbase中啥是Region,啥是RegionServer
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hbase中啥是Region,啥是RegionServer相关的知识,希望对你有一定的参考价值。
regionServer 其实是hbase的服务,部署在一台物理服务器上,region有一点像关系型数据的分区,数据存放在region中,当然region下面还有很多结构,确切来说数据存放在memstore和hfile中。我们访问hbase的时候,先去hbase 系统表查找定位这条记录属于哪个region,然后定位到这个region属于哪个服务器,然后就到哪个服务器里面查找对应region中的数据 参考技术A Region是HBase数据存储和管理的基本单位。一个表中可以包含一个或多个Region。
每个Region只能被一个RS(RegionServer)提供服务,RS可以同时服务多个Region,来自不同RS上的Region组合成表格的整体逻辑视图。
Java中啥是可调用的?
【中文标题】Java中啥是可调用的?【英文标题】:What is callable in Java?Java中什么是可调用的? 【发布时间】:2014-09-16 23:14:20 【问题描述】:标题几乎概括了它。
我想知道 callable 的概念和思想。我已经阅读了question here 关于可调用和可运行之间的区别。但是没有人显示代码并详细说明什么是可调用对象。我不想知道它们之间的区别。我想知道,
什么是可调用对象?
何时使用它们以及如何使用它们。
当他们为 安卓。
【问题讨论】:
【参考方案1】:你可以查看这个example:
在此示例中,可调用任务在一秒后返回执行任务的线程的名称。我们正在使用 Executor 框架并行执行 100 个任务,并使用 Future 来获取提交任务的结果。
package com.journaldev.threads;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class MyCallable implements Callable<String>
@Override
public String call() throws Exception
Thread.sleep(1000);
//return the thread name executing this callable task
return Thread.currentThread().getName();
public static void main(String args[])
//Get ExecutorService from Executors utility class, thread pool size is 10
ExecutorService executor = Executors.newFixedThreadPool(10);
//create a list to hold the Future object associated with Callable
List<Future<String>> list = new ArrayList<Future<String>>();
//Create MyCallable instance
Callable<String> callable = new MyCallable();
for(int i=0; i< 100; i++)
//submit Callable tasks to be executed by thread pool
Future<String> future = executor.submit(callable);
//add Future to the list, we can get return value using Future
list.add(future);
for(Future<String> fut : list)
try
//print the return value of Future, notice the output delay in console
// because Future.get() waits for task to get completed
System.out.println(new Date()+ "::"+fut.get());
catch (InterruptedException | ExecutionException e)
e.printStackTrace();
//shut down the executor service now
executor.shutdown();
您也可以查看Using Callable to Return Results From Runnables
【讨论】:
当它们在 Android 上发挥作用时【参考方案2】:Callable 类似于 Runnable 但它返回一个结果并可能抛出异常。 当您希望异步任务返回结果时使用它们。
异步计算的返回结果用Future表示。
您可以查看这个使用FutureTask 实现的简单示例(它实现了RunnableFuture 和Future)
public static void main(String[] args)
// providing an anonymous callable to FutureTask
RunnableFuture<String> future = new FutureTask<String>(
new Callable<String>()
@Override
public String call() throws InterruptedException
System.out.println("sleeping");
Thread.sleep(2000);
System.out.println("returning");
return "hello-world";
);
Thread t = new Thread(future);
t.start();
try
// the get Waits if necessary for the computation to complete
System.out.println(future.get());
catch (InterruptedException | ExecutionException e)
e.printStackTrace();
【讨论】:
在运行未来任务的同一线程中等待有什么意义? get 调用等待直到结果可用或被中断、取消或发生某些计算异常。请注意,在调用 get 时(在 main 中),处理仍在发生/或已经完成(在线程“t”中)。 @Jimmy Lunceford,您可以与其他线程共享未来的 ref 并调用 get 到您那里,但这里的重点是演示它的作用。即使在这里,未来的任务也会在线程“t”而不是“main”中执行以上是关于hbase中啥是Region,啥是RegionServer的主要内容,如果未能解决你的问题,请参考以下文章