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

龙元建设集团有限公司网站gridlocked wordpress

龙元建设集团有限公司网站,gridlocked wordpress,怎么创建音乐网站,网站能看出建设时间吗一、概念 使用springcloud将项目拆分成一个一个微服务之后#xff0c;微服务之间的接口调用就需要通过远程的方式实现#xff0c;这里将介绍springcloud提供的两个微服务组件来介绍如何进行微服务间的远程接口调用。 1、使用RestTEmplate LoadBalanced来实现远程接口调用及…一、概念 使用springcloud将项目拆分成一个一个微服务之后微服务之间的接口调用就需要通过远程的方式实现这里将介绍springcloud提供的两个微服务组件来介绍如何进行微服务间的远程接口调用。 1、使用RestTEmplate LoadBalanced来实现远程接口调用及负载均衡 RestTemplate的优点 支持多种HTTP方法RestTemplate支持常见的HTTP方法如GET、POST、PUT、DELETE等可以根据需要选择合适的方法来发送请求。提供丰富的请求和响应处理方法RestTemplate提供了多种方法来处理请求和响应如添加请求头、设置请求参数、发送请求、获取响应等。开发者可以根据需要选择合适的方法来处理HTTP请求和响应。支持请求和响应的序列化和反序列化RestTemplate可以将请求和响应的数据进行序列化和反序列化支持多种数据格式如JSON、XML等。开发者可以根据需要选择合适的序列化和反序列化方式。支持错误处理和异常处理RestTemplate可以处理HTTP请求过程中的错误和异常如连接超时、请求失败等。开发者可以根据需要进行错误处理和异常处理。可扩展性和定制化RestTemplate提供了一些扩展点和配置选项可以进行定制化配置。开发者可以根据需要进行扩展和定制以满足特定的业务需求。 但是RestTemplate没有负载均衡的功能所以需要配合LoadBalanced来实现负载均衡。 2、使用OpenFeign实现远程接口调用 openFeign的优点 声明式的API定义通过使用注解开发者可以定义和描述服务间的API接口包括请求方法、路径、参数、请求头等信息。这样可以使得服务间的调用代码更加简洁和易于维护。自动化的服务发现和负载均衡OpenFeign集成了服务注册中心可以自动发现和调用其他微服务。它还支持负载均衡可以根据配置的负载均衡策略选择合适的服务实例进行调用。内置的请求和响应拦截器OpenFeign提供了一些内置的拦截器可以在请求和响应的不同阶段进行拦截和处理。开发者可以自定义拦截器来实现日志记录、错误处理等功能。支持多种编码器和解码器OpenFeign支持多种编码器和解码器可以处理不同的数据格式如JSON、XML等。开发者可以根据需要选择合适的编码器和解码器。整合了Hystrix和RibbonOpenFeign与Hystrix和Ribbon等其他Spring Cloud组件集成可以实现服务的容错和熔断机制提高系统的可靠性和稳定性。 二、代码实现 1、前提 所有微服务使用springboot搭建并且使用springcloud的服务注册和发现服务这里我们使用的是consul 1、将服务注册到consul server:port: 80 spring:application:name: ordercloud:consul:host: 127.0.0.1port: 8500discovery:service-name: ${spring.application.name} 2、在启动类上添加注解开启服务发现 EnableDiscoveryClient 3、远程调用的接口 RestController Slf4j public class PayController {Resourceprivate PayService payService;Operation(summary 添加支付信息)PostMapping(value /pay/add)public ResultDate addPay(RequestBody PayDto payDto){Pay pay new Pay();BeanUtils.copyProperties(payDto,pay);pay.setDeleted((byte) 1);int add payService.add(pay);return ResultDate.success(add);} } 2、RestTemplate 1、导入依赖 dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-consul-discovery/artifactId/dependencydependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-loadbalancer/artifactId/dependency!--web actuator--dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependency 项目中使用了spring-boot-starter-dependencies所以没有配置版本号大家根据自己使用的springboot和springcloud版本进行配置即可。 2、使用loadBalanced进行负载均衡 Configuration public class RestTempConfig {BeanLoadBalancedpublic RestTemplate restTemplate(){return new RestTemplate();} } loadbalanced默认的负载均衡算法是通过轮询实现的底层是通过DiscoveryClient获取所有的微服务名返回的是个数组遍历数组即可找到对应的微服务同时可以根据微服务获取其在线实例数量最后使用循环取模的方法实现轮询。 springcloud为loadBalanced提供了两个负载均衡的算法除了轮询外还有随机算法默认使用的是轮询。 3、编写代码 RestController public class OrderController {public static final String PaymentSrv_URL http://cloud-payment-service; // public static final String PaymentSrv_URL http://localhost:8001;Resourceprivate RestTemplate restTemplate;GetMapping(/consumer/pay/add)public ResultDate addOrder(RequestBody PayDto payDto){ResultDate resultDate restTemplate.postForObject(PaymentSrv_URL /pay/add, payDto, ResultDate.class);return resultDate;} } 从这里我们可以看出使用restTemplate进行远程调用非常方便只需要调用对应的方法传入返回值类型和参数即可。 3、OpenFeign 1、导入依赖 !--openfeign--dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-openfeign/artifactId/dependencydependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-consul-discovery/artifactId/dependency 2、编写FeignClient接口 FeignClient(name cloud-payment-service) public interface PayFeignClient {PostMapping(value /pay/add)public ResultDate addPay(RequestBody PayDto payDto); } 使用feignClient进行远程接口调用只需要像声明函数是接口一样将需要调用的API进行申明再加上FeignClient注解即可 需要注意的是 FeignClient注解里面需要申明对应的微服务名与注册的服务名一致XXMapper的url路径要与调用接口的url一致需要注意我们可能在application.yaml里面配置了统一的请求头server.servlet.context-path或者在定义Controller时使用RequestMapper定义了统一的请求头地址接口定义时要与调用接口拥有相同的参数并且使用注解控制时需要指明例如使用RequestParem时就需要指定对应的参数名RequestParem(id) 3、使用FeignClient RestController public class OrderController {Resourceprivate PayFeignClient payFeignClient;PostMapping(/consumer/pay/add)public ResultDate addOrder(RequestBody PayDto payDto){return payFeignClient.addPay(payDto);} } 从代码上可以看出与RestTemplate比较OpenFeign的代码更为简洁使用起来更加方便并且OpenFeign自带负载均衡的功能不需要额外使用LoadBalanced实现负载均衡。所以更加推荐使用OpenFeign进行远程接口调用。
http://www.pierceye.com/news/739646/

