IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Springcloud服务调用Feign组件以及负载均衡 -> 正文阅读

[Java知识库]Springcloud服务调用Feign组件以及负载均衡

前言

Ribbon是Spring Cloud的一个组件, 它可以让我们使用一个注解就能轻松的搞定负载均衡。
前边我们调用是从服务中获取实例获取调用的地址和端口,从而调用服务,这样特别麻烦,Feign是Spring Cloud提供的一个声明式的伪Http客户端, 它使得调用远程服务就像调用本地服务一样简单, 只需要创建一个接口并添加一个注解即可。Nacos很好的兼容了Feign, Feign默认集成了 Ribbon, 所以在Nacos下使用Fegin默认就实现了负载均衡的效果。

项目实战

随机获取服务调用

从上篇中,我们复制两个module改下端口,也可以IDEA中直接进行改端口运行两个服务。查看nacos查询服务。
module
启动成功之后,登录nacos进行查询服务。
nacos服务注册成功
此时我们在订单中进行调用product服务。
订单中代码,获取商品服务实例的列表,随机获取一个实例进行调用。

 //从nacos服务注册中心获取product服务
        List<ServiceInstance> productServiceInstanceList =  discoveryClient.getInstances("springcloud-product");
        int index = new Random().nextInt(productServiceInstanceList.size());
        ServiceInstance productServiceInstance =
                discoveryClient.getInstances("springcloud-product").get(index);
        String productUrl = productServiceInstance.getHost()+":"+productServiceInstance.getPort();
        log.info("获取到的商品实例的url:"+productUrl);
        Product product = restTemplate.getForObject("http://"+productUrl+"/springcloud/product/getProductById/"+order.getProductId(), Product.class);
        res.put("product",product);

调用结果

ribbon实现负载均衡

ribbon非常简单,直接在在RestTemplate 的生成方法上添加@LoadBalanced注解即可。

/**
 * 获取RestTemplate
 */
@Configuration
public class RestemplateConfig {
    @LoadBalanced
    @Bean
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}
访问日志可以看到ribbon相关的

日志
负载均衡策略接口类
负载均衡策略类

public interface IRule {
    Server choose(Object var1);

    void setLoadBalancer(ILoadBalancer var1);

    ILoadBalancer getLoadBalancer();
}

也可以自己定义负载均衡策略,配置一下ribbon负载均衡对应的类即可,这里就不多说。
具体的实现类

feign实现服务调用

引入feign组件依赖
    <!--fegin组件-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

启动类

@EnableDiscoveryClient
@SpringBootApplication
@EnableFeignClients//开启Fegin
public class SpringcloudOrderApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringcloudOrderApplication.class,args);
    }
}

product服务接口

@FeignClient("springcloud-product")
public interface ProductService {
    //指定调用提供者的哪个方法
    //@FeignClient+@GetMapping 就是一个完整的请求路径
    @GetMapping(value = "/springcloud/product/getProductById/{product_id}")
    Product getProductById(@PathVariable("product_id") Integer product_id);
}
@FeignClient("springcloud-user")
public interface UserService {
    @GetMapping(value = "/springcloud/user/getUserByUseId/{user_id}")
    User getUserByUseId(@PathVariable("user_id") Integer user_id);
}

controller测试类

@RestController
@RequestMapping("/springcloud/feign/order")
@Slf4j
public class OrderFeignController {

    @Autowired
    IOrderService orderService;
    @Autowired
    ProductService productService;
    @Autowired
    private UserService userService;
    /**
     * 获取订单列表
     * @return
     */
    @GetMapping("/getOrderById/{order_id}")
    public HashMap<String,Object> getOrderById(@PathVariable("order_id")Integer order_id){
        HashMap<String,Object> res = new HashMap<>();
        //获取订单
        Order order = orderService.getById(order_id);
        res.put("order",order);
        //直接使用服务名字作为URL进行调用
        //获取用户
        User user = userService.getUserByUseId(order.getUserId());
        res.put("user",user);
        //获取商品信息
        Product product = productService.getProductById(order.getProductId());
        res.put("product",product);
        return res;
    }

}

测试

测试

日志

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-09-13 10:59:34  更:2022-09-13 10:59:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 12:10:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码