it-swarm.dev

sudo echo "something" >> / etc / privilegedFile non funziona

Questa è una domanda piuttosto semplice, almeno sembra che dovrebbe essere, sui permessi Sudo in Linux.

Ci sono molte volte in cui voglio solo aggiungere qualcosa a /etc/hosts o un file simile, ma alla fine non riesco a farlo perché sia ​​> che >> non sono permessi, anche con root.

C'è qualche modo per fare questo lavoro senza dover su o Sudo su in root?

529
David

Utilizza tee --append o tee -a.

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

Assicurati di evitare citazioni tra virgolette.

Per evitare di ritrasmettere i dati alla console, reindirizzare l'output su/dev/null.

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

Il problema è che Shell esegue il reindirizzamento dell'output, non Sudo o echo, quindi questo viene eseguito come utente normale.

Prova il seguente frammento di codice:

Sudo sh -c "echo 'something' >> /etc/privilegedfile"
294
Matt P

Il problema è che è Shell che gestisce il reindirizzamento; sta cercando di aprire il file con le tue autorizzazioni non quelle del processo che stai eseguendo in Sudo.

Usa qualcosa come questo, forse:

Sudo sh -c "echo 'something' >> /etc/privilegedFile"
31
Incident
Sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
17
Vinko Vrsalovic

Fare

Sudo sh -c "echo >> somefile"

dovrebbe funzionare. Il problema è che> e >> sono gestiti dalla Shell, non dal comando "sudoed", quindi i permessi sono i tuoi, non quelli dell'utente su cui stai "sudo".

13
agnul

Vorrei notare, per i curiosi, che puoi anche citare un heredoc (per blocchi di grandi dimensioni):

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"
9
msanford

In bash puoi usare tee in combinazione con > /dev/null per mantenere pulito lo stdout.

 echo "# comment" |  Sudo tee -a /etc/hosts > /dev/null
8
Vytenis Bivainis

Usando la risposta di Yoo , metti questo nel tuo ~/.bashrc:

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

Ora puoi eseguire sudoe 'deb blah # blah' /etc/apt/sources.list


Edit:

Una versione più completa che consente di reindirizzare l'input o il reindirizzamento da un file e include un parametro -a per disattivare l'accodamento (attivato per impostazione predefinita):

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
}
4
hololeap

Puoi anche utilizzare sponge dal package moreutils e non è necessario reindirizzare l'output (ad esempio, nessun tee rumore da nascondere):

echo 'Add this line' | Sudo sponge -a privfile
2

echo "Hello World" | (Sudo tee -a /etc/apt/sources.list)

0
Sudev Shetty