将Dubbo注册到Nacos,与DubboAdmin的部署
王有志,一个分享硬核Java技术的互金摸鱼侠
加入Java人的提桶跑路群:共同富裕的Java人
本文是《从 0 开始学 Dubbo》系列文章中应用篇的番外篇。
在这篇文章中我会和大家一起部署单机模式的 Nacos,并将 Dubbo 的注册中心从 Zookeeper 迁移到 Nacos 上。另外,为了在只启动 Dubbo 服务提供者的场景下进行测试,我们会部署一个 Dubbo Admin 服务。
部署 Nacos
Nacos 的部署非常简单,可以下载 Nacos 源码编译后启动,或者直接使用 Nacos 官方提供的安装包。具体过程请参考官方文档:Nacos 快速开始。
我是在 IDEA 中直接启动的 Nacos,只需要稍微修改 Nacos 子模块 consle 的 application.properties 文件的一项鉴权相关的配置即可:

Nacos 的启动类同样位于子模块 console 中:

到此,我们就可以在 IDEA 中启动 Nacos 服务了,正常启动后可以通过 localhost:8848/nacos 访问 Nacos 的 Web 管理端:

除了从 IDEA 中启动,也可以选择通过 Maven 命令打包后启动项目:
mvn -Prelease-nacos -Dmaven.test.skip=true clean install -U
打包后的压缩包位于 /nacos/distribution/target 下,我这里打包的版本是 2.2.1-RC-develop:

上传到服务器解压项目后,同样需要处理鉴权相关的配置,然后就可以正常启动 Nacos 项目:
# Linux
sh startup.sh -m standalone
# Windows
startup.cmd -m standalone
Tips:Nacos 默认账户密码是“nacos”。
切换 Nacos
Nacos 部署成功后,我们就可以切换 Dubbo 服务的注册中心了,首先是在 POM 文件中引入dubbo-registry-nacos依赖(同时可以移除dubbo-dependencies-zookeeper-curator5依赖):
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-registry-nacos</artifactId>
<version>3.2.2</version>
</dependency>
接着修改 application.properties 文件中注册中心的配置:
dubbo:
registry:
address: nacos://106.75.33.232:8848
至此注册中心的迁移就完成了,直接启动修改后的 Dubbo 项目,并打开 Nacos 的管理端,就可以看到我们的服务已经注册到了 Nacos 上:

部署 Dubbo Admin
最后,我们来部署一个 Dubbo Admin 服务,用来在不启动服务使用方的场景下,测试服务提供方的服务。目前 Dubbo Admin 正在通过 Go 重构,因此我们需要将分支 refactor-with-go 切换到 master(master 为 Java 构建的分支,如果你能够熟练部署 Go 项目,可以不切换)。
Dubbo Admin 需要修改的内容并不多,主要修改注册中心,Dubbo Admin 的端口号,以及 Dubbo 的 protocol 端口号,首先是注册中心的配置,Dubbo Admin 默认使用的注册中心是 Zookeeper,我们修改为 Nacos 的配置:
# centers in dubbo2.7, if you want to add parameters, please add them to the url
#admin.registry.address=zookeeper://127.0.0.1:2181
#admin.config-center=zookeeper://127.0.0.1:2181
#admin.metadata-report.address=zookeeper://127.0.0.1:2181
# nacos config, add parameters to url like username=nacos&password=nacos
admin.registry.address=nacos://127.0.0.1:8848?group=DEFAULT_GROUP&namespace=public
admin.config-center=nacos://127.0.0.1.232:8848?group=dubbo
admin.metadata-report.address=nacos://127.0.0.1:8848?group=dubbo
接着是修改 Dubbo Admin 的端口号和 Dubbo 的 protocol 端口号:
#compress
server.port=8090
server.compression.enabled=true
server.compression.mime-types=text/css,text/javascript,application/javascript
server.compression.min-response-size=10240
#dubbo config
dubbo.application.name=dubbo-admin
dubbo.registry.address=${admin.registry.address}
至此,我们就可以启动 Dubbo Admin 的服务了,Dubbo Admin 的启动类在子模块 dubbo-admin-server 中:

启动后,我们可以看到如下 Web 管理端页面:

可以看到,Dubbo Admin 提供了非常非常多的功能,不过我们这里主要使用的是服务测试的功能:

