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


Java EurekaHttpResponse類代碼示例

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


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

示例1: testSimpleDiscovery

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Test
public void testSimpleDiscovery(){
    ArgumentCaptor<InstanceInfo> captor = ArgumentCaptor.forClass(InstanceInfo.class);

    EurekaHttpResponse<Applications> response = generateMockResponse(Collections.<InstanceInfo>emptyList());
    when(requestHandler.getApplications()).thenReturn(response);

    HazelcastInstance hz1 = factory.newHazelcastInstance();
    HazelcastInstance hz2 = factory.newHazelcastInstance();

    verify(requestHandler, timeout(5000).times(2)).register(captor.capture());
    response = generateMockResponse(captor.getAllValues());
    when(requestHandler.getApplications()).thenReturn(response);

    assertClusterSizeEventually(2, hz1);
    assertClusterSizeEventually(2, hz2);

    HazelcastInstance client = factory.newHazelcastClient();
    reset(requestHandler);
    when(requestHandler.getApplications()).thenReturn(response);
    verify(requestHandler, timeout(1000).times(0)).register(Matchers.<InstanceInfo>any());
    assertClusterSizeEventually(2, client);
}
 
開發者ID:hazelcast,項目名稱:hazelcast-eureka,代碼行數:24,代碼來源:HazelcastClientTestCase.java

示例2: testExternalRegistration

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Test
public void testExternalRegistration(){
    EurekaHttpResponse<Applications> response = generateMockResponse(Collections.<InstanceInfo>emptyList());
    when(requestHandler.getApplications()).thenReturn(response);

    Config config = new XmlConfigBuilder().build();
    DiscoveryConfig discoveryConfig = config.getNetworkConfig().getJoin().getDiscoveryConfig();
    DiscoveryStrategyConfig strategyConfig = discoveryConfig.getDiscoveryStrategyConfigs().iterator().next();
    strategyConfig.addProperty("self-registration", "false");

    HazelcastInstance hz1 = factory.newHazelcastInstance(config);
    HazelcastInstance hz2 = factory.newHazelcastInstance(config);

    assertClusterSizeEventually(2, hz1);
    assertClusterSizeEventually(2, hz2);

    verify(requestHandler, after(5000).never()).register(any(InstanceInfo.class));

}
 
開發者ID:hazelcast,項目名稱:hazelcast-eureka,代碼行數:20,代碼來源:HazelcastClientTestCase.java

示例3: testNamespaceRegistration

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Test
public void testNamespaceRegistration(){
    final String appName = "other";
    final String namespace = "hz";
    configure(namespace, appName);

    EurekaHttpResponse<Applications> response = generateMockResponse(Collections.<InstanceInfo>emptyList(), appName);
    when(requestHandler.getApplications()).thenReturn(response);

    Config config = new XmlConfigBuilder().build();
    DiscoveryConfig discoveryConfig = config.getNetworkConfig().getJoin().getDiscoveryConfig();
    DiscoveryStrategyConfig strategyConfig = discoveryConfig.getDiscoveryStrategyConfigs().iterator().next();
    strategyConfig.addProperty("namespace", namespace);

    HazelcastInstance hz1 = factory.newHazelcastInstance(config);

    assertClusterSizeEventually(1, hz1);

    ArgumentCaptor<InstanceInfo> captor = ArgumentCaptor.forClass(InstanceInfo.class);
    verify(requestHandler, timeout(5000).atLeastOnce()).register(captor.capture());

    String actual = captor.getValue().getAppName().toLowerCase();
    assertThat(actual, is(appName));

}
 
開發者ID:hazelcast,項目名稱:hazelcast-eureka,代碼行數:26,代碼來源:HazelcastClientTestCase.java

示例4: renew

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
/**
 * Renew with the eureka service by making the appropriate REST call
 */
