【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是显示指定的优先选择。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值