前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >webclient负载均衡踩坑

webclient负载均衡踩坑

作者头像
阿超
发布2024-01-10 09:39:31
1770
发布2024-01-10 09:39:31
举报
文章被收录于专栏:快乐阿超快乐阿超

一个人总免不了称为别人的对立面。——乔治·克列孟俊

今天踩坑

代码语言:javascript
复制
import cn.dev33.satoken.same.SaSameUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.reactive.function.client.WebClient;
import reactor.core.publisher.Mono;

/**
 * UserClient
 *
 * @author VampireAchao<achao @ hutool.cn>
 */
@Service
public class UserClient {

    private final WebClient webClient;

    @Autowired
    public UserClient(WebClient.Builder loadBalancedWebClientBuilder) {
        this.webClient = loadBalancedWebClientBuilder.baseUrl("http://user-service").build();
    }

    public Mono<Users> selectUserById(Object userId) {
        return webClient.get()
                .uri("/user/getUserBy/{userId}", userId)
                .headers(m -> {
                    m.add(SaSameUtil.SAME_TOKEN, SaSameUtil.getToken());
                })
                .retrieve().bodyToMono(String.class)
                .map(str -> JsonUtils.getResData(str, Users.class))
                .doOnError(Throwable::printStackTrace);
    }

}

这里是这么注入的:

代码语言:javascript
复制
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.reactive.function.client.WebClient;

@Configuration
public class WebClientConfig {

    @Bean
    public WebClient.Builder webClientBuilder() {
        return WebClient.builder();
    }

    @Bean("loadBalancedWebClientBuilder")
    @LoadBalanced
    public WebClient.Builder loadBalancedWebClientBuilder() {
        return WebClient.builder();
    }
}

看起来没问题,但是一直报错:

代码语言:javascript
复制
failed to resolve 'user-service' after 2 queries

然后排查了很久才发现是依赖没有引入…

代码语言:javascript
复制
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

这里因为看到了@LoadBalanced注解成功引入,所以先入为主认为依赖引入了,没有排查依赖,浪费了很久时间

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-01-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
负载均衡
负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档