小编Gab*_*.ge的帖子

如何通过假装在春天的云中调整负载平衡规则

据我所知,假装包括功能区,我在我的代码中证明了这一点.

当我使用假装时,默认规则是循环规则.但是如何在我的假装客户端代码中更改规则,功能区是唯一的方法吗?

以下是我的代码,请帮忙.

ConsumerApplication.java

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableCircuitBreaker
public class ConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}
Run Code Online (Sandbox Code Playgroud)

UserFeignClient .java

@FeignClient(name = "cloud-provider", fallback = UserFeignClient.HystrixClientFallback.class)
public interface UserFeignClient {
    @RequestMapping("/{id}")
    BaseResponse findByIdFeign(@RequestParam("id") Long id);

    @RequestMapping("/add")
    BaseResponse addUserFeign(UserVo userVo);

    @Component
    class HystrixClientFallback implements UserFeignClient {
        private static final Logger LOGGER = LoggerFactory.getLogger(HystrixClientFallback.class);

        @Override
        public BaseResponse findByIdFeign(@RequestParam("id") Long id) {
            BaseResponse response = new BaseResponse();
            response.setMessage("disable");
            return response;
        }

        @Override
        public BaseResponse addUserFeign(UserVo userVo) {
            BaseResponse response …
Run Code Online (Sandbox Code Playgroud)

spring spring-cloud netflix-feign netflix-ribbon

4
推荐指数
1
解决办法
2827
查看次数

Spring Cloud配置假装回退(CircuitBreaker)规则

现在,我将伪装与hystrix一起使用,事实证明,回退方法在5秒钟内调用20次后,Circuit将变为Open状态。如何更改此规则。例如,当回退方法在5秒钟内调用50次或以回退回调率调用时,让Circuit状态打开。这是我主要的Java代码。

ConsumerApplication.java

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
@EnableCircuitBreaker
@RibbonClients({@RibbonClient(name = "cloud-provider", configuration = CloudProviderConfiguration.class)})
public class ConsumerApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class, args);
    }
}
Run Code Online (Sandbox Code Playgroud)

UserFeignClient.java

@FeignClient(name = "cloud-provider", fallback = UserFeignClient.HystrixClientFallback.class)
public interface UserFeignClient {
    @RequestMapping("/{id}")
    BaseResponse findByIdFeign(@RequestParam("id") Long id);

    @RequestMapping("/add")
    BaseResponse addUserFeign(UserVo userVo);

    @Component
    class HystrixClientFallback implements UserFeignClient {
        private static final Logger LOGGER = LoggerFactory.getLogger(HystrixClientFallback.class);

        @Override
        public BaseResponse findByIdFeign(@RequestParam("id") Long id) {
            BaseResponse response = new BaseResponse();
            response.setMessage("disable!!!!");
            return response;
        }

        @Override
        public BaseResponse addUserFeign(UserVo userVo) …
Run Code Online (Sandbox Code Playgroud)

hystrix spring-cloud spring-cloud-feign spring-cloud-netflix

3
推荐指数
1
解决办法
2480
查看次数