我几天来一直在努力解决此问题。

文件1:docker-entrypoint.sh

#!/bin/bash
set -e
source /home/${HADOOP_INSTALL_USERNAME}/.bashrc
kinit -kt /home/${HADOOP_INSTALL_USERNAME}/keytab/dept-test-hadoop.${HADOOP_INSTALL_ENV}.keytab dept-test-hadoop
mkdir /tmp/test222222
exec "$@"

Dockerfile的:
ENTRYPOINT ["/home/dept-test-hadoop/docker-entrypoint.sh"]

docker 运行命令:
docker run -it hadoop-hive:v1 /bin/mkdir /tmp/test1

挑战或我正在尝试执行的命令是作为命令行参数传递给docker run命令的命令。请注意,这些命令需要kerberos身份验证

1)我已经注​​意到/tmp/test222222,但是在上面的docker run命令中我看不到像/tmp/test1的代码。我认为docker-entrypoint.sh中的我的exec "$@"没有执行。但是我可以确认脚本正在执行,因为可以看到/tmp/test222222
2)有什么方法可以分配环境变量的值?
ENTRYPOINT ["/home/dept-test-hadoop/docker-entrypoint.sh"]

最佳答案

只要容器创建目录,它就会退出。您的容器寿命是exec命令或docker-entrypoint的寿命,因此您的容器将在exec "$@"之后不久死亡。

如果您正在寻找一种从env创建目录的方法,那么可以尝试一下

#!/bin/bash
set -x
source /home/${HADOOP_INSTALL_USERNAME}/.bashrc
kinit -kt /home/${HADOOP_INSTALL_USERNAME}/keytab/dept-test-hadoop.${HADOOP_INSTALL_ENV}.keytab dept-test-hadoop
mkdir $MY_DIR
ls
exec "$@"

因此,现在将MY_DIR传递给env,但要记住漫长的过程。
docker run -it -e MY_DIR=abcd hadoop-hive:v1  "your_long_running_process_to_exec"

例如
docker run -it -e MY_DIR=abcd hadoop-hive:v1 "<hadoop command>"

如果您在exec中从ENV运行任何进程,那么您也可以尝试
#!/bin/sh
set -x
mkdir $MY_DIR
ls
exec ${START_PROCESS}

这样您就可以在运行时通过
docker run -it -e MY_DIR=abcd -e START_PROCESS=my_process hadoop-hive:v1

10-06 10:05
查看更多