【Flink入门】Flink通过sh启动集群报错

flink通过sh ${file}启动和停止集群集群会报错如下:

[fuyun@bigdata-training tools]$ sh /opt/modules/flink-1.12.0/bin/stop-cluster.sh 
/opt/modules/flink-1.12.0/bin/config.sh: line 32: syntax error near unexpected token `<'
/opt/modules/flink-1.12.0/bin/config.sh: line 32: `    done < <(find "$FLINK_LIB_DIR" ! -type d -name '*.jar' -print0 | sort -z)'
/opt/modules/flink-1.12.0/bin/config.sh: line 32: warning: syntax errors in . or eval will cause future versions of the shell to abort as Posix requires
/opt/modules/flink-1.12.0/bin/stop-cluster.sh: line 26: TMWorkers: command not found
/opt/modules/flink-1.12.0/bin/stop-cluster.sh: line 45: /jobmanager.sh: No such file or directory

原因:
flink启动和停止脚本解释器并不是bash,所以不能通过sh命令执行脚本,执行时直接输入文件绝对路径或相对路径即可/opt/modules/flink-1.12.0/bin/start-cluster.sh。如下图:

在这里插入图片描述

!/usr/bin/env bash和#!/usr/bin/bash、#!/bin/bash的比较

  • #!/usr/bin/env bash在不同的系统上提供了一些灵活性。
  • #!/usr/bin/bash将对给定的可执行文件系统进行显式控制。

通过/usr/bin/env运行程序,用户不需要去寻找程序在系统中的位置(因为在不同的系统,命令或程序存放的位置可能不同),只要程序在你的$PATH中;

通过/usr/bin/env运行程序另一个好处是,它会根据你的环境寻找并运行默认的版本,提供灵活性。

不好的地方是,有可能在一个多用户的系统中,别人在你的$PATH中放置了一个bash,可能出现错误。

大部分情况下,/usr/bin/env是优先选择的,因为它提供了灵活性,特别是你想在不同的版本下运行这个脚本;而指定具体位置的方式#!/usr/bin/bash,在某些情况下更安全,因为它限制了代码注入的可能。

可能在一些系统上/usr/bin/bash没有,而/bin/bash则一定存在的。所以/bin/bash是显示指定的优先选择。

猜你喜欢

转载自blog.csdn.net/lz6363/article/details/112472262