Dinky项目常规部署指南:从数据库初始化到服务启动

Dinky项目常规部署指南:从数据库初始化到服务启动

dinky Dinky is an out-of-the-box, one-stop, real-time computing platform dedicated to the construction and practice of Unified Streaming & Batch and Unified Data Lake & Data Warehouse. Based on Apache Flink, Dinky provides the ability to connect many big data frameworks including OLAP and Data Lake. dinky 项目地址: https://gitcode.com/gh_mirrors/di/dinky

前言

Dinky作为一款强大的数据开发平台,其部署过程需要特别注意数据库配置、依赖管理和服务启动等关键环节。本文将详细介绍Dinky的常规部署流程,帮助用户快速搭建稳定运行的Dinky环境。

数据库初始化

Dinky采用MySQL作为后端存储数据库,支持MySQL 5.7及以上版本。数据库初始化是部署的第一步,需要特别注意权限配置和版本差异。

MySQL 5.x版本配置

对于MySQL 5.x版本,执行以下SQL命令:

# 登录MySQL
mysql -uroot -p

# 创建数据库
CREATE DATABASE dinky;

# 创建用户并授权
GRANT ALL PRIVILEGES ON dinky.* TO 'dinky'@'%' IDENTIFIED BY 'dinky' WITH GRANT OPTION;
FLUSH PRIVILEGES;

MySQL 8.x版本配置

MySQL 8.x在用户认证方式上有所变化,需要使用以下命令:

# 登录MySQL
mysql -uroot -p

# 创建数据库
CREATE DATABASE dinky;

# 创建用户并设置认证方式
CREATE USER 'dinky'@'%' IDENTIFIED WITH mysql_native_password BY 'dinky';

# 授权
GRANT ALL PRIVILEGES ON dinky.* TO 'dinky'@'%';
FLUSH PRIVILEGES;

数据库初始化脚本执行

首次部署时,需要执行初始化脚本:

# 使用dinky用户登录
mysql -h fdw1 -udinky -pdinky

# 执行初始化脚本
USE dinky;
SOURCE /opt/dinky/sql/dinky-mysql.sql;

Dinky服务部署

版本选择注意事项

从Dinky v1.0.0开始,项目采用了新的打包方式,每个版本都针对特定Flink版本进行了适配。部署前需确认:

  1. 选择与您Flink环境匹配的Dinky版本
  2. 不再支持多版本共存的单一二进制包

解压安装包

tar -zxf dinky-release-${flink.version}-${dinky.version}.tar.gz
mv dinky-release-${flink.version}-${dinky.version} dinky
cd dinky

配置文件调整

主配置文件修改

编辑config/application.yml文件,设置数据库类型:

spring:
  application:
    name: Dinky
  profiles:
    active: ${DB_ACTIVE:mysql}  # 可选值:[h2,mysql,pgsql]

MySQL配置文件修改

编辑config/application-mysql.yml文件,配置数据库连接:

spring:
  datasource:
    url: jdbc:mysql://${MYSQL_ADDR:127.0.0.1:3306}/${MYSQL_DATABASE:dinky}?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=convertToNull&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true
    username: ${MYSQL_USERNAME:dinky}
    password: ${MYSQL_PASSWORD:dinky}
    driver-class-name: com.mysql.cj.jdbc.Driver

依赖管理

Dinky需要Flink环境支持,需特别注意以下依赖管理要点:

必须上传的依赖

  1. JDBC驱动:需手动上传MySQL/PostgreSQL驱动到libextends目录
  2. Hadoop依赖:监控功能强依赖Hadoop,即使不使用Hadoop功能也需上传

Flink依赖配置

将对应Flink版本的依赖放入extends/flink${FLINK_VERSION}目录,例如Flink 1.16.x需要:

flink-cep-1.16.1.jar
flink-connector-files-1.16.1.jar
flink-connector-jdbc-1.16.1.jar
flink-csv-1.16.1.jar
flink-dist-1.16.1.jar
flink-json-1.16.1.jar
flink-scala_2.12-1.16.1.jar
flink-shaded-hadoop-2-uber-2.7.5-8.0.jar
flink-shaded-zookeeper-3.5.9.jar
flink-table-api-java-uber-1.16.1.jar
flink-table-planner_2.12-1.16.1.jar
flink-table-runtime-1.16.1.jar

特别注意事项

  1. 必须替换带loader的planner jar包为不带loader的版本
  2. 对于standalone、HDFS、K8s等集群上的Flink集群同样需要此操作

服务启动与管理

基本操作命令

# 启动服务
sh auto.sh start

# 停止服务
sh auto.sh stop

# 重启服务
sh auto.sh restart

# 查看服务状态
sh auto.sh status

# 前台启动(调试用)
sh auto.sh startOnPending

版本指定启动

从1.0.2版本开始支持自动检测Flink版本,也可手动指定:

# 指定Flink 1.16版本启动
sh auto.sh start 1.16

Nginx配置建议

Dinky使用SSE技术实现日志推流,使用Nginx代理时需要特别配置:

proxy_buffering off;
proxy_cache off;
proxy_read_timeout 86400s;
proxy_send_timeout 86400s;

访问与登录

服务启动后,默认访问地址为http://127.0.0.1:8888,默认管理员账号为:

  • 用户名:admin
  • 密码:dinky123!@#

建议首次登录后立即修改默认密码。

总结

本文详细介绍了Dinky项目的完整部署流程,从数据库初始化到服务启动,涵盖了各个关键环节的配置要点和注意事项。正确完成这些步骤后,您将获得一个稳定运行的Dinky环境,为后续的数据开发工作奠定坚实基础。

dinky Dinky is an out-of-the-box, one-stop, real-time computing platform dedicated to the construction and practice of Unified Streaming & Batch and Unified Data Lake & Data Warehouse. Based on Apache Flink, Dinky provides the ability to connect many big data frameworks including OLAP and Data Lake. dinky 项目地址: https://gitcode.com/gh_mirrors/di/dinky

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

资源下载链接为: https://pan.quark.cn/s/7cc20f916fe3 以下是对“js做的期末项目”的介绍:这是一个以童话为主题的前端开发作品,通过一系列功能实现,打造出了一个互动性强且视觉效果吸引人的用户界面,充分展现了作者对JavaScript语言的掌握程度。在项目中,作者运用了诸多JavaScript知识点。首先是DOM操作,JavaScript与HTML文档对象模型(DOM)紧密相连,可动态地创建、修改或删除页面元素,像document.getElementById()、document.querySelector()或document.querySelectorAll()等方法,就可能被用于选择和操作DOM节点。其次,为实现用户交互,例如轮播图切换等功能,addEventListener()函数被用来添加事件监听器,涵盖点击、滑动等事件,事件处理函数则依据用户行为执行相应逻辑。再者,JavaScript能够改变元素的CSS样式,通过element.style.property = value的方式,实现诸如轮播图过渡动画、照片墙图片淡入淡出等动态效果。在处理照片墙等涉及集合数据的场景时,数组的遍历方法,如forEach()、for...of循环或map()等,可能会被用到,以便显示或操作多个元素。闭包(Closure)在项目中也发挥了作用,它常用于封装私有变量和函数,保障数据安全,同时实现一些特定功能,像计时器控制等。为了实现自动轮播等功能,setTimeout()或setInterval()函数被用来定期执行任务,比如切换图片。在控制程序流程方面,if...else、switch语句以及逻辑运算符&&、||、!不可或缺,它们依据条件执行不同的代码块。函数是JavaScript的重要组成部分,项目中可能定义了多个函数,包括初始化页面、处理用户输入
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

幸愉旎Jasper

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值