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


Java HostAndPort.fromParts方法代碼示例

本文整理匯總了Java中com.google.common.net.HostAndPort.fromParts方法的典型用法代碼示例。如果您正苦於以下問題:Java HostAndPort.fromParts方法的具體用法?Java HostAndPort.fromParts怎麽用?Java HostAndPort.fromParts使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.common.net.HostAndPort的用法示例。


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

示例1: createLeaderWrapper

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private boolean createLeaderWrapper(String leaderUrlStr) {
  try {
    URL tURL = new URL(leaderUrlStr);
    HostAndPort newLeader = HostAndPort.fromParts(tURL.getHost(), tURL.getPort());
    leaderUrlStr = newLeader.toString();
    if (leaderWrapper != null && leaderUrlStr.equals(leaderWrapper.getLeaderInfo())) {
      return true;
    }

    // create new Leader
    ManagedChannel clientChannel = session.getChannel(leaderUrlStr);
    leaderWrapper =
      new LeaderWrapper(
          leaderUrlStr,
          PDGrpc.newBlockingStub(clientChannel),
          PDGrpc.newStub(clientChannel),
          System.nanoTime());
  } catch (MalformedURLException e) {
    logger.error("Error updating leader.", e);
    return false;
  }
  logger.info(String.format("Switched to new leader: %s", leaderWrapper));
  return true;
}
 
開發者ID:pingcap,項目名稱:tikv-client-lib-java,代碼行數:25,代碼來源:PDClient.java

示例2: updateSeeds

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private void updateSeeds(ClusterConfig config) throws SyncException {
    List<String> hosts = new ArrayList<String>();
    for (Node n : config.getNodes()) {
        if (!config.getNode().equals(n)) {
            HostAndPort h = 
                    HostAndPort.fromParts(n.getHostname(), n.getPort());
            hosts.add(h.toString());
        }
    }
    Collections.sort(hosts);
    String seeds = Joiner.on(',').join(hosts);
    while (true) {
        try {
            Versioned<String> sv = unsyncStoreClient.get(SEEDS);
            if (sv.getValue() == null || !sv.getValue().equals(seeds)) {
                if (logger.isDebugEnabled()) {
                    logger.debug("[{}] Updating seeds to \"{}\" from \"{}\"", 
                                 new Object[]{config.getNode().getNodeId(),
                                              seeds, sv.getValue()});
                }
                unsyncStoreClient.put(SEEDS, seeds);
            }
            break;
        } catch (ObsoleteVersionException e) { }
    }
}
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:27,代碼來源:SyncStoreCCProvider.java

示例3: getReturnsPushGatewayProvider

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Test
public void getReturnsPushGatewayProvider() throws Exception {
    final MockWebServer server = new MockWebServer();
    server.enqueue(new MockResponse().setResponseCode(HttpURLConnection.HTTP_ACCEPTED));
    server.start();

    final MetricsPrometheusReporterConfiguration configuration = new MetricsPrometheusReporterConfiguration() {
        @Override
        public HostAndPort getAddress() {
            return HostAndPort.fromParts(server.getHostName(), server.getPort());
        }
    };
    final PushGatewayProvider provider = new PushGatewayProvider(configuration);
    final PushGateway pushGateway = provider.get();
    pushGateway.push(CollectorRegistry.defaultRegistry, "test");

    final RecordedRequest request = server.takeRequest();
    assertEquals("PUT", request.getMethod());
    assertEquals("/metrics/job/test", request.getPath());
    assertEquals("text/plain; version=0.0.4; charset=utf-8", request.getHeader("Content-Type"));
    assertEquals(0L, request.getBodySize());
}
 
開發者ID:graylog-labs,項目名稱:graylog-plugin-metrics-reporter,代碼行數:23,代碼來源:PushGatewayProviderTest.java

示例4: remoteDataSetTest

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Test
public void remoteDataSetTest() throws IOException {
    final int numCols = 3;
    final int size = 1000, resolution = 20;
    final SmallTable randTable = TestTables.getIntTable(size, numCols);
    RecordOrder cso = new RecordOrder();
    for (String colName : randTable.getSchema().getColumnNames()) {
        cso.append(new ColumnSortOrientation(randTable.getSchema().getDescription(colName), true));
    }
    final SampleQuantileSketch sqSketch = new SampleQuantileSketch(cso, resolution, size, 0);
    final HostAndPort h1 = HostAndPort.fromParts("127.0.0.1", 1234);
    final HillviewServer server1 = new HillviewServer(h1, new LocalDataSet<ITable>(randTable));
    try {
        final RemoteDataSet<ITable> rds1 = new RemoteDataSet<>(h1);
        final SampleList sl = rds1.blockingSketch(sqSketch);
        IndexComparator comp = cso.getComparator(sl.table);
        for (int i = 0; i < (sl.table.getNumOfRows() - 1); i++)
            assertTrue(comp.compare(i, i + 1) <= 0);
    } finally {
        server1.shutdown();
    }
}
 
