我试图在具有严格安全措施的Kubernetes集群上运行rethinkdb映像,并且我们必须以非root用户身份运行容器,因此我使用用户1000运行它们,并将Dockerfile更改为以下内容:
FROM ubuntu:18.04
RUN apt update && apt install -y wget libcurl4 libprotobuf10 python3-pip
RUN wget https://github.com/srh/rethinkdb/releases/download/v2.3.6.srh.1/rethinkdb_2.3.6.srh.1.0bionic_amd64.deb
RUN dpkg -i rethinkdb_2.3.6.srh.1.0bionic_amd64.deb
ADD rethinkdb_tables /opt/rethinkdb_tables
RUN pip3 install rethinkdb==2.3
ADD entry_point.sh /opt/entry_point.sh
ENV RUN_ENV docker-compose
RUN id
RUN apt-get update && apt-get install -y sudo
RUN groupadd newuser
RUN useradd -u 1000 -m -g newuser newuser
RUN adduser newuser sudo
RUN echo '%sudo ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers
RUN mkdir /data
RUN chown -R newuser:0 /opt/
RUN chown -R newuser:0 /data
USER newuser
ENTRYPOINT [ "sh", "/opt/entry_point.sh" ]
CMD []
entry_point.sh是一个小的脚本,它启动rethinkdb,并且一旦rethinkdb启动,它就会导入一些表。但我得到以下错误:
Launch rethinkdb in Kubernetes
Could not create directory 'rethinkdb_data': Permission denied
我该如何解决?我不得不提到,这是我以前以非超级用户身份运行其他映像的方式,并且对它们有效。
由于rethinkdb想要创建rethinkdb_data
at,/
我决定自己在Dockerfile中创建该目录并更改其所有者,以便rethinkdb可以访问它,从而解决了我的问题。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句