Dockerfile不会以具有sudo权限的用户身份运行脚本

时间:2015-03-19 03:36:46

标签: linux bash shell ubuntu docker

我有这个Docker文件......

FROM ubuntu:14.04 MAINTAINER Sindhu S sindhu@alum.hackerschool.org
# RUN apt-get update && apt-get -y install sudo wget bash git && rm -rf /var/cache/apt-get/archives/*
RUN adduser --disabled-password --gecos "" scrollback  
RUN adduser scrollback sudo  
RUN echo 'scrollback ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers RUN mkdir -p /home/scrollback && chown -R scrollback:scrollback /home/scrollback
WORKDIR /home/scrollback/ 
ADD https://raw.githubusercontent.com/sindhus/scrollback/install-script/tools/install.sh /home/scrollback/install.sh 
RUN chown scrollback:scrollback install.sh
RUN chmod +x install.sh
USER scrollback RUN ["/bin/bash", "-c", "/home/scrollback/install.sh"]

正如您所看到的,它应该以installback用户身份运行install.sh(此用户具有sudo权限)。基本上,脚本不应该以root身份运行,而应该以具有sudo权限的用户身份运行,因为我们需要修改一些系统文件。

我尝试过:

RUN ["/bin/bash", "-c", "sudo touch /etc/apt/sources.list.d/pgdg.list"]

这有效!

然而,当我有这条线时:

RUN ["/bin/bash", "-c", "/home/scrollback/install.sh"]

在脚本中有一行:

$(sudo echo $apt_source > /etc/apt/sources.list.d/pgdg.list)

我得到......

Adding Postgres' deb http://apt.postgresql.org/pub/repos/apt/ trusty-pgdg main source to your software sources list (need root user rights).. ./install.sh: line 136: /etc/apt/sources.list.d/pgdg.list: Permission denied

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

在bash脚本中使用sudo不是一个好习惯。而是直接使用该命令并使用sudo运行脚本。因此,您的脚本(以及在其中启动的程序)将以root权限启动。