zoukankan      html  css  js  c++  java
  • springboot+dubbo之多端口注入服务

      前面介绍了,springboot+dubbo基础整合,这篇介绍多端口注入服务。

      springboot使用@Bean注入dubbo服务,当你是单一的ProviderConfig实例,dubbo的@Service会自动索引到你注入的实例。但实际使用情况下,dubbo服务提供者不可能统统只用一个端口提供服务。

      这是你就需要注入多个ProviderConfig,ProtocolConfig实例, 因此你可以封装自己的dubboConfiguration,注入新的ProviderConfig,ProtocolConfig实例。

    package hello.configuration;
    
    import javax.annotation.Resource;
    
    import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    import com.alibaba.dubbo.config.ApplicationConfig;
    import com.alibaba.dubbo.config.ProtocolConfig;
    import com.alibaba.dubbo.config.ProviderConfig;
    import com.alibaba.dubbo.config.RegistryConfig;
    import com.alibaba.dubbo.rpc.Exporter;
    
    /**
     * 多端口提供dubbo服务
     *     当你使用多端口提供服务,使用默认端口提供服务:需要加入在service上加上defaultProvider
     * @author chenlili
     *
     */
    @Configuration
    @ConditionalOnClass(Exporter.class)
    public class DubboAutoConfiguration {
        
        @Resource(name="protocolConfig1")
        private ProtocolConfig protocolConfig;
        
        @Resource(name="protocolConfig2")
        private ProtocolConfig protocolConfig2;
        
        /**
         * 默认基于dubbo协议提供服务
         * 
         * @return
         */
        @Bean(name = "protocolConfig1")
        public ProtocolConfig protocolConfig() {
            // 服务提供者协议配置
            ProtocolConfig protocolConfig = new ProtocolConfig();
            protocolConfig.setName("rmi");
            protocolConfig.setPort(20881);
            protocolConfig.setThreads(200);
    
            System.out.println("protocolConfig1的hashCode: " + protocolConfig.hashCode());
    
            return protocolConfig;
        }
    
        /**
         * dubbo服务提供
         * 
         * @param applicationConfig
         * @param registryConfig
         * @param protocolConfig
         * @return
         */
        @Bean(name = "providerConfig1")
        public ProviderConfig providerConfig(ApplicationConfig applicationConfig, RegistryConfig registryConfig) {
            ProviderConfig providerConfig = new ProviderConfig();
            providerConfig.setTimeout(1000);
            providerConfig.setRetries(1);
            providerConfig.setDelay(-1);
            providerConfig.setApplication(applicationConfig);
            providerConfig.setRegistry(registryConfig);
            providerConfig.setProtocol(this.protocolConfig);
            return providerConfig;
        }
    
        /**
         * 默认基于dubbo协议提供服务
         * 
         * @return
         */
        @Bean(name = "protocolConfig2")
        public ProtocolConfig protocolConfig2() {
            // 服务提供者协议配置
            ProtocolConfig protocolConfig = new ProtocolConfig();
            protocolConfig.setName("dubbo");
            protocolConfig.setPort(20882);
            protocolConfig.setThreads(200);
    
            System.out.println("protocolConfig2的hashCode: " + protocolConfig.hashCode());
    
            return protocolConfig;
        }
    
        /**
         * dubbo服务提供
         * 
         * @param applicationConfig
         * @param registryConfig
         * @param protocolConfig
         * @return
         */
        @Bean(name = "providerConfig2")
        public ProviderConfig providerConfig2(ApplicationConfig applicationConfig, RegistryConfig registryConfig) {
            ProviderConfig providerConfig = new ProviderConfig();
            providerConfig.setTimeout(1000);
            providerConfig.setRetries(1);
            providerConfig.setDelay(-1);
            providerConfig.setApplication(applicationConfig);
            providerConfig.setRegistry(registryConfig);
            providerConfig.setProtocol(protocolConfig2);
            return providerConfig;
        }
    }

      @Service使用时,直接使用@Service(version="1.0.0")会报错,提示你找不到对应的provider,因此需要配上对应的provider,因此在默认dubboConfiguration上加了@Bean(name="defaultProvider"),用于索引默认provider。

      

    package hello.dubbo;
    
    import com.alibaba.dubbo.config.annotation.Service;
    import com.jon.show.service.IDubboDemoService;
    
    @Service(version="1.0.0",provider="providerConfig1")
    public class DubboDemoServiceImpl implements IDubboDemoService{
    
        @Override
        public String sayHello(String name) {
            return "hello " + name;
        }
    
        @Override
        public String sayYourAge(int age) {
            return null;
        }
    
    }
    package hello.dubbo;
    
    
    import com.alibaba.dubbo.config.annotation.Service;
    import com.google.gson.Gson;
    import com.jon.show.model.Person;
    import com.jon.show.service.IDubboPersonService;
    
    @Service(version="1.0.0", provider="providerConfig2")
    public class PersonServiceImpl implements IDubboPersonService{
        
        @Override
        public String toJson(Person person) {
            Gson gson = new Gson();
            return gson.toJson(person);
        }
    
    }

      启动appliction类,dubbo服务就能提供多端口支持了!!

      PS:dubbo服务的所需实例均交由spring管理。

  • 相关阅读:
    8-kubernetes-安全
    6-kubernetes网络
    5-kunernetes资源调度
    4-K8S 部署Java应用及应用程序生命周期管理
    3-kubernetes监控与日志管理
    2-K8S常用命令
    1-kubeadm部署1.18.0单master集群
    部署Prometheus+Grafana监控
    微信小程序学习
    vue 中使用 @scroll事件 没有用
  • 原文地址:https://www.cnblogs.com/cl2Blogs/p/5692357.html
Copyright © 2011-2022 走看看