**Apache DolphinScheduler** 是一个分布式、可扩展的开源工作流编排平台,拥有强大的DAG可视化界面。DolphinScheduler 3.2.2 版本于2024年7月23号正式发布,您可以通过查阅官方文档来深入了解 DolphinScheduler 的架构和技术细节。本文重点介绍如何在Amazon Web Services 使用Terraform 脚本一键快速部署DolphinScheduler的**生产可用环境**。您可以联系亚马逊云科技或DolphinScheduler社区,加入 ***海豚调度&AWS用户交流群*** 联系管理员获取免费的AWS Workshop账号,体验完整的部署流程,并快速获取一个Dophinscheduler集群进行测试体验。
#### 部署脚本的核心架构细节:
整体架构:部署基于 EKS 容器化,部署完成后会提供一个公开可访问的 ELB 代理域名进行用户访问。
data:image/s3,"s3://crabby-images/4fa2a/4fa2a55fcef32cb2c7f6681a5cd3746d599545a8" alt="1280X1280.PNG"
部署用于DolphinScheduler 的核心服务组件(全部由Terraform脚本进行部署):
- Serverless数据库:采用 [Amazon Aurora Serverless v2](https://aws.amazon.com/cn/rds/aurora/serverless/),支持弹性伸缩范围配置,默认范围为 2-16 ACUs,为系统提供弹性数据库能力。
- 持久化存储:使用[Amazon EFS](https://aws.amazon.com/cn/efs/) 提供[无服务器](https://aws.amazon.com/cn/serverless/?trk=cndc-detail)、弹性的持久化存储。
- 任务日志:默认启用远程任务日志存储,日志保存在 [Amazon S3](https://aws.amazon.com/cn/s3/) 中,支持任务级别日志的审阅。
- 依赖和文件管理:依赖项和文件管理存储在 S3 中。
- 命名空间管理:DolphinScheduler 的命名空间和节点扩展由 [Karpenter ](https://karpenter.sh/)自动管理。
以下详细说明如何快速进行DolphinScheduler部署
基础环境准备
- 获取Amazon Workshop 账户,进入workshop链接后点击OTP 输入个人邮箱进行登陆
data:image/s3,"s3://crabby-images/ef556/ef556bdb6b5efaee05414ec41b61d54684947c1d" alt="1280X1280 (1).PNG".PNG")
data:image/s3,"s3://crabby-images/5c022/5c022fbc58be74c18d98a88755cc83114f4d21fe" alt="1280X1280 (2).PNG".PNG")
data:image/s3,"s3://crabby-images/a3405/a3405a6e2191c6fae607f8326b16e790dfbaf921" alt="1280X1280 (3).PNG".PNG")
##### 创建EC2虚拟机进行部署准备
data:image/s3,"s3://crabby-images/6b1d4/6b1d4ed2c57baaa483a0b0d3b35128a6a9caba01" alt="2828247d-b7df-44ce-8f0b-e3c4698feb72.png"
data:image/s3,"s3://crabby-images/4a2fb/4a2fb09e859c753f79f7eb726f0f1d3019965e43" alt="7a8f3aad-3964-447e-af93-0aa8dae37916.png"
data:image/s3,"s3://crabby-images/e391c/e391c54d601dd8ca8a08981b5193f789a3db3994" alt="499b3e5e-2fcc-45e7-a016-bb2e20029521.png"
data:image/s3,"s3://crabby-images/48485/48485ed0db610192f7d12b75b317834a367c7c51" alt="48820435-b997-4a1a-91d3-cd9129b444cd.png"
data:image/s3,"s3://crabby-images/3f392/3f39288917dc48899153265764d051cf7f2dafdd" alt="836cdbed-9fb6-467a-9595-65fede06f788.png"
- 为EC2 关联IAM 权限,为后续创建资源
data:image/s3,"s3://crabby-images/8c836/8c83609f29d928597ceb1aec230a9157450a62dd" alt="67b6fa25-e9e3-4cbb-a7ca-1af066a145f7.png"
data:image/s3,"s3://crabby-images/4578f/4578fc08d0dff2494328b96086ac5a3a97333473" alt="930f565a-4813-499a-aece-a4f9fb859161.png"
data:image/s3,"s3://crabby-images/fc495/fc495bd2a25a27155ca682f21e33698a32662ad1" alt="18071e69-943f-45ba-afa9-0beb507c24f1.png"
data:image/s3,"s3://crabby-images/9ef02/9ef025604e9708d056f0be7673d69ea370c1febe" alt="73f157e5-a333-4aad-b080-7e6b7db6ef9d.png"
data:image/s3,"s3://crabby-images/37a44/37a44d284299219d87a00e294aa5aebd41edb865" alt="f76fc1a5-ccf9-4dc7-84bd-d0831d797e80.png"
data:image/s3,"s3://crabby-images/43c33/43c336911f7da1f21ea89bf9c59a05f0e82dc047" alt="b1f02d4b-489b-49fe-8ed9-c9a3a6399d65.png"
data:image/s3,"s3://crabby-images/7b0ac/7b0ac41b4c02c79c36723ca2ff321afb1622abe7" alt="e856b837-9390-4fd2-b3f1-0a9fc7adfe31.png"
- 更新EC2 IAM role
data:image/s3,"s3://crabby-images/6dad5/6dad52df2d1388b87f1b9a3077eb3223f4a6cb14" alt="46445236-ed01-4135-859a-0b0426d2a72d.png"
data:image/s3,"s3://crabby-images/960ce/960ce9a77c0bb0dc255f8e6ce1f0476754433f98" alt="5c85a67a-6d38-4aae-ac08-bb81a618e2dd.png"
##### 进行部署前的环境准备
data:image/s3,"s3://crabby-images/afc00/afc00fb401ddbb8fa6bb730d4aeaeb41504a08fb" alt="ec21cc34-6ea8-4b9d-badf-1c42cb7f5e18.png"
- 安装terraform
参考: https://developer.hashicorp.com/terraform/install#
```
sudo yum install -y yum-utils shadow-utils
sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/AmazonLinux/hashicorp.repo
sudo yum -y install terraform
```
- 安装helm
参考:https://docs.aws.amazon.com/zh_cn/eks/latest/userguide/helm.html
```
curl https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3 > get_helm.sh
chmod 700 get_helm.sh
./get_helm.sh
helm version | cut -d + -f 1
```
- 安装kubectl EKS(版本1.30)
参考:https://docs.aws.amazon.com/zh_cn/eks/latest/userguide/install-kubectl.html
```
curl -O https://s3.us-west-2.amazonaws.com/amazon-eks/1.30.0/2024-05-12/bin/linux/amd64/kubectl
chmod +x ./kubectl
mkdir -p \$HOME/bin && cp ./kubectl \$HOME/bin/kubectl && export PATH=\$HOME/bin:\$PATH
kubectl version --client
```
#### 安装部署
- 下载部署源码并执行部署脚本:
```
cd /opt/
# clone source code
git clone https://github.com/SEZ9/terraform-dolphinscheduler.git
# update helm dependency
cd /opt/terraform-dolphinscheduler/helm-values/dolphinscheduler/
helm repo add bitnami https://charts.bitnami.com/bitnami
helm dependency update .
# Execute deployment
cd /opt/terraform-dolphinscheduler/
sh install.sh
```
data:image/s3,"s3://crabby-images/53053/53053d136fe06e0863cf43bd63af2e7af48069d8" alt="a18f7f92-a417-409b-801b-f0f1c4ad7531.png"
等待执行完成 大约30-50分钟
#### 即刻体验
执行输出的kubectl 配置命令
data:image/s3,"s3://crabby-images/83039/83039558bb89446ad35eeba1b569cbd4422bdf75" alt="e3b8f77f-93d3-45aa-9352-234de0d35a42.png"
获取dolphinscheduler访问地址
```
kubectl get ingress -n dolphinscheduler
NAME CLASS HOSTS ADDRESS PORTS AGE
dolphinscheduler alb * xxx.elb.amazonaws.com 80 89s
访问地址为:xxx.elb.amazonaws.com:12345/dolphinscheduler
```
data:image/s3,"s3://crabby-images/8188f/8188f6cc3d4f3cea0c90b05f8e31197bc3d99cbd" alt="954f9138-a1b3-44a4-9ab6-2ee9b1c2aeea.png"