dubbo RegistryConfig

1.RegistryConfig 来根据接口,注册中心,consumerConfig 来构成,形成接口的代理。
在这里插入图片描述

1.1 ProtocolListenerWrapper 监听器的包装
1.2 ProtocolFilterWrapper 过滤器的包装
1.3RegistryProtocol 注册中心和协议
1.3.1 RegistryDirectory 的构建,directory.subscribe()订阅,然后根据订阅模式得到channel

这里的 Invoker 是 Provider 的一个可调用 Service 的抽象,Invoker 封装了 Provider 地址及Service 接口信息
Directory 代表多个 Invoker,可以把它看成 List ,但与 List不同的是,它的值可能是动态变化的,比如注册中心推送变更
Cluster 将 Directory 中的多个 Invoker 伪装成一个Invoker,对上层透明,伪装过程包含了容错逻辑,调用失败后,重试另一个
Router 负责从多个 Invoker 中按路由规则选出子集,比如读写分离,应用隔离等
LoadBalance 负责从多个 Invoker 中选出具体的一个用于本次调用,选的过程包含了负载均衡算法,调用失败后,需要重选

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Dubbo Shiro是一种基于Dubbo和Shiro框架的权限管理解决方案。它可以帮助开发人员快速实现基于角色的访问控制和权限管理。下面是一个简单的演示: 1.在Dubbo服务提供者中配置Shiro过滤器链 ```java @Bean public FilterRegistrationBean<DelegatingFilterProxy> shiroFilter() { FilterRegistrationBean<DelegatingFilterProxy> filterRegistration = new FilterRegistrationBean<>(); filterRegistration.setFilter(new DelegatingFilterProxy("shiroFilter")); filterRegistration.addUrlPatterns("/*"); filterRegistration.setDispatcherTypes(DispatcherType.REQUEST, DispatcherType.FORWARD, DispatcherType.INCLUDE, DispatcherType.ERROR); return filterRegistration; } @Bean("shiroFilter") public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); shiroFilterFactoryBean.setSecurityManager(securityManager); Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>(); filterChainDefinitionMap.put("/dubbo/**", "authc, roles[dubbo]"); filterChainDefinitionMap.put("/**", "anon"); shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } ``` 2.在Dubbo服务消费者中配置Shiro ```java @Bean public ReferenceBean<DemoService> demoService() { ReferenceBean<DemoService> referenceBean = new ReferenceBean<>(); referenceBean.setInterface(DemoService.class); referenceBean.setUrl("dubbo://localhost:20880"); referenceBean.setVersion("1.0.0"); referenceBean.setTimeout(5000); referenceBean.setRetries(3); referenceBean.setCluster("failover"); referenceBean.setLoadbalance("roundrobin"); referenceBean.setApplication(applicationConfig()); referenceBean.setRegistry(registryConfig()); referenceBean.setInterface(DemoService.class); referenceBean.setCheck(false); referenceBean.setFilter("shiro"); return referenceBean; } ``` 3.在Shiro配置文件中配置权限 ```ini [users] admin=admin,admin guest=guest,guest [roles] dubbo=guest ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值