nacos迁移及踩坑历程

背景:将内部使用的nacos迁移到新的服务器nacos;新版本:2.2.0

开发环境:nacos  1.1.0

       因为开发环境都是组内成员使用,所以采用冷迁移的方式(简单来说就是不考虑任何服务宕机问题直接硬迁):

       直接将服务注册地址更改为新的服务地址,不考虑别人使用情况,内部成员一起硬迁,避免因迁移问题导致其他使用成员服务异常。(这里就涉及测试和生产如何解决问题)

测试环境:1.1.0

发版工具:坎特

     模拟生产迁移,因为测试环境无论是对接还是测试老师都在使用,不能因为个人原因影响测试进度或对接进度。

     1.保证原有服务的可用,采用热启动(双注册双发现)的方式,下载polaris代理包放到指定路径,供坎特发版引入实现双注册(原nacos及新nacos)。这时候是不是就考虑请求是打在原nacos上还是新的nacos,可以通过测试进行验证,当然是原nacos,因为代码中指向的节点还都是原来的nacos,那如果下线的话,只能下掉原nacos服务,新的nacos是下不了的;这时候还要考虑如果将代码中某个服务的配置信息更改为新nacos节点会出现什么情况?答案是:服务不可用,它是找不到其他服务的,并且原有依赖它的服务也会因为找不到这个服务而不可用。

     2.保证所有服务都迁移完成(这一点非常重要否则到了生产直接GG,我们都是excel表进行统计多人同时操作再三确认),为什么要等到所有服务都注册进来呢?就是为了新nacos(集群)各服务之间是通的,完成以后修改代码配置新的nacos信息及相关配置信息(这里面也是非常关键包括坎特发版中的配置信息:命名空间、服务名等),这样就可以直接一个服务一个服务的迁移到新的nacos(双注册双发现)。

常见问题:

       1.根据需要升级spring-cloud-alibaba-XXX服务发现版本升级为2.1.4,否则注册不上。版本匹配问题。为了提高集群的稳定性及降低cpu的使用率,将spring-cloud-alibaba-XXX升级到2.2.9,因为之前版本对应nacos-client版本为1.4.1,而现在对应的版本号为2.1.0。nacos服务端与nacos客户端对应关系,spring-cloud-alibaba-XXX与nacos-client对应关系,都影响nacos使用性能。

       2.生产发版工具是坎特及jekins,由于生产环境nacos版本是1.1.0版本,在测试环境无法测出问题导致生产无法注册问题,坎特和jekins发版首先进行的是下线操作,之前版本发版超过就会自动上线状态,但是新的nacos会对下线操作emtadata缓存。默认60秒,导致还是下线操作,这个问题有很多解决方案?比如:修改默认值(由于用的腾讯云的所以不支持修改),运维掉api进行上线操作(都不想因为你的任务,别人去负责)、延长发版时间等,所以我们自己写了一个新的nacos客户端包,监听服务是否上线,如果没有上线则调用api上线操作。每一个服务都要引入这个服务注册依赖,去掉之前的。
       3.之前提到的polaris因为默认注册到public命名空间还要对其进行修改。
       4.整个流程,从头到尾不知道反复测试大概一个月的时间,因为还有其他开发任务,只能业余时间处理,在加上反复踩坑,尤其是测试完成灰度验证失败的时候是最绝望的,还要排查还要重新测试,重新走一遍。
       5.最重要的是一定要保证服务可用,并且每走一步都要进行验证是否与自己想的一样,否则一步错,步步错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要将Nacos配置迁移到数据库配置,可以按照以下步骤进行操作。 步骤1: 将Nacos中的配置导出为文件。可以通过发送GET请求来导出配置文件。如果两台机器联通,可以使用以下命令导出配置文件: curl --location --request GET 'http://ip_of_A/nacos/v1/cs/configs?export=true&group=&tenant=&appName=&ids=&dataId=' > /tmp/nacos_config.zip 如果两台机器不联通,则需要手动从机器A的Nacos管理页面下载配置文件。 步骤2: 将导出的配置文件导入到数据库中。可以通过将导出的配置文件压缩成zip文件,并将其上传到机器B的Nacos中。可以使用以下命令导入配置文件: curl --location --request POST 'http://127.0.0.1:8848/nacos/v1/cs/configs?import=true&namespace=' \ --form 'policy=OVERWRITE' \ --form 'file=@"/tmp/nacos_config.zip"' 这样,Nacos的配置就成功迁移到了数据库中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Nacos配置管理](https://blog.csdn.net/m0_61940426/article/details/126616979)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [nacos 配置迁移](https://blog.csdn.net/eddiehrs/article/details/114698951)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值