flink 源码调试
Last updated on January 18, 2025 am
🧙 Questions
flink大版本区别比较大,当前以
1.12.7
版本为例子
☄️ Ideas
源码下载
选择tag:
release-1.12.7
建议使用gitee下载,github下载太慢了git clone -b release-1.12.7 https://gitee.com/apache/flink.git
git clone -b release-1.12.7 https://github.com/apache/flink.git
源码运行
建议使用idea进行调试
建议忽略大提交的commitIdgit config blame.ignoreRevsFile .git-blame-ignore-revs
前提
- idea安装scala插件
- 安装maven
- 安装jdk(11+)
本地编译
mvn clean package -DskipTests
生成的路径:
flink/flink-dist/target/flink-1.12.7-bin/flink-1.12.7/
调试场景
本地启动flink服务
使用git bash,将编译后的程序启动起来,并运行本地的一个jar包,判断是否可行
vim flink-1.12.7/bin/flink-daemon.sh
移除 $INTERNAL_HADOOP_CLASSPATHS
$JAVA_RUN $JVM_ARGS ${FLINK_ENV_JAVA_OPTS} "${log_setting[@]}" -classpath "`manglePathList "$FLINK_TM_CLASSPATH"`" ${CLASS_TO_RUN} "${ARGS[@]}" > "$out" 200<&- 2>&1 < /dev/null &
关闭flink
bash bin/stop-cluster.sh
cd flink-dist/target/flink-1.12.7-bin/flink-1.12.7
bash bin/start-cluster.sh
vim flink-1.12.7/bin/flink
移除 $INTERNAL_HADOOP_CLASSPATHS
exec $JAVA_RUN $JVM_ARGS $FLINK_ENV_JAVA_OPTS "${log_setting[@]}" -classpath "`manglePathList "$CC_CLASSPATH"`" org.apache.flink.client.cli.CliFrontend "$@"
bash bin/flink run examples/streaming/WordCount.jar --output log/result.text
cat log/result.text
调试本地flink服务
调试flink源码,启动flink服务
本地启动为standalonesession
模式,代码入口org.apache.flink.runtime.entrypoint.StandaloneSessionClusterEntrypoint
执行flinkSql调试flink源码
直接执行sql脚本,调试flink源码运行
目录结构
🔗 Links
flink 源码调试
https://ispong.isxcode.com/hadoop/flink/flink 源码调试/