開發者ID:vmware,項目名稱:hillview,代碼行數:23,代碼來源:TableDataSetTest.java

示例5: setupResourceTestRule

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private ResourceTestRule setupResourceTestRule() {
    _authIdentityManager = new InMemoryAuthIdentityManager<>();
    _authIdentityManager.createIdentity(UAC_ALL_API_KEY, new ApiKeyModification().addRoles("uac-all"));

    final EmoPermissionResolver permissionResolver = new EmoPermissionResolver(mock(DataStore.class), mock(BlobStore.class));
    final InMemoryPermissionManager permissionManager = new InMemoryPermissionManager(permissionResolver);
    _roleManager = new InMemoryRoleManager(permissionManager);

    LocalSubjectUserAccessControl uac = new LocalSubjectUserAccessControl(_roleManager, permissionResolver,
            _authIdentityManager, HostAndPort.fromParts("localhost", 8080), new MetricRegistry());
    
    createRole(_roleManager, null, "uac-all", ImmutableSet.of("role|*", "apikey|*"));
    createRole(_roleManager, null, "uac-none", ImmutableSet.of());

    return setupResourceTestRule(
            ImmutableList.of(
                    new UserAccessControlResource1(
                            new RoleResource1(uac),
                            new ApiKeyResource1(uac)),
                    new UserAccessControlRequestMessageBodyReader()),
            _authIdentityManager,
            permissionManager);
}
 
開發者ID:bazaarvoice,項目名稱:emodb,代碼行數:24,代碼來源:UserAccessControlJerseyTest.java

示例6: getHostAndPortFromConnectorFactories

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private HostAndPort getHostAndPortFromConnectorFactories(List<ConnectorFactory> connectors) {
    // find the first connector that matches and return it host/port information (in practice there should
    // be one, and just one, match)
    try {
        HttpConnectorFactory httpConnectorFactory = (HttpConnectorFactory) Iterables.find(connectors, Predicates.instanceOf(HttpConnectorFactory.class));

        String host = httpConnectorFactory.getBindHost();
        if (host == null) {
            host = getLocalHost().getHostAddress();
        }
        int port = httpConnectorFactory.getPort();
        return HostAndPort.fromParts(host, port);
    } catch (NoSuchElementException ex) {
        throw new IllegalStateException("Did not find a valid HttpConnector for the server", ex);
    }
}
 
開發者ID:bazaarvoice,項目名稱:emodb,代碼行數:17,代碼來源:SelfHostAndPortModule.java

示例7: updateSeeds

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private void updateSeeds(ClusterConfig config) throws SyncException {
    List<String> hosts = new ArrayList<String>();
    for (Node n : config.getNodes()) {
        if (!config.getNode().equals(n)) {
            HostAndPort h =
                    HostAndPort.fromParts(n.getHostname(), n.getPort());
            hosts.add(h.toString());
        }
    }
    Collections.sort(hosts);
    String seeds = Joiner.on(',').join(hosts);
    while (true) {
        try {
            Versioned<String> sv = unsyncStoreClient.get(SEEDS);
            if (sv.getValue() == null || !sv.getValue().equals(seeds)) {
                if (logger.isDebugEnabled()) {
                    logger.debug("[{}] Updating seeds to \"{}\" from \"{}\"",
                                 new Object[]{config.getNode().getNodeId(),
                                              seeds, sv.getValue()});
                }
                unsyncStoreClient.put(SEEDS, seeds);
            }
            break;
        } catch (ObsoleteVersionException e) { }
    }
}
 
開發者ID:zhenshengcai,項目名稱:floodlight-hardware,代碼行數:27,代碼來源:SyncStoreCCProvider.java

示例8: testProcessor

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private static int testProcessor(TProcessor processor, List<ToIntFunction<HostAndPort>> clients)
        throws Exception
{
    try (TServerSocket serverTransport = new TServerSocket(0)) {
        TProtocolFactory protocolFactory = new Factory();
        TTransportFactory transportFactory = new TFramedTransport.Factory();
        TServer server = new TSimpleServer(new Args(serverTransport)
                .protocolFactory(protocolFactory)
                .transportFactory(transportFactory)
                .processor(processor));

        Thread serverThread = new Thread(server::serve);
        try {
            serverThread.start();

            int localPort = serverTransport.getServerSocket().getLocalPort();
            HostAndPort address = HostAndPort.fromParts("localhost", localPort);

            int sum = 0;
            for (ToIntFunction<HostAndPort> client : clients) {
                sum += client.applyAsInt(address);
            }
            return sum;
        }
        finally {
            server.stop();
            serverThread.interrupt();
        }
    }
}
 
開發者ID:airlift,項目名稱:drift,代碼行數:31,代碼來源:TestApacheThriftMethodInvoker.java