public boolean renew(InstanceInfo instanceInfo) {
	EurekaHttpResponse<InstanceInfo> httpResponse;
	try {
		httpResponse = this.transport.getEurekaHttpClient().sendHeartBeat(instanceInfo.getAppName(), instanceInfo.getId(), instanceInfo, null);
		log.debug("EurekaLite_{}/{} - Heartbeat status: {}", instanceInfo.getAppName(), instanceInfo.getId(), httpResponse.getStatusCode());
		if (httpResponse.getStatusCode() == HttpStatus.NOT_FOUND.value()) {
			log.info("EurekaLite_{}/{} - Re-registering apps/{}", instanceInfo.getAppName(), instanceInfo.getId(), instanceInfo.getAppName());
			return register(instanceInfo);
		}
		return httpResponse.getStatusCode() == HttpStatus.OK.value();
	} catch (Exception e) {
		log.error("EurekaLite_"+instanceInfo.getAppName()+"/"+ instanceInfo.getId() + " - was unable to send heartbeat!", e);
		return false;
	}
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:19,代碼來源:Eureka.java

示例5: sendHeartBeat

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Override
public EurekaHttpResponse<InstanceInfo> sendHeartBeat(String appName, String id,
		InstanceInfo info, InstanceStatus overriddenStatus) {
	String urlPath = serviceUrl + "apps/" + appName + '/' + id + "?status="
			+ info.getStatus().toString() + "&lastDirtyTimestamp="
			+ info.getLastDirtyTimestamp().toString() + (overriddenStatus != null
					? "&overriddenstatus=" + overriddenStatus.name() : "");

	ResponseEntity<InstanceInfo> response = restTemplate.exchange(urlPath,
			HttpMethod.PUT, null, InstanceInfo.class);

	EurekaHttpResponseBuilder<InstanceInfo> eurekaResponseBuilder = anEurekaHttpResponse(
			response.getStatusCodeValue(), InstanceInfo.class)
					.headers(headersOf(response));

	if (response.hasBody())
		eurekaResponseBuilder.entity(response.getBody());

	return eurekaResponseBuilder.build();
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-netflix,代碼行數:21,代碼來源:RestTemplateEurekaHttpClient.java

示例6: getApplicationsInternal

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
private EurekaHttpResponse<Applications> getApplicationsInternal(String urlPath,
		String[] regions) {
	String url = serviceUrl + urlPath;

	if (regions != null && regions.length > 0)
		urlPath = (urlPath.contains("?") ? "&" : "?") + "regions="
				+ StringUtil.join(regions);

	ResponseEntity<EurekaApplications> response = restTemplate.exchange(url,
			HttpMethod.GET, null, EurekaApplications.class);

	return anEurekaHttpResponse(response.getStatusCodeValue(),
			response.getStatusCode().value() == HttpStatus.OK.value()
					&& response.hasBody() ? (Applications) response.getBody() : null)
							.headers(headersOf(response)).build();
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-netflix,代碼行數:17,代碼來源:RestTemplateEurekaHttpClient.java

示例7: testInstanceDown

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Test
public void testInstanceDown(){
    ArgumentCaptor<InstanceInfo> captor = ArgumentCaptor.forClass(InstanceInfo.class);

    EurekaHttpResponse<Applications> response = generateMockResponse(Collections.<InstanceInfo>emptyList());
    when(requestHandler.getApplications()).thenReturn(response);

    HazelcastInstance hz1 = factory.newHazelcastInstance();
    HazelcastInstance hz2 = factory.newHazelcastInstance();

    verify(requestHandler, timeout(5000).times(2)).register(captor.capture());
    response = generateMockResponse(captor.getAllValues());
    when(requestHandler.getApplications()).thenReturn(response);

    hz1.shutdown();

    ArgumentCaptor<String> id = ArgumentCaptor.forClass(String.class);
    verify(requestHandler, timeout(5000).times(1)).cancel(anyString(), id.capture());

    reset(requestHandler);
    for(InstanceInfo info : captor.getAllValues()){
        if(info.getId().equals(id.getValue())){
            captor.getAllValues().remove(info);
            break;
        }
    }

    response = generateMockResponse(captor.getAllValues());
    when(requestHandler.getApplications()).thenReturn(response);

    assertClusterSizeEventually(1, hz2);
}
 
開發者ID:hazelcast,項目名稱:hazelcast-eureka,代碼行數:33,代碼來源:HazelcastClientTestCase.java

示例8: generateMockResponse

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
private EurekaHttpResponse<Applications> generateMockResponse(List<InstanceInfo> infoList, String appName){

        Application application = new Application();
        application.setName(appName);
        for(InstanceInfo info : infoList){
            application.addInstance(info);
        }

        Applications applications = new Applications();
        applications.addApplication(application);

        return anEurekaHttpResponse(200, applications)
                .type(MediaType.APPLICATION_JSON_TYPE)
                .build();
    }
 
開發者ID:hazelcast,項目名稱:hazelcast-eureka,代碼行數:16,代碼來源:HazelcastClientTestCase.java

示例9: register

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
/**
 * Register with the eureka service by making the appropriate REST call.
 */
protected boolean register(InstanceInfo instanceInfo) {
	log.info("EurekaLite_{}/{}: registering service...", instanceInfo.getAppName(), instanceInfo.getId());
	EurekaHttpResponse<Void> httpResponse;
	try {
		httpResponse = this.transport.getEurekaHttpClient().register(instanceInfo);
	} catch (Exception e) {
		log.warn("EurekaLite_"+instanceInfo.getAppName()+"/"+ instanceInfo.getId() + " - registration failed " + e.getMessage(), e);
		throw e;
	}
	if (log.isInfoEnabled()) {
		log.info("EurekaLite_{}/{} - registration status: {}", instanceInfo.getAppName(), instanceInfo.getId(), httpResponse.getStatusCode());
	}
	return httpResponse.getStatusCode() == HttpStatus.NO_CONTENT.value();
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:18,代碼來源:Eureka.java

示例10: cancel

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
public void cancel(String appName, String instanceId) {
	try {
		EurekaHttpResponse<Void> httpResponse = this.transport.getEurekaHttpClient().cancel(appName, instanceId);
		log.info("EurekaLite_{}/{} - deregister  status: {}", appName, instanceId, httpResponse.getStatusCode());
	} catch (Exception e) {
		log.error("EurekaLite_"+appName+"/"+ instanceId + " - de-registration failed " + e.getMessage(), e);
	}
	this.transport.shutdown();
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:10,代碼來源:Eureka.java

示例11: getRegistration

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
public Registration getRegistration(String appName, String instanceId) {
	EurekaHttpResponse<InstanceInfo> response = this.transport.getEurekaHttpClient().getInstance(appName, instanceId);
	//TODO: error handling and logging
	InstanceInfo instanceInfo = response.getEntity();

	Registration registration = getRegistration(instanceInfo);
	return registration;
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:9,代碼來源:Eureka.java

示例12: getRegistrations

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
public List<Registration> getRegistrations(String appName) {
	EurekaHttpResponse<com.netflix.discovery.shared.Application> response = this.transport.getEurekaHttpClient().getApplication(appName);
	//TODO: error handling and logging
	com.netflix.discovery.shared.Application application = response.getEntity();

	return getRegistrations(application);
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:8,代碼來源:Eureka.java

示例13: getApplications

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
public Map<String, List<Registration>> getApplications() {
	//TODO: support regions
	EurekaHttpResponse<Applications> response = this.transport.getEurekaHttpClient().getApplications();
	List<com.netflix.discovery.shared.Application> applications = response.getEntity().getRegisteredApplications();
	LinkedHashMap<String, List<Registration>> map = new LinkedHashMap<>();

	for (com.netflix.discovery.shared.Application application : applications) {
		List<Registration> registrations = getRegistrations(application);
		map.put(application.getName(), registrations);
	}

	return map;
}
 
開發者ID:spencergibb,項目名稱:spring-cloud-netflix-eureka-lite,代碼行數:14,代碼來源:Eureka.java

示例14: getInstanceInfo

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
public InstanceInfo getInstanceInfo(String appname, String instanceId) {
	EurekaHttpResponse<InstanceInfo> response = getEurekaHttpClient().getInstance(appname, instanceId);
	HttpStatus httpStatus = HttpStatus.valueOf(response.getStatusCode());
	if (httpStatus.is2xxSuccessful() && response.getEntity() != null) {
		return response.getEntity();
	}
	return null;
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-netflix,代碼行數:9,代碼來源:CloudEurekaClient.java

示例15: register

import com.netflix.discovery.shared.transport.EurekaHttpResponse; //導入依賴的package包/類
@Override
public EurekaHttpResponse<Void> register(InstanceInfo info) {
	String urlPath = serviceUrl + "apps/" + info.getAppName();

	HttpHeaders headers = new HttpHeaders();
	headers.add(HttpHeaders.ACCEPT_ENCODING, "gzip");
	headers.add(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE);

	ResponseEntity<Void> response = restTemplate.exchange(urlPath, HttpMethod.POST,
			new HttpEntity<InstanceInfo>(info, headers), Void.class);

	return anEurekaHttpResponse(response.getStatusCodeValue())
			.headers(headersOf(response)).build();
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-netflix,代碼行數:15,代碼來源:RestTemplateEurekaHttpClient.java


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