信创迁移适配实战-修改Nacos2.0.4源码以连接达梦数据库DM8

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 信创迁移适配实战-修改Nacos2.0.4源码以连接达梦数据库DM8

背景


因信创迁移适配需要,我们需要将服务部署在国产化平台上。其中涉及到 Nacos 连接国产数据库的问题,这里以达梦数据库为例,使用CV大法(复制、粘贴)完成对 Nacos 源码修改,来实现对达梦数据库 DM8 的连接支持。


如果直接通过官方版本连接国产化数据库,或者MariaDB,便会报错(以下错误会在无法连接数据库时抛出,可能是端口未开放、数据库不允许远程连接等,反正就是不能成功与数据库建立连接。。):


Nacos Server did not start because dumpservice bean construction failure: No DataSource set


其实说白了只是换个驱动而已。这里以实际迁移需要作为出发点,仅仅将涉及 MySQL 数据源的地方改为 DM8 对应的代码,并未考虑兼容多种数据源、同时支持多种数据库的连接,因为有这类需求的都是改为对某个数据库的支持后,直接扔到服务器运行即可。当然,如果真的需要扩展对多种数据库的支持,那么改起来也并复杂,只是这时候建议直接切换 GithubNacos 源码分支到feature_multiple_datasource_support


由于本系列文章仅用于记录当时项目的国产化迁移过程,不涉及太多的理论内容,基本都是一系列的操作过程,所以行文上就直接上操作了。如果您有任何疑问,欢迎留言评论。


从前车马很慢,书信很远,一生只够爱一个人。

如今生活太快,时间太少,不要绕圈子,给我来个痛快的。


下载源码


我这里使用的是 Nacos2.0.4本:github.com/alibaba/nac…


项目依赖


将达梦8的驱动安装至本地 Maven 仓库(驱动在安装包里有,包括文档)。


  • 本地仓库
mvn install:install-file -Dfile=D:\Java\IdeaProjects\dmtest\drivers\jdbc\DmJdbcDriver18.jar -DgroupId=com.dm -DartifactId=DmJdbcDriver18 -Dversion=1.8 -Dpackaging=jar

image.png


修改源码


pom.xml


修改nacos-config模块的pom依赖。

<dependency>
            <groupId>com.dm</groupId>
            <artifactId>DmJdbcDriver18</artifactId>
            <version>1.8</version>
        </dependency>

image.png


PropertiesConstant.java,PropertyUtil.java


  • PropertiesConstant.java
public static final String MYSQL = "mysql";
// 增加常量
public static final String DM8 = "dm8";
  • PropertyUtil.java
//            setUseExternalDB(PropertiesConstant.MYSQL
//                    .equalsIgnoreCase(getString(PropertiesConstant.SPRING_DATASOURCE_PLATFORM, "")));
            setUseExternalDB(PropertiesConstant.DM8
                    .equalsIgnoreCase(getString(PropertiesConstant.SPRING_DATASOURCE_PLATFORM, "")));

image.png


ExternalDataSourceProperties.java,ExternalDataSourceServiceImpl.java


复制 ExternalDataSourcePropertiesExternalDataSourceServiceImpl ,分别重命名为 DM8DataSourcePropertiesDM8DataSourceServiceImpl 。修改驱动名称,以及 DM8DataSourceServiceImpl.java 对应的类名称。


  • DM8DataSourceProperties.java
private static final String JDBC_DRIVER_NAME = "dm.jdbc.driver.DmDriver";
  • DM8DataSourceServiceImpl.java
dataSourceList = new DM8DataSourceProperties()
        .build(EnvUtil.getEnvironment(), (dataSource) -> {
            JdbcTemplate jdbcTemplate = new JdbcTemplate();
            jdbcTemplate.setQueryTimeout(queryTimeout);
            jdbcTemplate.setDataSource(dataSource);
            testJtList.add(jdbcTemplate);
            isHealthList.add(Boolean.TRUE);
        });

image.png


DynamicDataSource.java


主要是将 MySQL 的实现类换为我们复制出来的 DM8DataSourceServiceImpl

if (PropertyUtil.isEmbeddedStorage()) {
                if (localDataSourceService == null) {
                    localDataSourceService = new LocalDataSourceServiceImpl();
                    localDataSourceService.init();
                }
                return localDataSourceService;
            } else {
                if (basicDataSourceService == null) {
                    basicDataSourceService = new DM8DataSourceServiceImpl();
                    basicDataSourceService.init();
                }
                return basicDataSourceService;
            }

image.png

打完收工。


编译打包


mvn -Prelease-nacos -Dmaven.test.skip=true -Dpmd.skip=true -Dcheckstyle.skip=true clean install -U


编译输出在 \nacos-2.0.4\distribution\target\nacos-server-2.1.0-SNAPSHOT (我这里版本是自动从2.0.4升为2.1.0-SNAPSHOT快照版本)下的 nacos 目录。至此,属于我们自己的 Nacos 版本诞生了。

image.png


修改配置


依然是手动修改配置 conf\application.properties ,连接达梦数据库。

###If use DM8 as datasource:
spring.datasource.platform=dm8
###Count of DB:
db.num=1
###Connect URL of DB:
db.url.0=jdbc:dm://192.168.21.64:5236
db.user.0=SYSDBA
db.password.0=SYSDBA


数据迁移


既然我们要用 Nacos 连接达梦数据库,前提我们要把 Nacos 的数据或者 SQL 语句迁移到达梦数据库。借助 DM数据迁移工具 ,完成 Nacos 配置数据表迁移到达梦数据库。

image.png


连接成功


不出意外,成功启动 Nacos 后,可以看到这样的界面,左上角显示了我们编译后的版本号。

image.png


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
5月前
|
JavaScript API PHP
WordPress/Laravel企业官网源码-自适应多端SEO-前后端分离源码含数据库与部署文档​
本文详解如何结合WordPress与Laravel构建现代化企业官网,涵盖响应式设计、SEO优化、前后端分离、数据库安全及自动化部署。通过实战案例展示性能提升成果,并展望AI、云原生与区块链的未来融合方向,助力企业实现数字化增长。
|
5月前
|
数据库
【赵渝强老师】达梦数据库实例的状态
达梦数据库实例包含NORMAL、PRIMARY和STANDBY三种模式,以及MOUNT、OPEN和SUSPEND三种状态。模式之间可在MOUNT状态下相互转换,不同状态与模式适用于数据库的启动、配置及运行需求。
337 1
|
10月前
|
前端开发 数据库
会议室管理系统源码(含数据库脚本)
会议室管理系统源码(含数据库脚本)
188 0
|
11月前
|
SQL 缓存 分布式数据库
【赵渝强老师】达梦数据库的线程结构
达梦数据库采用单进程、多线程结构,利用对称服务器架构实现高效资源利用与可扩展性。其核心线程类型包括监听线程(管理客户端连接)、I/O线程(处理数据页读写)、工作线程(执行数据操作)、调度线程(定时任务管理)和日志刷新线程(确保REDO日志刷盘)。通过合理分工与同步机制,达梦数据库实现了高性能与稳定性。视频讲解进一步详细介绍了各线程的功能与协作方式。
322 1
【赵渝强老师】达梦数据库的线程结构
|
10月前
|
Java 关系型数据库 MySQL
Java汽车租赁系统源码(含数据库脚本)
Java汽车租赁系统源码(含数据库脚本)
275 4
|
11月前
|
SQL 存储 缓存
【赵渝强老师】达梦数据库的内存结构
本文介绍了达梦数据库管理系统的内存结构,包括内存池、缓冲区、排序区和哈希区。内存池分为共享内存池和运行时内存池,能够提高内存申请与释放效率,并便于监控内存使用情况。缓冲区涵盖数据缓冲区、日志缓冲区、字典缓冲区和SQL缓冲区,用于优化数据读写和查询性能。排序区和哈希区分别提供排序和哈希连接所需的内存空间,通过合理配置参数可提升系统效率。文内附有具体配置示例及视频讲解,帮助用户深入理解达梦数据库的内存管理机制。
374 0
|
10月前
|
存储 Kubernetes 安全
Nacos-Controller 2.0:使用 Nacos 高效管理你的 K8s 配置
无论是使用 Nacos-Controller 实现配置的双向同步,还是直接在应用中接入 Nacos SDK 以获得更高级的配置管理特性,都能显著提升配置管理的灵活性、安全性和可维护性。使用 Nacos,您能够更好地管理和优化您的应用配置,从而提高系统的稳定性和可靠性。
841 49
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
2125 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
1463 136
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
1163 207