示例9: testProcessor

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private static int testProcessor(TProcessor processor, List<ToIntFunction<HostAndPort>> clients)
        throws Exception
{
    try (TServerSocket serverTransport = new TServerSocket(0)) {
        TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();
        TTransportFactory transportFactory = new TFramedTransport.Factory();
        TServer server = new TSimpleServer(new Args(serverTransport)
                .protocolFactory(protocolFactory)
                .transportFactory(transportFactory)
                .processor(processor));

        Thread serverThread = new Thread(server::serve);
        try {
            serverThread.start();

            int localPort = serverTransport.getServerSocket().getLocalPort();
            HostAndPort address = HostAndPort.fromParts("localhost", localPort);

            int sum = 0;
            for (ToIntFunction<HostAndPort> client : clients) {
                sum += client.applyAsInt(address);
            }
            return sum;
        }
        finally {
            server.stop();
            serverThread.interrupt();
        }
    }
}
 
開發者ID:airlift,項目名稱:drift,代碼行數:31,代碼來源:TestDriftNettyMethodInvoker.java

示例10: testSingleDefault

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Test
public void testSingleDefault()
        throws Exception
{
    HostAndPort address = HostAndPort.fromParts("example.com", 1);
    testAddressSelector(simpleAddressSelector(address), ImmutableMap.of(), ImmutableList.of(address));

    testAddressSelector(
            simpleAddressSelector(address),
            ImmutableMap.of("testService" + ".thrift.client.addresses", "example.com:11,example.com:22"),
            ImmutableList.of(HostAndPort.fromParts("example.com", 11), HostAndPort.fromParts("example.com", 22)));
}
 
開發者ID:airlift,項目名稱:drift,代碼行數:13,代碼來源:TestSimpleAddressSelectorBinder.java

示例11: getAddress

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Override
public HostAndPort getAddress() {
  Preconditions.checkState(state() == State.RUNNING);
  return HostAndPort.fromParts(
      advertisedHostOverride.or(serverAddress.getHostText()),
      serverAddress.getPort());
}
 
開發者ID:PacktPublishing,項目名稱:Mastering-Mesos,代碼行數:8,代碼來源:JettyServerModule.java

示例12: createUrlAddress

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
/** Turns {@code address} into a more human readable form. */
static HostAndPort createUrlAddress(HostAndPort address) {
  if (address.getHost().equals("::") || address.getHost().equals("0.0.0.0")) {
    return address.getPortOrDefault(80) == 80
        ? HostAndPort.fromHost(getCanonicalHostName())
        : HostAndPort.fromParts(getCanonicalHostName(), address.getPort());
  } else {
    return address.getPortOrDefault(80) == 80 ? HostAndPort.fromHost(address.getHost()) : address;
  }
}
 
開發者ID:bazelbuild,項目名稱:rules_closure,代碼行數:11,代碼來源:NetworkUtils.java

示例13: testRedirectTargetNoAttribute

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Test
public void testRedirectTargetNoAttribute() throws Exception {
  HttpServletRequest mockRequest = mockRequest(null, null);

  replayAndMonitor(1);

  HostAndPort remote = HostAndPort.fromParts("foobar", HTTP_PORT);
  publishSchedulers(remote);

  assertEquals(
      Optional.of("http://foobar:500/some/path"),
      leaderRedirector.getRedirectTarget(mockRequest));
}
 
開發者ID:PacktPublishing,項目名稱:Mastering-Mesos,代碼行數:14,代碼來源:LeaderRedirectTest.java

示例14: testRedirectTargetWithAttribute

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
@Test
public void testRedirectTargetWithAttribute() throws Exception {
  HttpServletRequest mockRequest = mockRequest("/the/original/path", null);

  replayAndMonitor(1);

  HostAndPort remote = HostAndPort.fromParts("foobar", HTTP_PORT);
  publishSchedulers(remote);

  assertEquals(
      Optional.of("http://foobar:500/the/original/path"),
      leaderRedirector.getRedirectTarget(mockRequest));
}
 
開發者ID:PacktPublishing,項目名稱:Mastering-Mesos,代碼行數:14,代碼來源:LeaderRedirectTest.java

示例15: register

import com.google.common.net.HostAndPort; //導入方法依賴的package包/類
private static void register() {
    AgentClient agentClient = consul.agentClient();

    List<Registration.RegCheck> checks = new ArrayList<Registration.RegCheck>();

    HostAndPort serviceHostAndPort = HostAndPort.fromParts(visibleHost, visiblePort);

    Registration.RegCheck mainCheck = Registration.RegCheck.tcp(serviceHostAndPort.toString(), 30);

    checks.add(mainCheck);

    Registration registration = ImmutableRegistration
            .builder()
            .port(visiblePort)
            .address(visibleHost)
            .checks(checks)
            .name(serviceName)
            .id(serviceId)
            .addTags(tsdMode)
            .build();

    agentClient.register(registration);

    if (agentClient.isRegistered(serviceId)) {
        LOGGER.info("Registered this instance with Consul");
    } else {
        LOGGER.warn("Consul reports that this instance is not registered");
    }
}
 
開發者ID:inst-tech,項目名稱:opentsdb-plugins,代碼行數:30,代碼來源:ConsulPlugin.java


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