
Dubbo学习之简单的demo(纯java版)
发布日期:2021-05-07 08:41:14
浏览次数:17
分类:技术文章
本文共 2910 字,大约阅读时间需要 9 分钟。
当前环境:jdk1.8、eclipse、zookeeper3.4.13
1.创建父级项目
直接使用简单demo中的父级xml
2.创建子项目dubbo-java-customer
2.1 导入依赖
dubbo-api dubbo-api 0.0.1-SNAPSHOT
2.2 编写Customer类
/** * @description 使用java方式创建dubbo项目--客户端 * @author hy * @date 2019-10-07 */public class Customer { public static void main( String[] args ) { // 当前应用配置 ApplicationConfig application = new ApplicationConfig(); application.setName("hello-world-app-customer"); // 连接注册中心配置 RegistryConfig registry = new RegistryConfig(); registry.setAddress("zookeeper://192.168.133.129:2181");//这里使用zookeeper作为注册中心 // 注意:ReferenceConfig为重对象,内部封装了与注册中心的连接,以及与服务提供方的连接 // 引用远程服务 ReferenceConfigreference = new ReferenceConfig (); // 此实例很重,封装了与注册中心的连接以及与提供者的连接,请自行缓存,否则可能造成内存和连接泄漏 reference.setApplication(application); reference.setRegistry(registry); // 多个注册中心可以用setRegistries() reference.setInterface(DemoService.class); reference.setVersion("1.0.0"); // 和本地bean一样使用xxxService DemoService demoService = reference.get(); // 注意:此代理对象内部封装了所有通讯细节,对象较重,请缓存复用 String say = demoService.say("World"); System.out.println(say); }}
当前的Customer可以按照xml中的配置依此配置即可
3.创建子项目dubbo-java-provider
3.1 导入依赖
dubbo-api dubbo-api 0.0.1-SNAPSHOT
3.2 编写dubbo-api中的实现类
/** * @description 创建服务实现类 * @author hy * @date 2019-10-07 */public class DemoServiceImpl implements DemoService { @Override public String say(String context) { return "Hello "+context+" !"; }}
3.3 创建Provider类
/** * @description 使用纯java方式配置dubbo--服务提供端 * @author hy * @date 2019-10-07 */public class Provider { public static void main(String[] args) throws IOException { // 服务实现 DemoService demoService = new DemoServiceImpl(); // 当前应用配置 ApplicationConfig application = new ApplicationConfig(); application.setName("hello-world-app-provider"); // 连接注册中心配置 RegistryConfig registry = new RegistryConfig(); registry.setAddress("zookeeper://192.168.133.129:2181");//这里使用zookeeper作为服务注册中心 // 服务提供者协议配置 ProtocolConfig protocol = new ProtocolConfig(); protocol.setName("dubbo"); protocol.setPort(20880); //protocol.setThreads(200); // 注意:ServiceConfig为重对象,内部封装了与注册中心的连接,以及开启服务端口 // 服务提供者暴露服务配置 ServiceConfigservice = new ServiceConfig (); // 此实例很重,封装了与注册中心的连接,请自行缓存,否则可能造成内存和连接泄漏 service.setApplication(application); service.setRegistry(registry); // 多个注册中心可以用setRegistries() service.setProtocol(protocol); // 多个协议可以用setProtocols() service.setInterface(DemoService.class); service.setRef(demoService); service.setVersion("1.0.0"); // 暴露及注册服务 service.export(); System.in.read(); //需要等待 }}
发现其中创建的配置其实就跟xml配置完全一致
4.测试
4.1 启动Provider类
4.2 启动Customer类
5.总结
1.其实当前java配置版和xml配置版基本上差不多,就是将对应的标签换成了对应的对象
以上纯属个人见解,如有问题请联系本人!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2025年04月12日 04时22分27秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
重新整理数据结构与算法(c#)—— 算法套路二分法[二十四]
2019-03-06
不一样的备忘录模式(设计模式十六)
2019-03-06
【golang-GUI开发】qt之signal和slot(一)
2019-03-06
Markdown使用笔记
2019-03-06
「从零单排HBase 06」你必须知道的HBase最佳实践
2019-03-06
「从零单排canal 04」 启动模块deployer源码解析
2019-03-06
用ThreadLocal来优化下代码吧
2019-03-06
netcore中使用session
2019-03-06
Android 开发学习进程0.25 自定义控件
2019-03-06
多媒体文件格式全解说(下)--图片
2019-03-06
淘宝WAP版小BUG分析
2019-03-06
Java并发之ThreadPoolExecutor源码解析(三)
2019-03-06
TCP/IP网络编程之域名及网络地址
2019-03-06
Redis实现之对象(三)
2019-03-06
NodeJS+Express+MongoDB
2019-03-06
(五)c#Winform自定义控件-复选框-HZHControls
2019-03-06
(三十一)c#Winform自定义控件-文本框(四)-HZHControls
2019-03-06
(四十四)c#Winform自定义控件-水波-HZHControls
2019-03-06
c#winform主题实现的一个方法
2019-03-06