当前位置: 首页 > news >正文

电子邮箱网站建设大数据平台

电子邮箱网站建设,大数据平台,网站用什么框架做,政法委网站建设背景目录前言SpringCloud Feign远程服务调用一.远程调用逻辑图二.两个服务的yml配置和访问路径三.使用RestTemplate远程调用四.构建Feign五.自定义Feign配置六.Feign配置日志七.Feign调优八.抽离Feign前言 微服务分解成多个不同的服务,那么多个服务之间怎么调用呢&…

目录

  • 前言
  • SpringCloud Feign远程服务调用
    • 一.远程调用逻辑图
    • 二.两个服务的yml配置和访问路径
    • 三.使用RestTemplate远程调用
    • 四.构建Feign
    • 五.自定义Feign配置
    • 六.Feign配置日志
    • 七.Feign调优
    • 八.抽离Feign

前言

微服务分解成多个不同的服务,那么多个服务之间怎么调用呢?
Spring Cloud最新面试题
Spring Cloud Nacos详解之注册中心
Spring Cloud Nacos详解之配置中心
Spring Cloud Nacos详解之集群配置
Spring Cloud Eureka详解
Spring Cloud Ribbon详解
Spring Cloud Gateway详解
Spring Cloud Hystrix详解

SpringCloud Feign远程服务调用

一.远程调用逻辑图

现在有两个服务,订单服务(服务消费者)和用户服务(服务提供者),分别对应不同的数据库。
注意: 因为远程调用都是服务消费者调用服务提供者,所以配置和业务编写,都在服务消费者里面。
在这里插入图片描述

二.两个服务的yml配置和访问路径

用两个不同的数据库,模拟部署在两台服务器的数据库订单yml配置   访问路径:@GetMapping("order/{orderId}")
server:port: 8082
spring:datasource:url: jdbc:mysql://localhost:3306/cloud_order?useSSL=falseusername: rootpassword: rootdriver-class-name: com.mysql.jdbc.Driverapplication:name: orderservice //订单服务的名称用户yml配置  访问路径:@GetMapping("user/{id}")
server:port: 8081
spring:datasource:url: jdbc:mysql://localhost:3306/cloud_user?useSSL=falseusername: rootpassword: rootdriver-class-name: com.mysql.jdbc.Driverapplication:name: userservice //用户服务的名称

三.使用RestTemplate远程调用

1.注入RestTemplate

	/*** 因为启动类本身也是一个配置了,所以我们在启动类进行注入,你自己自定义配置类注入也行* 创建RestTemplate并注入Spring容器*/@Bean@LoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}

2.编写远程调用