至于 DUbbo Admin 提供的其它功能该如何使用,就留给大家来自行探索了。
Tips:
- 生产环境中,一台服务器上通常只会部署一个服务,所以不存在端口号冲突;
- 同样的,可以使用 Maven 命令mvn clean package打包 Dubbo Admin 服务后启动;
- Dubbo Admin 的默认账户密码是“root”。
如果本文对你有帮助的话,还请多多点赞支持。如果文章中出现任何错误,还请批评指正。最后欢迎大家关注分享硬核 Java 技术的金融摸鱼侠王有志,我们下次再见!
将Dubbo注册到Nacos,与DubboAdmin的部署的更多相关文章
- dubbo注册服务IP解析异常及IP解析源码分析
在使用dubbo注册服务时会遇到IP解析错误导致无法正常访问. 比如: 本机设置的IP为172.16.11.111, 但实际解析出来的是180.20.174.11 这样就导致这个Service永远也无 ...
- 阿里注册中心nacos使用整合Dubbo-原创
阿里注册中心nacos是今年开源的框架,一开始以为就是个zk.后面看了图才明白他对标的竟然是consul\eureka,最重要是完美支持dubbo.我想今年开源它也是别有用意 .(目前nacos0.7 ...
- 解决dubbo注册zookepper服务IP乱入问题的三种方式
最近做一个项目引入了dubbo+zookepper的分布式服务治理框架.在应用的发布的时候出现一个怪问题.zookepper服务是起在开发服务器192.168.23.180上.本机起应用服务提供者注册 ...
- 这个Dubbo注册中心扩展,有点意思!
今天想和大家聊聊Dubbo源码中实现的一个注册中心扩展.它很特殊,也帮我解决了一个困扰已久的问题,刚刚在生产中用了,效果很好,迫不及待想分享给大家. Dubbo的扩展性非常灵活,可以无侵入源码加载自定 ...
- 灵感乍现!造了个与众不同的Dubbo注册中心扩展轮子
hello大家好呀,我是小楼. 作为一名基础组件开发,服务好每一位业务开发同学是我们的义务(KPI). 客服群里经常有业务开发同学丢来一段代码.一个报错,而我们,当然要微笑服务,耐心解答. 有的问题, ...
- ZooKeeper 集群的安装、配置---Dubbo 注册中心
ZooKeeper 集群的安装.配置.高可用测试 Dubbo 注册中心集群 Zookeeper-3.4.6 Dubbo 建议使用 Zookeeper 作为服务的注册中心. Zookeeper 集群中只 ...
- dubbo注册中心zookeeper出现异常 Opening socket connection to server 10.70.42.99/10.70.42.99:2181. Will not attempt to authenticate using SASL (无法定位登录配置)
linux下,zookeeper安装并启动起来了 DEMO时,JAVA控制台出现: INFO 2014-03-06 09:48:41,276 (ClientCnxn.java:966) - Openi ...
- Dubbo框架介绍与安装 Dubbo 注册中心(Zookeeper-3.4.6)
背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. • 单一应用架构 • 当网站流量很小时, ...
- 2016年工作中遇到的问题41-50:Dubbo注册中心奇葩问题,wifi热点坑了
41.获得JSON中的变量.//显示json串中的某个变量,name是变量名function json(json,name){ var jsonObj = eval(json); return jso ...
- 第二个视频作品《[SpringCloudAlibaba]微服务之注册中心nacos》上线了
1.场景描述 第二个视频作品出炉了,<[SpringCloudAlibaba]微服务之注册中心nacos>上线了,有需要的朋友可以直接点击链接观看.(如需购买,请通过本文链接购买) 2. ...
随机推荐
- CentOS配置Django虚拟环境--坑点总结
1.CentOS原装有python2.7,编译安装python3.X版本 2.sqlite-devel未安装 3.sqlite3版本过低报错 升级sqlite3版本 参考 https://blog.c ...
- PostgreSQL插件那么多,怎样管理最高效?
摘要:华为云RDS for PostgreSQL通过插件管理功能,很好地解决了PostgreSQL版本与插件耦合的问题,帮助用户更直观.更快速地安装管理数据库插件. 本文分享自华为云社区<Pos ...
- Swift下Data处理全流程:从网络下载,数模转换,本地缓存到页面使用
Swift下将网络返回json数据转换成struct 假如网络请求返回的数据结构是一个深层嵌套的Json 首先要通过key-value取出这个json中的数据源 // 将返回的json字符串转Dict ...
- cryptohack wp day (2)
接着昨天的题目 第五题 看题目,一道简单的xor题,就是将"label中每个字符与13进行异或处理",直接上代码: s="label" result = &qu ...
- 自建CA和公共CA有什么不同?
据统计,全球有数百个公共CA,通常它们是按国家地区进行划分的.这类CA受大众的广泛认可和使用,也被称为公共信任的证书颁发机构.但是由于一些大型企业拥有许多站点,为了更轻松高效的管理以及考虑到维护成本, ...
- golang版本sdl2显示窗体
golang版本sdl2显示窗体 go用syscall调用sdl2,在win10 x64上没问题,其他系统不敢保证. 见地址 package main import ( "fmt" ...
- django时区问题的解决
django时区问题的解决 更新时间:2021年05月18日 09:37:58 作者:Silent丿丶黑羽 我们都知道时区,标准时区是UTC时区,django默认使用的就是UTC时区,我 ...
- 【Python笔记】第一章Python基本语法
嗨你好,我是AllenMi, 这是我学习北京理工大学的<Python语言程序设计>第一张笔记. 写笔记的目的一方面在于记录自己一步一步学习Python的内容, 另一方面也希望能够帮助到他人 ...
- Shiro 授权绕过 (CVE-2022-32532)
Shiro 授权绕过 (CVE-2022-32532) 一.产品简介 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理. 1.9.1 之前的 Apache ...
- Java的Atomic原子类
Java SDK 并发包里提供了丰富的原子类,我们可以将其分为五个类别,这五个类别提供的方法基本上是相似的,并且每个类别都有若干原子类. 对基本数据类型的变量值进行原子更新: 对对象变量的指向进行原子 ...