1. 程式人生 > >springcloud服務呼叫其它服務介面例項及ribbon均衡負載

springcloud服務呼叫其它服務介面例項及ribbon均衡負載

建立服務註冊中心(埠:8000)並啟動

建立被呼叫的服務A(埠8010,服務名:service-hi)並編寫controller/action將相關方法暴露出來 如下:

package com.ldcn.cloudsd.controllers;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


@RestController
public class BizController {

    @Value("${server.port}")
    String port;
	
    @RequestMapping("/hi")
    public String home() {
        return "hi,i am from port:" +port;
    }
    
}

服務A的一個訪問controller/action地址為:localhost:8010/hi 返回一個字串  準備被呼叫

建立被呼叫服務B(埠8011,服務名:service-hi)並編寫controller/action同上

服務B的一個訪問controller/action地址為:localhost:8011/hi 返回一個字串  準備被呼叫

啟動服務A和服務B,此時springcloud註冊中心可以看service-hi服務8010和8011的2個例項


建立另一個服務ribbon(埠:8013)註冊到註冊中心,準備呼叫服務A或B的hi返回的字串:

服務ribbon編寫一個介面 如下:

package com.ldcn.cloudsd.callservice;

import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestMapping;

@Component
@FeignClient(value="SERVICE-HI")
public interface CallClientService {

	@RequestMapping(value="/hi")
	public String getClientString();
}

@FeignClient(value="SERVICE-HI")   value為呼叫的服務名 即application.properties/yml配置裡spring.application.name=xxx的配置

介面方法上面@RequestMapping(value="/hi")為service-hi服務的controller/action訪問地址

服務ribbon編寫controller/action呼叫剛剛編寫的介面 :

package com.ldcn.cloudsd.controllers;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.ldcn.cloudsd.callservice.CallClientService;


@RestController
public class BizController {

	@Autowired
	CallClientService callClientService;
	
    @RequestMapping("/call")
    public String home() {
        return callClientService.getClientString();
    }
}

啟動服務ribbon,並訪問服務ribbon的地址localhost:8013/call並不斷重新整理,瀏覽器依次出現如下結果:

呼叫8010:

呼叫8011:


注意

服務ribbon啟動類需要新增如下註解

@EnableFeignClients

同時需引入以下jar包

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-feign</artifactId>
</dependency>