相关文章:

  • 关于设计的网站免费注册公司
  • 网站建设排名北京网站排名降级的原因有哪些
  • 介绍网页设计做seo推广网站
  • 建立个人博客网站wordpress东城东莞网站建设
  • 从哪些方面建设网站泰州东方医院
  • 分类信息网站系统cmsWordPress新闻面包屑主题
  • wordpress 多标签关键字优化策略
  • idea15网站开发网站如何提升seo排名
  • 谁有网站推荐一下好安阳刚刚发生的事
  • 博客网站快速排名临邑县住房和城乡建设局网站
  • 二手网站建设方案营销网站建设服务平台
  • 遵化建设局网站濮阳新闻综合频道
  • 百度云如何做网站论文网站建设与运营
  • 网站开发环境实验报告注册公司流程和费用是多少
  • 下载一个网站学院网站建设的作用
  • 济南专业网站优化花西子的网络营销策略
  • 武城网站建设费用网页设计试题及答案
  • 郑州外贸网站建设公司搜索引擎排名的三大指标
  • 温州专业微网站制作电台 主题 wordpress
  • wordpress做网站过程阳江网上车管所
  • 网站抓取qq上海自贸区注册公司流程
  • 深圳网站设计推荐刻烟台制作网站有哪些
  • 网站注册系统源码卢松松博客源码 wordpress博客模板
  • 网站开发进阶实训报告廊坊安次区网站建设公司
  • jquery插件网站推荐打开网站自动跳转代码
  • 佛山顺德容桂网站制作写作平台
  • 网站源码下载pdf文件品质好房
  • 山网站建设长沙网站开发湖南微联讯点不错
  • 网站建设的方案模板邢台123今天的招聘信息
  • 一个网站做app网站如何做收款二维码