springcloud服務呼叫其它服務介面例項及ribbon均衡負載
阿新 • • 發佈:2019-01-28
建立服務註冊中心(埠: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>