Frage

Dies ist eine ziemlich einfache Frage, zumindest scheint es, wie es sein soll, über sudo-Berechtigungen in Linux.

Es gibt eine Menge Zeit, wenn ich will nur etwas anhängen /etc/hosts oder eine ähnliche Datei, aber am Ende nicht in der Lage, weil beide > und >> sind nicht erlaubt, auch mit Wurzel.

Gibt es irgendwie, diese Arbeit zu machen, ohne in root su oder sudo su mit?

War es hilfreich?

Lösung

Mit tee --append oder tee -a.

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

Stellen Sie sicher, Zitate in Anführungszeichen zu vermeiden.

Um Druckdaten zurück an die Konsole zu vermeiden, leiten Sie die Ausgabe nach / dev / null.

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

Andere Tipps

Das Problem ist, dass die Shell tut Ausgabeumleitung, nicht sudo oder Echo, so dass diese als normalen Benutzer getan wird.

Versuchen Sie, den folgenden Codeausschnitt:

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

Das Problem ist, dass es die Shell, die Umleitung behandelt; es versucht, die Datei zu öffnen mit Ihre Berechtigungen nicht die der Prozess unter sudo Sie ausführen.

Verwenden Sie so etwas wie dieses, vielleicht:

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

Sie

sudo sh -c "echo >> somefile"

sollte funktionieren. Das Problem ist, dass> und >> von Shell behandelt werden, nicht von der „sudoed“ -Befehl, so dass die Berechtigungen sind Ihre diejenigen, nicht diejenigen des Benutzers Sie „sudoing“ in sind.

Ich möchte darauf hinweisen, für die Neugierigen, dass Sie auch eine heredoc (für große Blöcke) zitieren:

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"

In der bash Sie tee in Kombination mit > /dev/null können stdout sauber zu halten.

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

Mit Yoo Antwort , setzen Sie diese in Ihrem ~/.bashrc:

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

Jetzt können Sie laufen sudoe 'deb blah # blah' /etc/apt/sources.list


Edit:

Eine vollständigere Version, die Sie Pipeeingabe ermöglicht in oder aus einer Datei umleiten und enthält einen -a Schalter auszuschalten Anhänge (das ist standardmäßig aktiviert):

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
}

Sie können auch sponge vom moreutils Paket verwenden und nicht brauchen die Ausgabe zu umleiten (das heißt, kein tee Rauschen zu verbergen):

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

echo 'Hallo Welt' | (Sudo tee -a /etc/apt/sources.list)

Das funktionierte für mich: Original-Befehl

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

Arbeits Befehl

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

Durch die Verwendung von sed -i mit a $, können Sie anfügen Text, beide Variablen und Sonderzeichen enthält, nach der letzten Zeile.

Zum Beispiel das Hinzufügen $ NEW_HOST mit $ NEW_IP / etc / hosts:

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

sed Optionen erläutert:

  • -i für in-place
  • $ für letzte Zeile
  • a für append

Können Sie sich das Eigentum an der Datei ändern Sie es dann nach der Verwendung von cat >> ändern zurück zu anhängen?

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

So etwas wie diese Arbeit für Sie?

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top