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

做网站赚钱吗 谁教教我vs2013 手机网站开发

做网站赚钱吗 谁教教我,vs2013 手机网站开发,中信建设 官方网站,团队做网站分工一、概念 使用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.hkea.cn/news/14556999/

相关文章:

  • 网站建设长尾关键词ppt网站建设的目的
  • 如何做收费会员定制网站云浮网站网站建设
  • 网站程序员阆中市网站建设服务
  • 做网站买空间手机室内设计软件app
  • 同城手机网站开发做安全题目是哪个网站
  • 网站的制作哪家好wordpress html5 播放器
  • 建站 网站程序html5网站设计工作室源码
  • 自做网站多少钱小兔自助建站系统
  • 重庆市建设工程施工安全管理总站怎么找客户的联系方式
  • 开发一个网站需要几个人十大品牌网
  • 做兼职网站赚钱吗湖南批量出品机
  • 山东省 安全双体系建设网站企业集团网站建设方案
  • 做网站地图的步骤做一个一般的网站需要多少钱
  • 做美团网站多少钱云南昆明百度推广公司
  • 酒水食品做的好网站吴江建设银行网站
  • 单页网站模板安装h5教程入门
  • 网站建设售价多少钱重庆三类人员查询
  • 专业做律师网站的公司wordpress移动模板
  • 怎么做网站销售wordpress 威联通
  • 一个静态网站开发考虑什么个人养老金制度将出炉
  • 淘客网站做的好的wordpress的优势
  • 建网站花多少钱广东省建设工程执业中心网站
  • 织梦网站怎么做404页面城阳区规划建设局网站
  • 最基本的网站设计网站锚点链接怎么做
  • 两学一做11月答题网站网站建设国内外研究现状模板
  • 优化网站工具东营seo网站推广
  • 贸易公司网站建设方案重庆有没有做网站的
  • 常见的网站开发环境公司网站设计需要什么
  • asp.net 网站计数器企业网络营销为什么要选择外包?
  • 网站设计合同附件温州市微网站制作多少钱