@Autowiredprivate RestTemplate restTemplate;public Order queryOrderById(Long orderId) {// 根据订单id查询订单Order order = orderMapper.findById(orderId);// 利用RestTemplate发起http请求,根据用户id查询用户// url路径  http://服务名称(上面配置了)/请求路径/参数String url = "http://localhost:8081/user/" + order.getUserId();// 发送http请求,实现远程调用,现在是get请求类型User user = restTemplate.getForObject(url, User.class);// 封装user到Orderorder.setUser(user);// 返回值return order;}

3.RestTemplate的缺点

  • 参数复杂URL难以维护。
  • 不符合正常接口调用的格式。

四.构建Feign

1.引入依赖

		<!--feign客户端依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency>

2.在启动类使用注解开启Feign功能

@SpringBootApplication
@EnableFeignClients
public class OrderApplication {
}

3.编写远程调用

//服务名称
@FeignClient(value = "userservice")
public interface UserClient {@GetMapping("/user/{id}")User findById(@PathVariable("id") Long id);}

4.调用接口

@Autowiredprivate UserClient userClient;public Order queryOrderById(Long orderId) {// 根据订单id查询订单Order order = orderMapper.findById(orderId);// 用Feign远程调用User user = userClient.findById(order.getUserId());// 封装user到Orderorder.setUser(user);// 返回return order;}

5.Feign还集成了Ribbon,所以我们不用考虑负载均衡问题

在这里插入图片描述

五.自定义Feign配置

类型作用说明
feign.Logger.Level修改日志级别四种不同的级别:NONE(没有任何日志)、BASIC(发起请求的开始结束时间)、HEADERS(会记录请求头请求体)、FULL(请求和响应信息)
feign.codec.Decoder响应结果的解析器http远程调用的结果做解析,例如解析json字符串为java对象
feign.codec.Encoder请求参数编码将请求参数编码,便于通过http请求发送
feign. Contract支持的注解格式默认是SpringMVC的注解
feign. Retryer失败重试机制请求失败的重试机制,默认是没有,不过会使用Ribbon的重试

一般我们自定义配置的是日志

六.Feign配置日志

1.配置文件配置日志

//全局配置
feign:client:config:default://default全局配置,远程调用的服务的接口也会打印。loggerLevel:FULL //日志级别//局部配置
feign:client:config:orderservice://只打印服务名为orderservice的日志。loggerLevel:FULL //日志级别

2.代码方式配置日志

//第一步:注入对象
public class DefaultFeignConfiguration {@Beanpublic Logger.Level logLevel(){//日志级别return Logger.Level.BASIC;}
}
//第二步:注解配置//全局配置
@EnableFeignClients(defaultConfiguration = DefaultFeignConfiguration.class)//局部配置
@FeignClient(value = "userservice",confiquration = FeignClientConfiguration.class)

七.Feign调优

Feign底层客户端实现:

  • URLConnection:默认实现,不支持连接池。
  • Apache HttpClient: 支持连接池。
  • OKHttp:支持连接池。

1.使用连接池替代默认的URL Connection(使用HttpClient支持)

①pom文件引入依赖

	    <!--引入HttpClient依赖--><dependency><groupId>io.github.openfeign</groupId><artifactId>feign-httpclient</artifactId></dependency>

②yml文件进行配置

feign:httpclient:enabled: true # 支持HttpClient的开关max-connections: 100 # 最大连接数max-connections-per-route: 25 # 单个路径的最大连接数

2.日志级别最好是basic或none

八.抽离Feign

如果A、B、C服务都要调用D服务,那我们要在A、B、C里面都使用Feign调用D吗,如果写就造成了很多代码冗余,所以我们要把Feign抽离出来放在一个公共的服务里面。我们新建一个Feign-api服务,然后谁用谁就在pom文件引入一下。

注意: 需要把调用的接口(加上@FeignClient(vaule=服务名)注解)和实体类写在公共的服务里面。

Feign-api结构目录
在这里插入图片描述

		<!--谁用谁引入,引入feign的统一api--><dependency><groupId>cn.xinxin.demo</groupId><artifactId>feign-api</artifactId><version>1.0</version></dependency>

但是这样做会导致SpringBootApplication在扫描包时找不到定义FeignClient对象,那么怎么解决呢?

解决

方式一:指定FeignClient所在包
@EnableFeignClients(basePackages = "cn.xinxin.feign.clients")方式二:指定FeignClient字节码
EnableFeignClients(clients = {UserClient.class})

Feign的pom文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>cloud-demo</artifactId><groupId>cn.xinxin.demo</groupId><version>1.0</version></parent><modelVersion>4.0.0</modelVersion><artifactId>feign-api</artifactId><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><!--feign客户端依赖--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency></dependencies>
</project>

示例: 订单服务远程调用用户服务
在这里插入图片描述

http://www.mmbaike.com/news/35405.html

相关文章:

  • 甘肃网站定制开发sem和seo是什么
  • 湖南省建设厅208号文seo技巧是什么意思
  • 购物网站页面设计图片百度小说排行榜2019
  • 专门做狗猫配套网站有什么意思我想创建一个网络平台
  • 自己做网站需不需要钱搜狗推广助手
  • 有哪些设计网站央视新闻
  • 湖南环保设备公司中企动力网站建设技术支持如何推广自己成为网红
  • 房地产公司网站建设与推广方案什么是网站优化
  • 什么网站可以做二建的题目海南百度推广公司电话
  • 摄影作品网站源码seo免费推广软件
  • wordpress无法访问图片株洲百度seo
  • 商城网站建设视频网站推广优化的原因
  • 门户网站制作平台好的营销网站
  • 图书馆网站建设海外推广专员
  • 精品课程网站开发项目石家庄关键词优化软件
  • 阿里巴巴上怎样做自己的网站西安抖音seo
  • 建设用地规划许可证查询网站近期时事新闻10条
  • 如何与知名网站做友情链接湖南网络优化服务
  • java网站开发思维导图售卖链接
  • 张家界工程建设信息网站搜索引擎优化网页
  • 2023今日新闻头条白山seo
  • 网站建设方案目录seo 公司
  • 广州网站制域名网站查询
  • 成都个人网站开发互联网营销师培训内容
  • 网站做seo推广信息流广告哪个平台好
  • 开源网站代码如何做seo搜索优化
  • 哪些网站使用wordpressgoogle本地搜索
  • 外国网站 icp备案单页网站模板
  • 网站建设维护面试seo是什么字
  • wordpress点文字弹出层搜索引擎优化seo应用