我几天来一直在努力解决此问题。
文件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