[RPC学习]Dubbo+nacos实现动态更新内存RTree
1.背景
服务架构一般都是从 单体架构 -> 微服务架构 -> 分布式架构 的迭代,我上一家公司就是在业务发展到一定规模时,开始拆老的单体服务,按业务维度拆成多个微服务,服务之间用的是HTTP请求,通常要求接口RT在200ms以内。目前的公司已经是分布式架构了,服务之间接口RT通常要求20ms以内。所以趁着清明节放假的时间,学一学现在开源的RPC框架Dubbo。
2.问题
之前LBS笔记写了怎么用RTree判断点在多边形内:【LBS学习笔记2】RTree判断点在多边形内-Java版本
个人学习的时候是可用的,但是在企业部署时会存在一个问题:线上服务器都是集群部署的,多台机器,如果需要更新内存RTree的数据,可以手动一台一台重启服务器,或者是一个个调更新接口去刷新。这样就很浪费人力了,我们需要的是自动化更新。所以我调研之后,发现可以用配置中心动态更新配置,使得每台机器都能pull到更新数据,根据这个特性,就能刷新所有机器的内存配置了。
3.准备
- 了解注册中心nacos的安装部署:nacos快速开始
- 了解Dubbo+SpringBoot的开发使用,可参考阿里云文档:使用spring-boot开发Dubbo
- 了解Dubbo是个啥,Dubbo简介
- (可选)了解阿里云云效自动化部署 2分钟教你部署2048小游戏到云服务器
4.具体细节
4.1 nacos注册中心部署
从GitHub上下载最新的nacos压缩包,解压后,进到bin目录下,执行startup.sh脚本,启动命令为:
sh startup.sh -m standalone
(以单机模式运行)
我这里将nacos部署在华为云上的,注意部署后要将端口8848
加到安全组里,然后访问nacos控制台地址:
http://[你的IP]:8848/nacos/#/login
,登录名和密码都是nacos,登录后就能看到页面了
nacos不仅能作为注册中心,也能用作配置中心,支持服务配置动态更新。
4.2 服务监听配置
如上图,我新建了个配置,Data Id叫:dubbo-config:rtree.properties
,配置文件里再随便写点内容。然后开始搞服务端开发,写到这我发现如果只关注配置中心的动态更新的话,不需要了解Dubbo,只关注nacos使用就可以了,囧...
点上图示例代码 按钮就能看到Java代码调用怎么写了,这里我写了一个监听配置的示例:
@PostConstruct
public String getConfig() throws NacosException, InterruptedException {
String serverAddr = "http://你的IP";
String dataId = "dubbo-config:rtree.properties";
String group = "DEFAULT_GROUP";
Properties properties = new Properties();
properties.put(PropertyKeyConst.SERVER_ADDR, serverAddr);
ConfigService configService = NacosFactory.createConfigService(properties);
String content = configService.getConfig(dataId, group, 5000);
log.info("启动时nacos配置:{}", content);
configService.addListener(dataId, group, new Listener() {
@Override
public void receiveConfigInfo(String configInfo) {
log.info("动态监听配置:{}", configInfo);
//监听配置后可以做重建RTree操作了
rTreeService.rebuild();
}
@Override
public Executor getExecutor() {
return null;
}
});
return content;
}
4.3 实践
部署2个服务连接nacos配置中心,部署架构是:
然后在nacos控制台修改一下配置的值,查看服务日志,可以看到2个服务都监听到配置变更了
5.FAQ
Dubbo消费者服务启动时报错No provider available for the service?
如果你的Dubbo生产者部署在云服务器上,在注册到nacos上时,IP显示的是内网IP,就会报这个问题。具体解决并办法是修改服务器上的hosts文件,服务器名对应的IP改为公网IP,重启服务即可。
欢迎关注我的公众号:福音同学
技术文章会先在公众号上更新哦
[RPC学习]Dubbo+nacos实现动态更新内存RTree的更多相关文章
- 详解Nacos 配置中心客户端配置缓存动态更新的源码实现
Nacos 作为配置中心,当应用程序去访问Nacos动态获取配置源之后,会缓存到本地内存以及磁盘中. 由于Nacos作为动态配置中心,意味着后续配置变更之后需要让所有相关的客户端感知,并更新本地内存! ...
- spring boot 配置文件动态更新原理 以Nacos为例
配置文件的动态更新 通常获取配置文件的方式 1, @Value 2. @ConfigurationProperties(Prefix) 如果是在运行时要动态更新的话, 第一种方式要在bean上加@Re ...
- rpc框架dubbo学习入门及环境搭建(spring boot+Kotlin)
学习之前,确保有以下知识基础: Java网络编程 Socket传输数据 IO流 rpc简介及实现 rpc是remote procedure call的简写,意思为远程过程调用. rpc应用较多的情景是 ...
- RPC 框架 Dubbo 从理解到使用(一)
技术架构演变 单一应用架构 通俗地讲,"单体应用(monolith application)"就是将应用程序的所有功能都打包成一个独立的单元.当网站流量很小时,只需一个应用,将所有 ...
- RPC 框架 Dubbo 从理解到使用(二)
本篇文章为系列文章,未读第一集的同学请猛戳这里:RPC 框架 Dubbo 从理解到使用(一) 本篇文章讲解 Dubbo 支持的注册中心.Dubbo 负载均衡策略和 Dubbo 控制台的安装. 注册中心 ...
- RPC学习
之前有一篇文章,说了RPC的内容: http://www.cnblogs.com/charlesblc/p/6214391.html 如果有一种方式能让我们像调用本地服务一样调用远程服务,而让调用者对 ...
- 微软Azure配置中心 App Configuration (三):配置的动态更新
写在前面 我在前文: <微软Azure配置中心 App Configuration (一):轻松集成到Asp.Net Core>已经介绍了Asp.net Core怎么轻易的接入azure ...
- JSPatch – 动态更新iOS APP
原文:http://blog.cnbang.net/works/2767/ JSPatch是最近业余做的项目,只需在项目中引入极小的引擎,就可以使用JavaScript调用任何Objective-C的 ...
- MyBatis学习 之 三、动态SQL语句
目录(?)[-] 三动态SQL语句 selectKey 标签 if标签 if where 的条件判断 if set 的更新语句 if trim代替whereset标签 trim代替set choose ...
随机推荐
- Markdown入门操作
Markdown基本操作 一. 字体 1. 标题 (1). 一级标题 "# + 标题名" (2). 其余类推 (最多支持6级标题) 加粗 " ** + 内容 + ** & ...
- linux环境下搭建solr服务器--单机版
前提需要在安装好jdk和tomcat,本人用的是jdk1.8+tomcat8.5+solr4.10. 第一步:安装linux.jdk.tomcat.(这步都是比较简单的,就不多说了) 第二步:把sol ...
- vim的vimrc配置
windows "# modified by Neoh set helplang=cn "使用中文帮助文档 set encoding=utf-8 "查看utf-8格式的帮 ...
- 二十三、原理图和PCB交互式布局
上图 在原理图里面直接选择在PCB里面就可以移动了,大功告成
- display:inline-block两端对齐 实现列表
做一个ul li 列表类似这样的平时经常会用到 要是用浮动做还是比较简单的直接左右浮动,清除浮动就可以搞定了,因为最近用display:inline-block用的比较顺手,所以就尝试一下.通过tex ...
- HTML5+CSS3兼容收藏夹
CSS3选择器兼容IE6~8: Selectivizr 使用方法: <!--[if (gte IE 6)&(lte IE 8)]> <script src="htt ...
- WebView的一些简单用法
一直想写一个关于 WebView 控件的 一些简单运用,都没什么时间,这次也是挤出时间写的,里面的一些基础知识就等有时间再更新讲解一下,今天就先把项目出来做一些简单介绍,过多的内容可以看我的源码,都传 ...
- h5 ios输入框与键盘 兼容性优化
起因 h5的输入框引起键盘导致体验不好,目前就算微信.知乎.百度等产品也没有很好的技术方案实现,尤其底部固定位置的输入框各种方案都用的前提下体验也并没有很好,这个问题也是老大难问题了.目前在准备一套与 ...
- 认识 Function.prototype.bind()
欢迎前端爱好者加入QQ群:112916679 答疑解惑,且可获取更多前端资料! bind()方法创建一个新的函数, 当被调用时,将其this关键字设置为提供的值,在调用新函数时,在任何提供之前提供一个 ...
- ES6-11学习笔记--Set
Set:一种新的数据结构 常用方法 遍历 应用场景 WeakSet 常用方法: // Set的成员值一定是唯一的不重复的 let s = new Set([1, 2, 3, 2]) // 添加数据 ...