Pergunta

Esta é uma pergunta muito simples, pelo menos, parece que ele deve ser, sobre permissões sudo em Linux.

Há um monte de vezes quando eu só quero acrescentar algo para /etc/hosts ou um arquivo semelhante, mas acabam por não ser capaz de porque ambos > e >> não são permitidos, mesmo com raiz.

Existe alguma maneira de fazer este trabalho sem ter que su ou sudo su na raiz?

Foi útil?

Solução

Use tee --append ou tee -a.

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list

Certifique-se evitar aspas dentro de aspas.

Para evitar a impressão de volta dados para o console, redirecionar a saída para / dev / null.

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list > /dev/null

Outras dicas

O problema é que o shell não redirecionamento de saída, não sudo ou eco, assim que isso está sendo feito como o usuário regular.

Tente o seguinte trecho de código:

sudo sh -c "echo 'something' >> /etc/privilegedfile"

A questão é que é o seu shell que alças redirecionamento; ele está tentando abrir o arquivo com seus permissões não as do processo que está sendo executado sob sudo.

Use algo como isto, talvez:

sudo sh -c "echo 'something' >> /etc/privilegedFile"
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"

Fazendo

sudo sh -c "echo >> somefile"

deve funcionar. O problema é que> e >> são manipulados pelo shell, e não pelo comando "sudoed", de modo que as permissões são os seus queridos, e não as do usuário que você está "sudoing" em.

Gostaria de observar, para os curiosos, que você também pode citar um heredoc (para grandes blocos):

sudo bash -c "cat <<EOIPFW >> /etc/ipfw.conf
<?xml version=\"1.0\" encoding=\"UTF-8\"?>

<plist version=\"1.0\">
  <dict>
    <key>Label</key>
    <string>com.company.ipfw</string>
    <key>Program</key>
    <string>/sbin/ipfw</string>
    <key>ProgramArguments</key>
    <array>
      <string>/sbin/ipfw</string>
      <string>-q</string>
      <string>/etc/ipfw.conf</string>
    </array>
    <key>RunAtLoad</key>
    <true></true>
  </dict>
</plist>
EOIPFW"

No bash você pode usar tee em combinação com > /dev/null para manter stdout limpo.

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null

Usando de Yoo resposta , colocar isso em seu ~/.bashrc:

sudoe() {
    [[ "$#" -ne 2 ]] && echo "Usage: sudoe <text> <file>" && return 1
    echo "$1" | sudo tee --append "$2" > /dev/null
}

Agora você pode executar sudoe 'deb blah # blah' /etc/apt/sources.list


Editar:

A versão mais completa que permite a entrada de tubo ou de redirecionamento de um arquivo e inclui um interruptor -a para desligar anexando (que é ativado por padrão):

sudoe() {
  if ([[ "$1" == "-a" ]] || [[ "$1" == "--no-append" ]]); then
    shift &>/dev/null || local failed=1
  else
    local append="--append"
  fi

  while [[ $failed -ne 1 ]]; do
    if [[ -t 0 ]]; then
      text="$1"; shift &>/dev/null || break
    else
      text="$(cat <&0)"
    fi

    [[ -z "$1" ]] && break
    echo "$text" | sudo tee $append "$1" >/dev/null; return $?
  done

  echo "Usage: $0 [-a|--no-append] [text] <file>"; return 1
}

Você também pode usar sponge do pacote moreutils e não precisa redirecionar a saída (ou seja, nenhum ruído tee para esconder):

echo 'Add this line' | sudo sponge -a privfile

echo 'Olá Mundo' | (Sudo tee -a /etc/apt/sources.list)

Isso funcionou para mim: original comando

echo "export CATALINA_HOME="/opt/tomcat9"" >> /etc/environment

comando de Trabalho

echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment

Ao usar o sed -i com $ a , você pode anexar texto, contendo ambas as variáveis ??e caracteres especiais, depois da última linha.

Por exemplo, adicionar $ NEW_HOST com US $ NEW_IP para / etc / hosts:

sudo sed -i "\$ a $NEW_IP\t\t$NEW_HOST.domain.local\t$NEW_HOST" /etc/hosts

Opções sed explicou:

  • -i para in-place
  • $ para última linha
  • a para anexar

Você pode alterar a propriedade do arquivo, em seguida, alterá-lo novamente depois de usar cat >> para acrescentar?

sudo chown youruser /etc/hosts  
sudo cat /downloaded/hostsadditions >> /etc/hosts  
sudo chown root /etc/hosts  

Algo como este trabalho para você?

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top