Dubbo——与SpringBoot整合的三种方式

https://blog.csdn.net/rubulai/article/details/84843975

https://blog.csdn.net/qq_33404395/article/details/85046493

 

一、引入
  通过配置文件能配置的属性,在使用注解的方式中也可以通过注解的相应属性进行配置,但是通过注解的方式对指定的方法进行配置时会有一定的局限性。

二、SpringBoot与Dubbo整合的三种方式
 1、在SpringBoot的项目中导入dubbo-starter,在application.properties/application.yml中配置dubbo相关的属性,使用dubbo的@Service注解暴露服务,使用@Reference订阅服务,通常我们使用@EnableDubbo来启用dubbo,在老版本中也可以通过在application.properties文件中配置dubbo.scan.base-packages属性来启用dubbo(此时则不再需要使用@EnableDubbo注解):此时不需要dubbo的xml配置文件,但缺陷是无法做到方法级别的精确配置

dubbo.scan.base-packages=com.bdm.gmall

 2、保留dubbo的xml配置文件(比如concumer.xml和provider.xml):可进行方法级别的配置,此时不再需要在application.properties/application.yml文件中进行dubbo相关的配置,在暴露服务和订阅服务时也不再需要使用dubbo的@Service注解和@Reference注解(使用@Autowired就可以),也不需要在主配置类中使用@EnableDubbo注解来启用dubbo,只需要在主配置类中使用@ImportResource将dubbo的配置文件引入即可,以服务提供者为例:
 主配置类:

//@EnableDubbo
@ImportResource(locations="classpath:provider.xml")
@SpringBootApplication
public class BootUserServiceProviderApplication {

	public static void main(String[] args) {
		SpringApplication.run(BootUserServiceProviderApplication.class, args);
	}
}

 服务提供者实现类:不需要dubbo的@Service暴露服务,因为在配置文件中已经暴露了

@Component
//@Service //此注解是dubbo的暴露服务注解
public class UserServiceImpl implements UserService {

	public List<UserAddress> getUserAddressList(String userId) {
		UserAddress address1 = new UserAddress(1, "北京市昌平区宏福科技园综合楼3层", "1", "李老师", "010-56253825", "Y");
		UserAddress address2 = new UserAddress(2, "深圳市宝安区西部硅谷大厦B座3层(深圳分校)", "1", "王老师", "010-56253825", "N");
		return Arrays.asList(address1, address2);
	}
}

  总结:导入dubbo-starter,使用@ImportResource导入dubbo的配置文件
 3、完全使用注解,使用配置类将dubbo的配置以bean的方式注册到IOC容器,每一个dubbo的xml标签都有一个对应的Config类,比如dubbo:application的对应类为ApplicationConfig,dubbo:registry的对应类为RegistryConfig等,相当于将xml的配置转化为一个个的bean,同时在主配置类中指定dubbo的包扫描路径,另外需要使用dubbo的@Service注解暴露服务:
 配置类如下:其他配置可参见官网

@Configuration
public class DubboConfig {

	@Bean
	public ApplicationConfig applicationConfig() {
		ApplicationConfig config = new ApplicationConfig();
		config.setName("boot-user-service-provider");
		return config;
	}

	@Bean
	public RegistryConfig registryConfig() {
		RegistryConfig config = new RegistryConfig();
		config.setProtocol("zookeeper");
		config.setAddress("127.0.0.1:2181");
		return config;
	}

	@Bean
	public ServiceConfig<UserService> serviceConfig(UserService userService) {
		ServiceConfig<UserService> config = new ServiceConfig<UserService>();
		config.setInterface(UserService.class);
		config.setRef(userService);// 由于我们将UserService的实现加入到了IOC容器,所以可以这么写
		config.setVersion("1.0.0");

		// 配置mothod信息
		List<MethodConfig> methods = new ArrayList<>();
		MethodConfig mConfig = new MethodConfig();
		mConfig.setName("getUserAddressList");
		mConfig.setTimeout(1000);
		methods.add(mConfig);
		config.setMethods(methods);

		return config;
	}
}

 指定包扫描路径:可使用@EnableDubbo也可使用@DubboComponentScan

//@ImportResource(locations="classpath:provider.xml")
@EnableDubbo(scanBasePackages="com.bdm.gmall")
@SpringBootApplication
public class BootUserServiceProviderApplication {

	public static void main(String[] args) {
		SpringApplication.run(BootUserServiceProviderApplication.class, args);
	}
}

 使用dubbo的@Service暴露服务:

@Component
@Service //此注解是dubbo的暴露服务注解
public class UserServiceImpl implements UserService {

	public List<UserAddress> getUserAddressList(String userId) {
		UserAddress address1 = new UserAddress(1, "北京市昌平区宏福科技园综合楼3层", "1", "李老师", "010-56253825", "Y");
		UserAddress address2 = new UserAddress(2, "深圳市宝安区西部硅谷大厦B座3层(深圳分校)", "1", "王老师", "010-56253825", "N");
		return Arrays.asList(address1, address2);
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值