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

做网站项目需要多少钱谷歌是如何运营的

做网站项目需要多少钱,谷歌是如何运营的,设计网站推荐国内,网站平台一.负载均衡 1.问题提出 上一篇文章写了服务注册和服务发现的相关内容。这里再提出一个新问题,如果我给一个服务开了多个端口,这几个端口都可以访问服务。 例如,在上一篇文章的基础上,我又新开了9091和9092端口,现在…

一.负载均衡

1.问题提出

上一篇文章写了服务注册和服务发现的相关内容。这里再提出一个新问题,如果我给一个服务开了多个端口,这几个端口都可以访问服务。

例如,在上一篇文章的基础上,我又新开了9091和9092端口,现在重新启动服务,查看访问的端口号:

通过运行发现,无论我怎么刷新,访问的永远是一个端口:

2.LoadBalance

负载均衡是高并发高可用系统中的必不可少的关键组件。我们上面的问题就可以使用负载均衡来解决。负载均衡可以按照一定规则分配资源。

负载均衡分为服务端负载均衡客户端负载均衡

1)服务端负载均衡

在服务端采用负载均衡算法分配资源,常用的有Nginx。

2)客户端负载均衡

在客户端采用负载均衡算法分配资源,客户端从注册中心获取服务列表,在发送请求前通过负载均衡算法选择⼀个服务器,然后进行访问。

二.SpringCloudLoadBalancer

SpringCloud从2020.0.1版本开始移除了Ribbon组件,使用SpringCloudLoadBalancer组件来代替Ribbon实现客户端负载均衡

1.添加注解

给 RestTemplate 添加注解@LoadBalanced

@Configuration
public class BeanConfig {@Bean@LoadBalancedpublic RestTemplate restTemplate(){return new RestTemplate();}
}

2.修改远程调用代码

将IP和端口号改成应用名:

@Resource
RestTemplate restTemplate;@RequestMapping("/{orderId}")
public OrderInfo getOrderById(@PathVariable("orderId") Integer orderId) {OrderInfo orderInfo = orderMapper.selectByOrderId(orderId);//String url = "http://127.0.0.1:9090/product/"+ orderInfo.getProductId();String url = "http://product-service/product/"+ orderInfo.getProductId();ProductInfo productInfo = restTemplate.getForObject(url, ProductInfo.class);orderInfo.setProductInfo(productInfo);return orderInfo;
}

然后启动验证即可。

3.负载均衡策略

SpringCloudLoadBalancer仅支持两种负载均衡策略:

1)轮询:服务器轮流处理用户请求;

2)随机选择:随机选择一个服务器处理请求。

SpringCloudLoadBalancer默认的负载均衡策略是轮询,当然我们也可以将其改成随机选择,具体方法在SpringCloud官网也有介绍。

public class LoadBalancerConfig {@BeanReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class),name);}
}

接着在RestTemplate配置类上,使用@LoadBalancerClient或@LoadBalancerClients注解,两个注解的区别在于有没有多个服务提供者。

这两个注解有两个注解属性:

1)name:负载均衡对哪个服务生效;

2)configuration:使用哪个负载均衡策略。

@LoadBalancerClient(name = "product-service",configuration = LoadBalancerConfig.class)
@Configuration
public class BeanConfig {@Bean@LoadBalancedpublic RestTemplate restTemplate(){return new RestTemplate();}
}

http://www.dtcms.com/wzjs/402349.html

相关文章:

  • appmakr教程海淀区seo引擎优化多少钱
  • 给网站写文章怎么做百度打车客服电话
  • 地方网站定位佛山外贸seo
  • 什么网站可以做音乐伴奏金戈枸橼酸西地那非
  • 深圳html5网站建设百度广告运营
  • 淮安网站建设费用推广优化工具
  • html网站后台管理系统网址链接查询
  • 制作网站服务器营销推广方案怎么写
  • 运城环保局网站王建设站内优化seo
  • 网站宣传与推广的指导思想个人网站制作软件
  • 游戏网站做代理seo搜索引擎优化工作内容
  • 做购物网站多少钱百度app打开
  • 炫酷的网站设计搜索引擎调价平台哪个好
  • 温州公司网站建设2022最近热点事件及评述
  • 如何自己做解析网站百度定位店铺位置怎么设置
  • 网站建设专业的公司排名2023年10月疫情恢复
  • 湛江高端网站建设百度广告投放公司
  • 重庆网站建设选卓光网络营销热点事件案例分析
  • 湖州网站设计建设网站开发需要哪些技术
  • 司机找事做那个网站靠谱徐州seo排名收费
  • 百度上传网站服务器怎么做游戏推广员
  • 高安网站找工作做面点事怎么在百度上做推广上首页
  • 中文网址和中文域名巩义网站优化公司
  • 商标设计软件免费版厦门seo关键词排名
  • 建设部网站示范文本网站百度
  • 网站建设方案大全网站推广的软件
  • 电子商务网站数据库怎么做学生个人网页制作
  • 三网合一网站建设程序制作网页的基本步骤
  • 成功卡耐基网站建设今天的国际新闻
  • 许昌做网站公司汉狮价格百度竞价