如何在Windows上搭建并运行DolphinScheduler前后端开发环境
作者:海豚调度研究随笔
编辑整理:曾辉
前言
Apache DolphinScheduler 是一个优秀的分布式调度系统,广泛应用于大数据处理和自动化任务管理中。本文详细介绍了如何在Windows环境下搭建Apache DolphinScheduler的前后端开发环境。
包括从源码的下载、环境配置、数据库初始化、依赖安装等具体步骤,帮助开发者在本地快速搭建并运行DolphinScheduler,适用于新手开发者和有一定经验的技术人员。
相关链接
- Apache DolphinScheduler官网:https://dolphinscheduler.apache.org/zh-cn
- Apache DolphinScheduler源码仓库:https://github.com/apache/dolphinscheduler/
一、环境准备
1. 下载源码
首先,前往 DolphinScheduler官网 下载 dolphinscheduler-3.1.9-release.zip
源码压缩包,并将其移动到你的IDEA工作目录中。接着,使用IDEA工具解压并打开该项目。你将看到如下界面:
data:image/s3,"s3://crabby-images/83498/83498fb7d4a7eb7f50d542ce3f1ab7dca803014e" alt=""
2. 修改IDEA项目配置
找到 .idea
文件夹下的 workspace.xml
文件,打开并进行如下修改:
data:image/s3,"s3://crabby-images/4c86e/4c86ef256064d957e3bc7f7b16625123a214816f" alt=""
在 <component name="PropertiesComponent">
下增加一行<property name="dynamic.classpath" value="true"
data:image/s3,"s3://crabby-images/897cc/897cc67a5771340c287407b0c3d6d7528246bca9" alt=""
打开dolphinscheduler-bom
模块的pom文件,将MySQL和Oracle的依赖中的<scope>test</scope>
注释掉,右上角的Maven要记得点击进行更新。
data:image/s3,"s3://crabby-images/413c5/413c5bb40ad87d808f09f16f2187ae0a292fb9ef" alt=""
这将动态调整项目的类路径配置,确保IDEA能够正常加载所需的依赖包。
二、数据库配置
创建DolphinScheduler数据库
在MySQL中创建 dolphinscheduler
数据库,并执行提供的SQL脚本进行数据库初始化。
data:image/s3,"s3://crabby-images/0eddb/0eddb5c87d2034e758d03825ab98da9a172d68df" alt=""
data:image/s3,"s3://crabby-images/21650/21650a7d305b3018193983f7969071e5ea256655" alt=""
data:image/s3,"s3://crabby-images/b4919/b4919f2e8aca634de818d64801dac950c1267b64" alt=""
data:image/s3,"s3://crabby-images/d10d1/d10d1a2ac28dda99176932712081424ad8072a01" alt=""
配置 application.yaml
打开 dolphinscheduler-api
模块的 application.yaml
文件,修改以下配置:
- 时区(time-zone):根据需要调整。
- MySQL 连接信息:填写数据库连接的URL、用户名和密码。
- Zookeeper配置:根据你的Zookeeper集群配置进行调整。
data:image/s3,"s3://crabby-images/f936c/f936c8b269801f0e2f97f7e9d83c4095bce58ea4" alt=""
data:image/s3,"s3://crabby-images/aa431/aa4311dd897e5f25b62ba9b393fdca7c59ddd8ce" alt=""
如果IDEA提示缺少MySQL JDBC驱动,可以点击红灯泡提示进行自动加载。
data:image/s3,"s3://crabby-images/b0050/b005077f876f224c75cfc12ad4bf3845d9e78c43" alt=""
data:image/s3,"s3://crabby-images/5a551/5a5519f736878e78af84c0141762bcae2732943e" alt=""
确认Quartz调度的JDBC Delegate类为 org.quartz.impl.jdbcjobstore.StdJDBCDelegate
data:image/s3,"s3://crabby-images/be567/be56734e0d232ea06f9cb3a6545e09350c1c76b8" alt=""
本地Zookeeper配置
如果Zookeeper在本地运行且已正确安装,则无需修改Zookeeper相关配置。否则,需要根据你的Zookeeper集群环境进行调整。
data:image/s3,"s3://crabby-images/6977c/6977cb31e0d7088ccb94800abaf63d25acf37990" alt=""
三、模块配置
配置 dolphinscheduler-master
模块
在 dolphinscheduler-master
模块中,打开 application.yaml
文件,确保MySQL、Zookeeper的相关参数配置正确,并根据你的需求调整时区配置。
data:image/s3,"s3://crabby-images/a507d/a507dea90ac5b7007b99a55ebc38ce198ad09b4f" alt=""
data:image/s3,"s3://crabby-images/2aeb5/2aeb5cd1798c74018d719e873534f84a8322f110" alt=""
配置 dolphinscheduler-worker 模块
类似于 Master 模块,在 dolphinscheduler-worker
模块的 application.yaml
中,同样需要更新MySQL、Zookeeper和时区等相关配置。
data:image/s3,"s3://crabby-images/5dc74/5dc743fc91325ef463ddeb812f6722c65af9b868" alt=""
配置 dolphinscheduler-alert 模块
打开 dolphinscheduler-alert 模块的 application.yaml 文件,修改MySQL的连接信息和时区配置,确保警报模块能够正确连接到数据库。
data:image/s3,"s3://crabby-images/56ec6/56ec6649482470c38cecc5808e98228288d9950a" alt=""
修改 dolphinscheduler-ui
模块的 package.json
为了避免版本冲突,打开 dolphinscheduler-ui
模块的 package.json
文件,去除所有 ^ 符号。
data:image/s3,"s3://crabby-images/82e8d/82e8dd9f3c811ecb1ff6043646390ea32130dbc0" alt=""
data:image/s3,"s3://crabby-images/75c29/75c2958a4647d2c5ef0ea87241b0d35cc6f2d824" alt=""
四、启动后端服务
确保你的MySQL数据库和Zookeeper集群已正常启动,依次启动以下后端服务:
- ApiApplicationServer
- MasterServer
- WorkerServer
- AlertServer
启动成功后,打开浏览器访问API服务的Swagger文档,确认服务是否正常运行:http://localhost:12345/dolphinscheduler/swagger-ui/index.html#/
data:image/s3,"s3://crabby-images/7dc71/7dc71bbb8ee24aacb3e301c7055c8df817eb26d2" alt=""
五、搭建前端开发环境
- 安装Node.js和Pnpm
Apache DolphinScheduler的前端依赖于Node.js和Pnpm。
请根据以下链接下载并安装:
- Node.js (v16.13+):https://nodejs.org/en/download
- Pnpm (v6.x):https://pnpm.io/installation
data:image/s3,"s3://crabby-images/bcbb8/bcbb87e4e714a5e6dd0b54761c5fb1327ea12406" alt=""
- 安装前端依赖并启动
进入dolphinscheduler-ui
目录,进入cmd命令行窗口后运行pnpm install,安装后会在目录下生成node_modules目录,然后运行pnpm run dev即可。
data:image/s3,"s3://crabby-images/d4c54/d4c544de7ce73b40a8e449be5a8609d8272fa89a" alt=""
data:image/s3,"s3://crabby-images/40ac4/40ac41987edcdec598b5fb0bba453d9b46607a58" alt=""
data:image/s3,"s3://crabby-images/e2891/e28911da476b9e44d965080f73f9262f90d6f478" alt=""
在浏览器中访问http://localhost:5173
,使用默认账号密码 admin/dolphinscheduler123 登录系统,开始使用Apache DolphinScheduler。
data:image/s3,"s3://crabby-images/18bb6/18bb60ea284c838dbbadca54f848fc04009d4b1f" alt=""
结语
通过本教程,你已经成功在Windows系统上搭建并运行了DolphinScheduler的前后端开发环境。这为开发者提供了一个完整的本地开发调试环境,使得对DolphinScheduler的进一步开发和测试更加高效。
希望本文能够帮助你顺利搭建环境,并推动你在DolphinScheduler开发上的进展。如果遇到问题,欢迎参考官方文档或社区支持。
本文由 白鲸开源 提供发布支持!