sudo echo "что-то" >> / etc / privilegedFile не работает - PullRequest
528 голосов
/ 17 сентября 2008

Это довольно простой вопрос, по крайней мере, так кажется, о разрешениях sudo в Linux.

Часто я просто хочу добавить что-то в /etc/hosts или подобный файл, но в итоге не могу, потому что и >, и >> не разрешены, даже с root.

Есть ли способ заставить это работать без необходимости su или sudo su в root?

Ответы [ 13 ]

762 голосов
/ 15 февраля 2009

Используйте tee --append или tee -a.

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

Обязательно избегайте кавычек внутри кавычек.

Чтобы избежать печати данных обратно на консоль, перенаправьте вывод в /dev/null.

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list > /dev/null
294 голосов
/ 17 сентября 2008

Проблема в том, что оболочка выполняет перенаправление вывода, а не sudo или echo, так что это делается обычным пользователем.

Попробуйте следующий фрагмент кода:

sudo sh -c "echo 'something' >> /etc/privilegedfile"
31 голосов
/ 17 сентября 2008

Проблема в том, что ваша оболочка обрабатывает перенаправление; он пытается открыть файл с вашими разрешениями, а не с теми процессами, которые вы запускаете под sudo.

Используйте что-то вроде этого, возможно:

sudo sh -c "echo 'something' >> /etc/privilegedFile"
17 голосов
/ 17 сентября 2008
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
13 голосов
/ 17 сентября 2008

делает

sudo sh -c "echo >> somefile"

должно работать. Проблема в том, что> и >> обрабатываются вашей оболочкой, а не командой "sudoed", поэтому разрешения принадлежат вам, а не пользователю, которому вы "sudoed".

9 голосов
/ 14 февраля 2014

Я хотел бы отметить, для любопытных, что вы также можете процитировать heredoc (для больших блоков):

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"
8 голосов
/ 20 марта 2014

В bash вы можете использовать tee в сочетании с > /dev/null для поддержания чистоты стандартного вывода.

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null
4 голосов
/ 24 сентября 2014

Используя ответ Yoo , введите это в свой ~/.bashrc:

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

Теперь вы можете запустить sudoe 'deb blah # blah' /etc/apt/sources.list


Edit:

Более полная версия, которая позволяет направлять входные данные или перенаправлять их из файла и включает переключатель -a для отключения добавления (которое включено по умолчанию):

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
}
2 голосов
/ 27 июня 2018

Вы также можете использовать sponge из пакета moreutils и не нужно перенаправлять вывод (т. Е. Нет tee шума, чтобы скрыть):

echo 'Add this line' | sudo sponge -a privfile
0 голосов
/ 18 октября 2018

эхо «Hello World» | (sudo tee -a /etc/apt/sources.list)

...