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的主要内容,如果未能解决你的问题,请参考以下文章

Js中啥是对象,啥是方法

在这个用例中啥是数据仓库

Java中啥是可调用的?

在Java中啥是<>符号[重复]

spss单因素方差分析中啥是因子,啥是因变量

verilog hdl中啥是综合?啥是模拟?