踏遍千山万水寻找真相
背景:
我们都知道有时候会使用java来调用linux服务器上的命令,这时候自热而然的我们就想到了Runtime.getRuntime().exec(),但是今天再调用一个hive -e命令时就发生了意外。
解析:
Runtime.getRuntime().exec()和直接在linux环境中调用命令不完全一致!
比如重定向,直接用Runtime.getRuntime().exec()调用会出现阻塞,卡住,不能执行成功
解决方法
Runtime.getRuntime().exec(new String[]{"/bin/sh","-c",command},null,null),闪亮登场,使用这种方法就可以解决hive -e ”sql > path“的问题。
一次一个小技巧