當前位置: 首頁>>代碼示例>>Java>>正文


Java ThriftClientManager類代碼示例

本文整理匯總了Java中com.facebook.swift.service.ThriftClientManager的典型用法代碼示例。如果您正苦於以下問題:Java ThriftClientManager類的具體用法?Java ThriftClientManager怎麽用?Java ThriftClientManager使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ThriftClientManager類屬於com.facebook.swift.service包,在下文中一共展示了ThriftClientManager類的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
/** 
 * @param args 
 */  
public static void main(String[] args) throws Exception {  
	/**
    TTransport transport = new TSocket("localhost", 8080);  
    transport.open();  
    TProtocol protocol = new TBinaryProtocol(transport);  
    ThriftTestService.Client client = new ThriftTestService.Client(protocol);  
    System.out.println(client.test("name"));  
    transport.close();  **/
	InMemoryScribe client;
	ThriftCodecManager thriftCodecManager = new ThriftCodecManager();
	HttpClientConnector connector = new HttpClientConnector(URI.create("http://localhost:" + 8080 +"/scribe"));

    ThriftClientManager clientManager = new ThriftClientManager(thriftCodecManager);
    client = clientManager.createClient(connector, InMemoryScribe.class).get();
    List<LogEntry> msgs = new ArrayList<LogEntry>();
    String name = client.log(msgs);
    System.out.println("name: "+ name);
}
 
開發者ID:tiaoling,項目名稱:high,代碼行數:22,代碼來源:Client.java

