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

网站 手机版 电脑版 怎么做下载百度2023最新版安装

网站 手机版 电脑版 怎么做,下载百度2023最新版安装,网站内做链接,中国有哪些软件公司高并发处理的思路: 扩容:水平扩容、垂直扩容缓存:将基础的数据放入缓存进行处理使用SpringCloud的注册中心,分服务注册到同一个注册中心,服务器检测使用Spring的熔断操作,检测服务器的心跳那个正常随机跳转…

高并发处理的思路:

  • 扩容:水平扩容、垂直扩容
  • 缓存:将基础的数据放入缓存进行处理
  • 使用SpringCloud的注册中心,分服务注册到同一个注册中心,服务器检测使用Spring的熔断操作,检测服务器的心跳那个正常随机跳转到正常的服务器上

也可以使用熔断机制通过实现Hystrix会监测微服务间调用的状况,当失败的调用到一定阈值缺省是5秒内20次调用失败,就会启用熔断机制

熔断机制的注解是@HystrixCommand ,Hystrix会找到有这个的注解,并将这类方法关联到和熔断器连在一起的代理上,@HystrixCommand仅当类的注解为@Service和@Component时

才会发挥作用。

微服务之间的调用有两种方式,一种是一个是RestTemplate,另一个是Feign。相对应,在这两种调用方式下,都有Hystrix调用方法

  • 数据量大的在数据库做集成处理

对于微服务项目开发中,多个微服务之间不仅是相对独立的,而且也是相对关联的。也就是说,微服务之间需要相互访问,多个微服务之间的接口可能会被互相调用多次,我们称之为微服务之间的通信。

  • 微服务之间的通信方式有很多种, 一般都是使用RestTemplate 或者Feign

RestTemplate,是Spring中方便使用rest资源的一个对象,交互访问的资源通过URL进行识别和定位。每次调用都使用模板方法的设计模式,模板方法依赖于具体的接口调用,从而实现了资源交互和调用。它的交互方法有30多种,大多数都是基于HTTP的方法,

例如:delete(),getForEntity(),getForObject(),put(),headForHeaders()

添加对应依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>

启动添加负载均衡标识

@LoadBalanced
@Bean
public RestTemplate getRestTemplate() {return new RestTemplate();
}

服务提供类,服务名称:SERVICE1,端口:7082

@RestController
@RequestMapping("/service1")
public class TestController {@RequestMapping(value = "test", method = {RequestMethod.POST,RequestMethod.GET})public String testService(@RequestParam(value = "testParam") String testParam) {System.println.out(testParam);return "success";}}

服务消费类

@RestController
@RequestMapping("/serviceFront")
public class ServiceFrontController {private final static String SERVICE1_URL = "http://SERVICE1:7082";private final static String SERVICE1 = "SERVICE1";@Autowired	LoadBalancerClient loadBalancerClient;@AutowiredRestTemplate restTemplate;@RequestMapping(value = "testFront", method = RequestMethod.POST)public HashMap<String,Object> testFront(@RequestParam String testParam) {this.loadBalancerClient.choose(SERVICE1);// 随机访问策略String result = restTemplate.getForObject(SERVICE1_URL + "/service1/test?testParam={1}", String.class, testParam);HashMap<String,Object> map = new HashMap<String,Object>();map.put("result", "测试结果!"+result);return map;}
}

RestTemplate发送post请求,主要的参数有如下几种

  • String url : 请求的路径
  • Object request:请求体【@RequestBody 注解接收】,或者是一个HttpEntity对象(包含请求参数,请求头)
  • Class< T> responseType:接收返回数据的类型
  • Map<String,?> uriVariables: uri 变量, 这是放置变量的地方
  • Object… uriVariables:可变长 Object 类型 参数
  • restTemplate.postForObject("http://XXXXXXXX?name={name}&age={age}", request, JSONObject.class, name,age);

    Feign,是声明式的伪HTTP客户端,使得编写HTTP客户端更新容易,只需要创建一个接口,并且使用注解的方式去配置,即可完成对服务提供方接口的绑定,大大简化了代码量,同时它还具有可拔插的注解特性,而且支持feign自定义的注解和springMvc的注解。

添加具体的Feign依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-ribbon</artifactId>
</dependency>

 在启动类Application添加feign注解,声明启动feign客户端

@EnableFeignClients

服务提供类,服务名称:SERVICE2 端口7083

@RestController
@RequestMapping("/service2")
public class TestController{@RequestMapping(value = "test2", method = {RequestMethod.POST,RequestMethod.GET})public String test2(@RequestParam(value = "testParam2") String testParam2) {System.println.out(testParam2);return "success";}}

 服务消费接口类

@FeignClient(name = "SERVICE2")
public interface TestFeignClient { @RequestMapping(value="/service2/test2",method = RequestMethod.GET)public String test2(@RequestParam("testParam2") String testParam2);}

服务消费控制层

@RestController
@RefreshScope
@RequestMapping("/serviceFront2")
public class TestFeignController {@Autowiredprivate TestFeignClient testFeignClient;@RequestMapping(value = "test2", method = { RequestMethod.POST })public HashMap<String,Object> test2(@RequestParam String testParam2) {		String result = testFeignClient.test2(testParam2);HashMap<String,Object> map = new HashMap<String,Object>();map.put("result", "测试结果!"+result);return map;}
}

总之,微服务之间的通讯方式可以多种并存,各有优势,在项目实践中可具体情况具体分析

http://www.hengruixuexiao.com/news/33972.html

相关文章:

  • wordpress网站下载文件长尾关键词挖掘精灵官网
  • 辽宁网站建设百度的营销中心上班怎么样
  • 用rp怎么做网站按钮下拉框简述搜索引擎的工作原理
  • 南宁seo建站域名停靠网页推广大全
  • 怎么注册域名免费谷歌seo软件
  • 南宁网站推广公司如何在百度推广
  • 微信小程序开发报价优化seo方案
  • 宝塔做网站安全吗技术培训班
  • 网站每天一条推送怎么做的江门关键词优化公司
  • 正规的饰品行业网站开发百度前三推广
  • 汽车网站建设方案刷赞网站推广空间免费
  • 100元建网站网络培训研修总结
  • 做网站编程在程序如何在百度推广自己的产品
  • 网站和自媒体都可以做常熟网络推广
  • 网站建设功能规划网站交换链接友情链接的作用
  • 对招聘网站页面设计做建议一个新品牌如何推广
  • 淘宝上做网站的可靠百度推广河南总部
  • 企业官网网站设计nba最新交易一览表
  • 网页设计 做网站的代码女生学电子商务好吗
  • 17网站一起做网店普宁轻纺城温馨百度网页入口官网
  • wordpress登陆后查看网站的seo优化报告
  • 使用magento的网站优化搜狗排名
  • html网站开发工具泉州百度竞价公司
  • 智能建站推荐百度登录首页
  • 最权威的网站推广公司谷歌排名
  • 在线制作电子签名谷歌seo优化
  • 手机app界面设计分析seo网络优化师
  • 中国建设银行招聘官方网站信息流优化师证书
  • 微信安全中心官网对网站外部的搜索引擎优化
  • 温江做网站的公司seo查询5118