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

大型企业网站欣赏/杭州最好的电商培训机构

大型企业网站欣赏,杭州最好的电商培训机构,玖玖建筑网官方网,手机上怎么做网站创业服务发现的领域模型 NameSpace:实线隔离,默认publicGroup:不同服务可以分到一个组,默认DEFAULT_GROUPservice:微服务cluster:对指定微服务的一个虚拟划分,默认Defaultinstance:微服务实例ribbo…

服务发现的领域模型

  • NameSpace:实线隔离,默认public
  • Group:不同服务可以分到一个组,默认DEFAULT_GROUP
  • service:微服务
  • cluster:对指定微服务的一个虚拟划分,默认Default
  • instance:微服务实例

 ribboon的父子上下文重叠,ribbon的懒加载。

自定义权重策略

import com.alibaba.nacos.api.exception.NacosException;
import com.alibaba.nacos.api.naming.NamingService;
import com.alibaba.nacos.api.naming.pojo.Instance;
import com.netflix.client.config.IClientConfig;
import com.netflix.loadbalancer.*;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.alibaba.nacos.NacosDiscoveryProperties;
import org.springframework.cloud.alibaba.nacos.ribbon.NacosServer;@Slf4j
public class NacosWeightedRule extends AbstractLoadBalancerRule {@Autowiredprivate NacosDiscoveryProperties nacosDiscoveryProperties;@Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {// 读取配置文件,并初始化NacosWeightedRule}@Overridepublic Server choose(Object key) {try {BaseLoadBalancer loadBalancer = (BaseLoadBalancer) this.getLoadBalancer();
//        log.info("lb = {}", loadBalancer);// 想要请求的微服务的名称String name = loadBalancer.getName();// 拿到服务发现的相关APINamingService namingService = nacosDiscoveryProperties.namingServiceInstance();// nacos client自动通过基于权重的负载均衡算法,给我们选择一个实例。Instance instance = namingService.selectOneHealthyInstance(name);log.info("选择的实例是:port = {}, instance = {}", instance.getPort(), instance);return new NacosServer(instance);} catch (NacosException e) {return null;}}
}// spring cloud commons --> 定义了标准
// spring cloud loadbalancer --> 没有权重

自定义同集群策略

import com.alibaba.nacos.api.exception.NacosException;
import com.alibaba.nacos.api.naming.NamingService;
import com.alibaba.nacos.api.naming.pojo.Instance;
import com.alibaba.nacos.client.naming.core.Balancer;
import com.netflix.client.config.IClientConfig;
import com.netflix.loadbalancer.AbstractLoadBalancerRule;
import com.netflix.loadbalancer.BaseLoadBalancer;
import com.netflix.loadbalancer.Server;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.alibaba.nacos.NacosDiscoveryProperties;
import org.springframework.cloud.alibaba.nacos.ribbon.NacosServer;
import org.springframework.util.CollectionUtils;import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;@Slf4j
public class NacosSameClusterWeightedRule extends AbstractLoadBalancerRule {@Autowiredprivate NacosDiscoveryProperties nacosDiscoveryProperties;@Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {}@Overridepublic Server choose(Object key) {try {// 拿到配置文件中的集群名称 BJString clusterName = nacosDiscoveryProperties.getClusterName();BaseLoadBalancer loadBalancer = (BaseLoadBalancer) this.getLoadBalancer();// 想要请求的微服务的名称String name = loadBalancer.getName();// 拿到服务发现的相关APINamingService namingService = nacosDiscoveryProperties.namingServiceInstance();// 1. 找到指定服务的所有实例 AList<Instance> instances = namingService.selectInstances(name, true);// 2. 过滤出相同集群下的所有实例 BList<Instance> sameClusterInstances = instances.stream().filter(instance -> Objects.equals(instance.getClusterName(), clusterName)).collect(Collectors.toList());// 3. 如果B是空,就用AList<Instance> instancesToBeChosen = new ArrayList<>();if (CollectionUtils.isEmpty(sameClusterInstances)) {instancesToBeChosen = instances;log.warn("发生跨集群的调用, name = {}, clusterName = {}, instances = {}",name,clusterName,instances);} else {instancesToBeChosen = sameClusterInstances;}// 4. 基于权重的负载均衡算法,返回1个实例Instance instance = ExtendBalancer.getHostByRandomWeight2(instancesToBeChosen);log.info("选择的实例是 port = {}, instance = {}", instance.getPort(), instance);return new NacosServer(instance);} catch (NacosException e) {log.error("发生异常了", e);return null;}}
}class ExtendBalancer extends Balancer {public static Instance getHostByRandomWeight2(List<Instance> hosts) {return getHostByRandomWeight(hosts);}
}

 

http://www.jmfq.cn/news/5257999.html

相关文章:

  • 做有支付系统的网站一般需要多少钱/百姓网推广怎么收费标准
  • 网站里面网友点评怎么做/国家高新技术企业查询
  • 网站服务类型/推广普通话图片
  • 其它区便宜营销型网站建设推荐/东莞网络营销优化
  • 公司做网站注意事项/推广新产品最好的方法
  • 做电影下载网站赚钱/站长之家域名查询鹿少女
  • 上海网站建设代码/网站seo优化价格
  • 网站建设有什么方法连接数据库/网络营销工具
  • 制作高端网站效果怎么样/微信朋友圈软文大全
  • 做网站外贸怎么找客户/百度指数查询移民
  • 淘宝客免费网站建设/baidu百度
  • 东莞网站建设市场/做网站平台需要多少钱
  • 买域名后 怎么做网站/关键词点击价格查询
  • 河池市住房城乡建设网站/软件开发工资一般多少
  • 纺织厂网站模板/百度统计数据分析
  • 广元市剑阁县建设局网站/网络销售好不好做
  • 潍坊哪里能找到做网站的/成都黑帽seo
  • 哪个网站做简历/semir是什么意思
  • 广州网站建设信科网络/网站流量统计查询
  • 国内使用wordpress/百度seo推广
  • 百度站点管理/今日新闻最新头条10条
  • jsp做网站实例教程/福州seo
  • 机票酒店 网站建设/打开百度一下网页版
  • 浅析淘宝网站的建设与运营论文/快手seo软件下载
  • 金融直播室网站建设/小程序商城
  • 上海企业网站备案/婚恋网站排名前10
  • 提升网站建设/竞价托管就选微竞价
  • 旅游网站开发需求/网络营销的目标
  • 网站备案主体授权书/竞价托管多少钱一个月
  • 免费虚拟机安卓版/seo关键词排名技术