it-swarm-tr.com

sudo echo "bir şey" >> / etc / privilegedFile çalışmıyor

Bu oldukça basit bir sorudur, en azından olması gerektiği gibi, Linux'taki Sudo izinleri hakkında.

/etc/hosts veya benzer bir dosyaya sadece bir şey eklemek istediğimde, ancak > ve >> öğelerine izin verilmediğinden, kök ile bile olsa çok fazla zamanım var. .

su veya Sudo su köküne gerek kalmadan bu işi yapmanın bir yolu var mı?

542
David

tee --append veya tee -a kullanın.

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

Tırnakların içindeki alıntılardan kaçındığınızdan emin olun.

Verileri konsola geri yazdırmamak için, çıktıyı/dev/null konumuna yönlendirin.

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

(-a/--append) bayrağını hatırlayın! Sadece tee> gibi çalışır ve dosyanızın üzerine yazar. tee -a>> gibi çalışır ve dosyanın sonuna yazacaktır.

784
Yoo

Sorun, Shell'in Sudo veya echo değil, yönlendirme yapmasıdır, bu yüzden normal kullanıcı olarak yapılır.

Aşağıdaki kod parçasını deneyin:

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

Mesele şu ki, yönlendirmeyi idare eden Shell'iniz; dosyayı açmaya çalışıyor your izinleriyle Sudo altında yürüttüğünüz işlemlerin izinlerini değil.

Belki böyle bir şey kullanın:

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

Sudo sh -c "echo >> somefile"

çalışmalı. Sorun şu ki,> ve >>, "sudoed" komutuyla değil, Shell'iniz tarafından ele alınmaktadır, bu yüzden izinler sizin "sudo" olanların değil, sizindir.

13
agnul

Meraklı için, heredoc (büyük bloklar için) de alıntı yapabilirsiniz:

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

Bash içinde, stdout'u temiz tutmak için > /dev/null ile birlikte tee kullanabilirsiniz.

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

Kullanarak Yoo'nun cevabı , bunu ~/.bashrc:

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

Şimdi çalıştırabilirsiniz sudoe 'deb blah # blah' /etc/apt/sources.list


Düzenleme:

Girdiyi bir dosyaya yönlendirebilmenizi veya yönlendirebilmenizi sağlayan ve eklemeyi kapatmak için (varsayılan olarak açık olan) -a anahtarı içeren daha eksiksiz bir sürüm:

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

Ayrıca sponge paketinden moreutils kullanabilirsiniz ve çıktıyı yönlendirmeniz gerekmez (yani gizlemek için tee parazit yok):

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

Peki ya:
yankı metni | Sudo dd durumu = hiçbiri = ayrıcalıklı dosya
/Proc/sys/net/ipv4/tcp_rmem işlevini değiştirmek istiyorum.
Yaptım:
Sudo dd durumu = hiçbiri =/proc/sys/net/ipv4/tcp_rmem <<< "4096 131072 1024000"
, tek satırlık bir belge ile yankıyı ortadan kaldırır

0
Marcelo Pacheco

yankı 'Merhaba Dünya' | (Sudo tee -a /etc/apt/sources.list)

0
Sudev Shetty

sed -i$ a ile kullanarak, her iki değişkeni de içeren metin ekleyebilirsiniz. Son satırdan sonra özel karakterler.

Örneğin,/etc/hosts dizinine $ NEW_Host $ NEW_IP ile ekleme:

Sudo sed -i "\$ a $NEW_IP\t\t$NEW_Host.domain.local\t$NEW_Host" /etc/hosts

sed seçenekleri açıkladı:

  • - i yerinde
  • $ Son satır için
  • a Ekleme için
0
Noam Manos