XXL-Job 支持 Oracle 改造过程及注意事项
lipiwang 2024-11-25 14:53 5 浏览 0 评论
背景
XXL-Job 默认支持 MySQL 数据库,为了解决多数据库兼容问题,上周做了 Oracle 和 Postgre 的验证测试,本文记录改造 Oracle 的过程及问题。
难料的问题有两个:
- Oracle 区分大小写,而 MySQL 不区分,直接将数据从 MySQL 数据库传输到 Oracle 连接库中,所有的查询会失效。一直用 MySQL ,把 Oracle 这个基础特性给忘记了。
- Oracle 数据库所在的服务器时间和 Executor 部署机时间不同步,会导致自动检测上下线失效,时钟同步是分布式系统的一个基本保证。
第一,数据传输
首先,数据传输。还是选择用 Navicat 的数据传输功能,好处是可以保证建表语句与当前的 XXL-Job 版本一致。虽然网上有很多改造 XXL-Job 支持其他数据库的案例,但是版本不一致,最新版本是 2.3.0 ,我选择的也是这个版本,所以还是自己整理初始化 SQL 语句比较保险。
其次,从 Oracle 中导出数据库的建表语句,命名为 xxl-job-oracle.sql。查看 Oracle 的表,看到由于从 MySQL 数据库导入的,所有的表和字段名称都是小写,到了 Oracle 中都被默认加上了转义符号 "" ,会导致查询报 SQL 异常,表或视图不存在。
第三,格式化 xxl-job-oracle.sql,文件,用 EditPlus 打开后直接编辑替换为大写。所有的字段和表名大写后,项目中的 MyBatis 映射查询虽然都是小写,但是会默认转成大写,程序就能正确运行。
第四,还原两条初始化语句 XXL_JOB_GROUP 表中的 APP_NAME 字段,插入数据的内容还是小写,另外一条是 XXL_JOB_USRR 表的数据。
第五,编辑每个表,有几个数值字段,且标识为 Not null 的字段,必须设置默认值。官方给出的 MySQL 建表语句中设置了默认值,但是数据传输到其他数据库时,这项信息就缺失了,所以必须自己调整。
第六,创建自增序列,有 7 张表,需要 7 个下面的序列语句。
create sequence XXL_JOB_GROUP_ID
minvalue 1
maxvalue 999999999999
start with 2
increment by 1
cache 20
cycle;
弄好了建表语句,后面基本上就简单了。
第二步,MyBatis 的 XML 映射
接着是修改 MyBatis 的映射文件,支持 Oracle 的语法,主要体现在:
- 表别名 AS t 需要替换成 t。
- MySQL 转义字符 ` 替换成空格。
- findLogReport 中的包含小写字母别名的字段,需要用双引号转义,保证 SQL 语句正确。
- 所有的 update 语句中,为字段设置 jdbcType 属性。
- 所有的 insert 语句中的自增 ID,插入列加 ID,值为序列值,以 Group 为例:
<insert id="save" parameterType="com.xxl.job.admin.core.model.XxlJobGroup" useGeneratedKeys="true" keyColumn="id" keyProperty="id" >
INSERT INTO xxl_job_group (id, app_name, title, address_type, address_list, update_time)
values ( XXL_JOB_GROUP_SEQ.NEXTVAL,#{appname}, #{title}, #{addressType}, #{addressList}, #{updateTime} )
</insert>
- RegistryMapper 的时间操作,MySQL 的 DATE_ADD 换成 Oracle 的 to_char。
<select id="findDead" parameterType="java.util.HashMap" resultType="java.lang.Integer" >
SELECT t.id
FROM xxl_job_registry t
WHERE to_char(t.update_time,'yyyy-mm-dd HH24:MI:SS') <![CDATA[ < ]]>to_char(sysdate-#{timeout} /24/60/60,'yyyy-mm-dd HH24:MI:SS')
</select>
<select id="findAll" parameterType="java.util.HashMap" resultMap="XxlJobRegistry">
SELECT <include refid="Base_Column_List" />
FROM xxl_job_registry t
WHERE to_char(t.update_time,'yyyy-mm-dd HH24:MI:SS') <![CDATA[ > ]]>to_char(sysdate-#{timeout} /24/60/60,'yyyy-mm-dd HH24:MI:SS')
</select>
- 分页查询前面包裹一层,例如 Group 表的 pageList
SELECT * FROM (
select row_number() over(ORDER BY id DESC) r,<include refid="Base_Column_List" />
FROM xxl_job_group t
<trim prefix="WHERE" prefixOverrides="AND | OR" >
<if test="appname != null and appname != ''">
AND t.app_name like CONCAT(CONCAT('%', #{appname}), '%')
</if>
<if test="title != null and title != ''">
AND t.title like CONCAT(CONCAT('%', #{title}), '%')
</if>
</trim>
) where r between #{offset}+1 and #{offset}+#{pagesize}
第三步,JDBC 连接修改
首先,pom.xml 添加 Oracle 驱动依赖:
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.3</version>
</dependency>
其次,修改 application.properties 配置,主要是连接地址和 Query 语句:
spring.datasource.url=jdbc:oracle:thin:@IP:1521:orcl
spring.datasource.username=username
spring.datasource.password=password
spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
spring.datasource.hikari.connection-test-query=SELECT 1 FROM DUAL
至此,改造完成,完整的 xml 和 建表语句已经上传 CSDN 资源,单机下载。
启示录
兼容性改造,过程其实很简单,但是涉及到的方方面面也不少,需要逐个检查并修正。还碰到一个低级错误,改造 SQL 的时候,没有删掉原来的 SQL ,随手用 IDEA 的注释,结果还引起了意想不到的的问题。
昨天跟踪了一遍 XXL-Job 自动感应执行器上下线的问题,发现是时钟不一致导致的。自动注册和心跳检测的代码相当简洁,有空会继续分析下它的 JobRegistryHelper 类是如何实现的,只有短短的两百多行,但是值得一看。
整理成本文,希望给需要改造的同行一些启示。
- 上一篇:Oracle数据库连接配置
- 下一篇:oracle数据库安装报错解决方法
相关推荐
- linux实例之设置时区的方式有哪些
-
linux系统下的时间管理是一个复杂但精细的功能,而时区又是时间管理非常重要的一个辅助功能。时区解决了本地时间和UTC时间的差异,从而确保了linux系统下时间戳和时间的准确性和一致性。比如文件的时间...
- Linux set命令用法(linux cp命令的用法)
-
Linux中的set命令用于设置或显示系统环境变量。1.设置环境变量:-setVAR=value:设置环境变量VAR的值为value。-exportVAR:将已设置的环境变量VAR导出,使其...
- python环境怎么搭建?小白看完就会!简简单单
-
很多小伙伴安装了python不会搭建环境,看完这个你就会了Python可应用于多平台包括Linux和MacOSX。你可以通过终端窗口输入"python"命令来查看本地是否...
- Linux环境下如何设置多个交叉编译工具链?
-
常见的Linux操作系统都可以通过包管理器安装交叉编译工具链,比如Ubuntu环境下使用如下命令安装gcc交叉编译器:sudoapt-getinstallgcc-arm-linux-gnueab...
- JMeter环境变量配置技巧与注意事项
-
通过给JMeter配置环境变量,可以快捷的打开JMeter:打开终端。执行jmeter。配置环境变量的方法如下。Mac和Linux系统在~/.bashrc中加如下内容:export...
- C/C++|头文件、源文件分开写的源起及作用
-
1C/C++编译模式通常,在一个C++程序中,只包含两类文件——.cpp文件和.h文件。其中,.cpp文件被称作C++源文件,里面放的都是C++的源代码;而.h文件则被称...
- linux中内部变量,环境变量,用户变量的区别
-
unixshell的变量分类在Shell中有三种变量:内部变量,环境变量,用户变量。内部变量:系统提供,不用定义,不能修改环境变量:系统提供,不用定义,可以修改,可以利用export将用户变量转为环...
- 在Linux中输入一行命令后究竟发生了什么?
-
Linux,这个开源的操作系统巨人,以其强大的命令行界面而闻名。无论你是初学者还是经验丰富的系统管理员,理解在Linux终端输入一条命令并按下回车后发生的事情,都是掌握Linux核心的关键。从表面上看...
- Nodejs安装、配置与快速入门(node. js安装)
-
Nodejs是现代JavaScript语言产生革命性变化的一个主要框架,它使得JavaScript从一门浏览器语言成为可以在服务器端运行、开发各种各样应用的通用语言。在不同的平台下,Nodejs的安装...
- Ollama使用指南【超全版】(olaplex使用方法图解)
-
一、Ollama快速入门Ollama是一个用于在本地运行大型语言模型的工具,下面将介绍如何在不同操作系统上安装和使用Ollama。官网:https://ollama.comGithub:http...
- linux移植(linux移植lvgl)
-
1uboot移植l移植linux之前需要先移植一个bootlader代码,主要用于启动linux内核,lLinux系统包括u-boot、内核、根文件系统(rootfs)l引导程序的主要作用将...
- Linux日常小技巧参数优化(linux参数调优)
-
Linux系统参数优化可以让系统更加稳定、高效、安全,提高系统的性能和使用体验。下面列出一些常见的Linux系统参数优化示例,包括修改默认配置、网络等多方面。1.修改默认配置1.1修改默认编辑器默...
- Linux系统编程—条件变量(linux 条件变量开销)
-
条件变量是用来等待线程而不是上锁的,条件变量通常和互斥锁一起使用。条件变量之所以要和互斥锁一起使用,主要是因为互斥锁的一个明显的特点就是它只有两种状态:锁定和非锁定,而条件变量可以通过允许线程阻塞和等...
- 面试题-Linux系统优化进阶学习(linux系统的优化)
-
一.基础必备优化:1.关闭SElinux2.FirewalldCenetOS7Iptables(C6)安全组(阿里云)3.网络管理服务||NetworkManager|network...
- 嵌入式Linux开发教程:Linux Shell
-
本章重点介绍Linux的常用操作和命令。在介绍命令之前,先对Linux的Shell进行了简单介绍,然后按照大多数用户的使用习惯,对各种操作和相关命令进行了分类介绍。对相关命令的介绍都力求通俗易懂,都给...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- maven镜像 (69)
- undefined reference to (60)
- zip格式 (63)
- oracle over (62)
- date_format函数用法 (67)
- 在线代理服务器 (60)
- shell 字符串比较 (74)
- x509证书 (61)
- localhost (65)
- java.awt.headless (66)
- syn_sent (64)
- settings.xml (59)
- 弹出窗口 (56)
- applicationcontextaware (72)
- my.cnf (73)
- httpsession (62)
- pkcs7 (62)
- session cookie (63)
- java 生成uuid (58)
- could not initialize class (58)
- beanpropertyrowmapper (58)
- word空格下划线不显示 (73)
- jar文件 (60)
- jsp内置对象 (58)
- makefile编写规则 (58)