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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 信创迁移适配实战-修改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


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4天前
|
存储 数据处理 数据库
深入了解达梦数据库的增删查改操作:从入门到精通
深入了解达梦数据库的增删查改操作:从入门到精通
|
2天前
|
Oracle 关系型数据库 Java
java操作多数据源将oracle数据同步达梦数据库
java操作多数据源将oracle数据同步达梦数据库
|
2天前
|
SQL 关系型数据库 MySQL
国产达梦数据库使用记录
国产达梦数据库使用记录
|
3天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
15 0
|
4天前
|
安全 Java 数据库连接
在IntelliJ IDEA中通过Spring Boot集成达梦数据库:从入门到精通
在IntelliJ IDEA中通过Spring Boot集成达梦数据库:从入门到精通
|
4天前
|
安全 测试技术 数据库
达梦数据库Windows安装教程:从准备到完成
达梦数据库Windows安装教程:从准备到完成
|
4天前
|
存储 Oracle 关系型数据库
达梦数据库入门语法:从基础到进阶的指南
达梦数据库入门语法:从基础到进阶的指南
|
12天前
|
SQL 关系型数据库 MySQL
数据库的迁移
数据库的迁移
|
2天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
10 0
|
2天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections