Вопрос

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

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

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

Это было полезно?

Решение

Использование 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

Другие советы

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

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

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

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

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

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

Делая

sudo sh -c "echo >> somefile"

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

Я хотел бы отметить, для любопытных, что вы также можете указать 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"

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

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

Используя Ответ Ю, положи это в свой ~/.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


Редактировать:

Более полная версия, которая позволяет вам передавать входные данные в файл или перенаправлять их из файла и включает в себя -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
}

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

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

echo 'Привет, мир' | (sudo tee -a /etc/apt/sources.list)

У меня это сработало:исходная команда

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

Рабочая команда

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

Используя сэд -я с $ a , вы можете добавить текст, содержащий как переменные, так и специальные символы, после последней строки.

Например, добавление $NEW_HOST с помощью $NEW_IP в /etc/hosts:

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

объясненные варианты sed:

  • для установки на месте
  • $ для последней строки
  • a для добавления

Можете ли вы изменить владельца файла, а затем изменить его обратно после использования cat >> добавить?

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

Что-то вроде этого работает для вас?

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top