示例2: testNonExistent

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testNonExistent() throws Exception
{
    final int port = NetUtils.findUnusedPort();

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig()
        .setPort(port)
        .setMaxRetries(5)
        .setRetrySleep(new Duration(1, TimeUnit.SECONDS))
        .setRetryTimeout(new Duration(30, TimeUnit.SECONDS));

    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final ThriftClientConfig clientConfig = new ThriftClientConfig();
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            assertFalse(metastore.isConnected());
            metastore.getTable("hello", "world");
            fail();
        }
        catch (TTransportException te) {
            assertEquals(TTransportException.UNKNOWN, te.getType());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:26,代碼來源:TestRetryingHiveMetastore.java

示例3: testSimple

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testSimple() throws Exception
{
    final int port = NetUtils.findUnusedPort();

    startService(port);

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig().setPort(port);
    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final ThriftClientConfig clientConfig = new ThriftClientConfig();
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            final Table table = metastore.getTable("hello", "world");
            assertNotNull(table);
            assertEquals("hello", table.getDbName());
            assertEquals("world", table.getTableName());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:21,代碼來源:TestHiveMetastoreClient.java

示例4: testLateConnectIsOk

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testLateConnectIsOk() throws Exception
{
    final int port = NetUtils.findUnusedPort();

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig().setPort(port);
    final ThriftClientConfig clientConfig = new ThriftClientConfig();
    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            assertFalse(metastore.isConnected());
        }

        startService(port);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            final Table table = metastore.getTable("hello", "world");
            assertNotNull(table);
            assertEquals("hello", table.getDbName());
            assertEquals("world", table.getTableName());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:25,代碼來源:TestHiveMetastoreClient.java

示例5: main

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
public static void main(String[] args) throws ExecutionException, InterruptedException, IllegalAccessException, NoSuchMethodException, InvocationTargetException {
       ThriftClientManager clientManager = new ThriftClientManager();
       FramedClientConnector connector = new FramedClientConnector(new InetSocketAddress("localhost",8899));
       ThirdPartyCollectionService scribe = clientManager.createClient(connector, ThirdPartyCollectionService.class).get();
       //scribe.getAll();
       ThirdPartyCollection collection =
               new ThirdPartyCollection(1001, "2014-08-29");
       ThirdPartyCollection co2 = scribe.save(collection);
       System.out.println("c:"+ co2.getId());
       System.out.println("c:"+ co2.getDate());
}
 
開發者ID:tiaoling,項目名稱:high,代碼行數:12,代碼來源:TheAppClient.java

示例6: setUp

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Before
public void setUp() throws Exception {
    HttpClientConnector connector = new HttpClientConnector(URI.create("http://localhost:" + port + "/thrift/"));

    ThriftClientManager clientManager = new ThriftClientManager(thriftCodecManager);
    client = clientManager.createClient(connector, TCalculatorService.class).get();
}
 
開發者ID:tiaoling,項目名稱:high,代碼行數:8,代碼來源:CalculatorApplicationTest.java

示例7: setUp

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
/** Sets up clients before each benchmark */
private void setUp() throws Exception {
  try {
    fileSystem = (DistributedFileSystem) FileSystem.get(
        StorageServiceConfigKeys.translateToOldSchema(conf, nameserviceId), conf);
    InetSocketAddress nameNodeAddr = fileSystem.getClient().getNameNodeAddr();
    metaInfo = new RequestMetaInfo(clusterId, nameserviceId, RequestMetaInfo.NO_NAMESPACE_ID,
        RequestMetaInfo.NO_APPLICATION_ID, (UnixUserGroupInformation) UserGroupInformation.getUGI(
        this.conf));

    directClientProtocol = RPC.getProxy(ClientProtocol.class, ClientProtocol.versionID,
        nameNodeAddr, conf);

    directClientProxyProtocol = RPC.getProxy(ClientProxyProtocol.class,
        ClientProxyProtocol.versionID, nameNodeAddr, conf);

    clientManager = new ThriftClientManager();
    FramedClientConnector connector = new FramedClientConnector(HostAndPort.fromParts(
        proxyHostname, proxyPortThrift));
    proxyTClientProxyProtocol = clientManager.createClient(connector, TClientProxyProtocol.class)
        .get();

    proxyClientProxyProtocol = RPC.getProxy(ClientProxyProtocol.class,
        ClientProxyProtocol.versionID, new InetSocketAddress(proxyHostname, proxyPortRPC), conf);

    fileSystem.mkdirs(new Path(ROOT));
  } catch (Exception e) {
    tearDown();
    throw e;
  }
}
 
開發者ID:rhli,項目名稱:hadoop-EAR,代碼行數:32,代碼來源:NNLatencyBenchmark.java

示例8: setUp

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Before
public void setUp() throws Exception {
  try {
    Configuration conf = new Configuration();
    // Bind ports automatically
    conf.setInt(StorageServiceConfigKeys.PROXY_THRIFT_PORT_KEY, 0);
    conf.setInt(StorageServiceConfigKeys.PROXY_RPC_PORT_KEY, 0);

    cluster = new MiniAvatarCluster(conf, 2, true, null, null, 1, true);
    fs = cluster.getFileSystem(0);

    metaInfo = new RequestMetaInfo(conf.getInt(FSConstants.DFS_CLUSTER_ID,
        RequestMetaInfo.NO_CLUSTER_ID), cluster.getNameNode(0).getNameserviceId(),
        RequestMetaInfo.NO_NAMESPACE_ID, RequestMetaInfo.NO_APPLICATION_ID,
        (UnixUserGroupInformation) UserGroupInformation.getUGI(conf));

    proxy = new ClientProxyService(new ClientProxyCommons(conf, conf.get(
        FSConstants.DFS_CLUSTER_NAME)));
    conf.setInt(StorageServiceConfigKeys.PROXY_THRIFT_PORT_KEY, proxy.getThriftPort());
    conf.setInt(StorageServiceConfigKeys.PROXY_RPC_PORT_KEY, proxy.getRPCPort());

    clientManager = new ThriftClientManager();
    FramedClientConnector connector = new FramedClientConnector(
        StorageServiceConfigKeys.getProxyThriftAddress(conf));
    clientThrift = clientManager.createClient(connector, TClientProxyProtocol.class).get();

    clientRPC = RPC.getProxy(ClientProxyProtocol.class, ClientProxyProtocol.versionID,
        StorageServiceConfigKeys.getProxyRPCAddress(conf), conf);
  } catch (IOException e) {
    tearDown();
    throw e;
  }
}
 
開發者ID:rhli,項目名稱:hadoop-EAR,代碼行數:34,代碼來源:TestClientProxyService.java

示例9: HiveMetaStoreClient

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
public HiveMetaStoreClient(HiveConf conf)
    throws MetaException
{
    this.thriftClientManager = closer.register(new ThriftClientManager());

    if (conf == null) {
        conf = new HiveConf(HiveMetaStoreClient.class);
    }
    this.conf = conf;

    String msUri = conf.getVar(HiveConf.ConfVars.METASTOREURIS);
    if (msUri == null || msUri.trim().length() == 0) {
        throw new MetaException("Local metastore is not supported!");
    }

    if (conf.getBoolVar(ConfVars.METASTORE_USE_THRIFT_SASL)) {
        throw new MetaException("SASL is not supported");
    }

    // get the number retries
    this.retries = HiveConf.getIntVar(conf, HiveConf.ConfVars.METASTORETHRIFTCONNECTIONRETRIES);
    this.retryDelaySeconds = conf.getIntVar(ConfVars.METASTORE_CLIENT_CONNECT_RETRY_DELAY);

    // user wants file store based configuration
    List<String> metastoreUris = ImmutableList.copyOf(Splitter.on(',').omitEmptyStrings().trimResults().split(msUri));

    metastoreHosts = new HostAndPort [metastoreUris.size()];

    for (int i = 0; i < metastoreUris.size(); i++) {
        URI uri = URI.create(metastoreUris.get(i));
        if (!uri.getScheme().equals("thrift")) {
            throw new MetaException("Only thrift:// URIs are supported!");
        }
        metastoreHosts[i] = HostAndPort.fromParts(uri.getHost(), uri.getPort());
    }

    // finally open the store
    open();
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:40,代碼來源:HiveMetaStoreClient.java

示例10: SimpleHiveMetastoreFactory

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
public SimpleHiveMetastoreFactory(final ThriftClientManager thriftClientManager,
                                  final ThriftClientConfig thriftClientConfig,
                                  final HiveMetastoreClientConfig hiveMetastoreClientConfig)
{
    super(hiveMetastoreClientConfig,
          new ThriftClient<>(checkNotNull(thriftClientManager, "thiftClientManager is null"),
                             HiveMetastore.class,
                             checkNotNull(thriftClientConfig, "thriftClientConfig is null"),
                             "hive-metastore"));
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:11,代碼來源:SimpleHiveMetastoreFactory.java

示例11: testExisting

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testExisting() throws Exception
{
    final int port = NetUtils.findUnusedPort();

    startService(port);

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig()
        .setPort(port)
        .setMaxRetries(5)
        .setRetrySleep(new Duration(1, TimeUnit.SECONDS))
        .setRetryTimeout(new Duration(30, TimeUnit.SECONDS));

    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final ThriftClientConfig clientConfig = new ThriftClientConfig();
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            assertFalse(metastore.isConnected());

            final Table table = metastore.getTable("hello", "world");
            assertNotNull(table);
            assertEquals("hello", table.getDbName());
            assertEquals("world", table.getTableName());

            assertTrue(metastore.isConnected());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:30,代碼來源:TestRetryingHiveMetastore.java

示例12: testLate

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testLate() throws Exception
{
    final int port = NetUtils.findUnusedPort();


    runner.schedule(new Runnable() {
        @Override
        public void run() {
            try {
                startService(port);
            }
            catch (Exception e) {
                fail(e.getMessage());
            }
        }
    }, 10, TimeUnit.SECONDS);

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig()
        .setPort(port)
        .setMaxRetries(5)
        .setRetrySleep(new Duration(5, TimeUnit.SECONDS))
        .setRetryTimeout(new Duration(30, TimeUnit.SECONDS));

    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final ThriftClientConfig clientConfig = new ThriftClientConfig();
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getDefaultClient()) {
            assertFalse(metastore.isConnected());

            final Table table = metastore.getTable("hello", "world");
            assertNotNull(table);
            assertEquals("hello", table.getDbName());
            assertEquals("world", table.getTableName());

            assertTrue(metastore.isConnected());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:41,代碼來源:TestRetryingHiveMetastore.java

示例13: testLetsShuffleOne

import com.facebook.swift.service.ThriftClientManager; //導入依賴的package包/類
@Test
public void testLetsShuffleOne() throws Exception
{
    final int port = NetUtils.findUnusedPort();

    final ImmutableSet.Builder<HostAndPort> builder = ImmutableSet.builder();
    builder.add(HostAndPort.fromParts("localhost", port));

    for (int i = 0; i < 3; i++) {
        builder.add(HostAndPort.fromParts("localhost", NetUtils.findUnusedPort()));
    }

    runner.schedule(new Runnable() {
        @Override
        public void run() {
            try {
                startService(port);
            }
            catch (Exception e) {
                fail(e.getMessage());
            }
        }
    }, 10, TimeUnit.SECONDS);

    final HiveMetastoreClientConfig metastoreConfig = new HiveMetastoreClientConfig()
        .setMaxRetries(10)
        .setRetrySleep(new Duration(3, TimeUnit.SECONDS))
        .setRetryTimeout(new Duration(45, TimeUnit.SECONDS));

    try (final ThriftClientManager clientManager = new ThriftClientManager()) {
        final ThriftClientConfig clientConfig = new ThriftClientConfig();
        final HiveMetastoreFactory factory = new SimpleHiveMetastoreFactory(clientManager, clientConfig, metastoreConfig);

        try (final HiveMetastore metastore = factory.getClientForHost(builder.build())) {
            assertFalse(metastore.isConnected());

            final Table table = metastore.getTable("hello", "world");
            assertNotNull(table);
            assertEquals("hello", table.getDbName());
            assertEquals("world", table.getTableName());

            assertTrue(metastore.isConnected());
        }
    }
}
 
開發者ID:facebookarchive,項目名稱:swift-hive-metastore,代碼行數:46,代碼來源:TestRetryingHiveMetastore.java


注:本文中的com.facebook.swift.service.ThriftClientManager類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。