Nextrp [CPP] RU + Many GEOs Игра на карте России | NEXTRP

sudo echo "что-то" >> / etc / privilegedFile не работает

bash shell scripting permissions sudo

176417 просмотра

14 ответа

9666 Репутация автора

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

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

Есть ли каким - то образом , чтобы сделать эту работу без необходимости suили sudo suв корень?

Автор: David Источник Размещён: 17.09.2008 04:09

Ответы (14)


17 плюса

211601 Репутация автора

sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
Автор: Vinko Vrsalovic Размещён: 17.09.2008 04:11

298 плюса

3897 Репутация автора

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

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

sudo sh -c "echo 'something' >> /etc/privilegedfile"
Автор: Matt P Размещён: 17.09.2008 04:11

31 плюса

389 Репутация автора

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

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

sudo sh -c "echo 'something' >> /etc/privilegedFile"
Автор: Incident Размещён: 17.09.2008 04:13

13 плюса

6488 Репутация автора

дела

sudo sh -c "echo >> somefile"

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

Автор: agnul Размещён: 17.09.2008 04:14

782 плюса

11088 Репутация автора

Решение

Используйте 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

Помните о ( -a/ --append) флаге! Просто teeработает как >и перезапишет ваш файл. tee -aработает как >>и напишет в конце файла.

Автор: Yoo Размещён: 15.02.2009 12:34

9 плюса

7405 Репутация автора

Я хотел бы отметить, для любопытных, что вы также можете процитировать 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"
Автор: msanford Размещён: 13.02.2014 08:10

8 плюса

1537 Репутация автора

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

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null
Автор: Vytenis Bivainis Размещён: 19.03.2014 08:53

4 плюса

651 Репутация автора

Используя ответ 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


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

Более полная версия, которая позволяет направлять входные данные или перенаправлять их из файла и включает -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
}
Автор: hololeap Размещён: 24.09.2014 05:50

-6 плюса

1 Репутация автора

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

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

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

Автор: pixistix Размещён: 21.01.2017 11:05

-1 плюса

90 Репутация автора

Это сработало для меня: оригинальная команда

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

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

echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment
Автор: f.a.abadi Размещён: 16.09.2017 06:50

0 плюса

6814 Репутация автора

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

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

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

Сед опций объяснил

  • для на месте
  • $ за последнюю строку
  • для Append
Автор: Noam Manos Размещён: 24.04.2018 01:43

2 плюса

53116 Репутация автора

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

echo 'Add this line' | sudo sponge -a privfile
Автор: Michael Goldshteyn Размещён: 27.06.2018 12:41

0 плюса

1 Репутация автора

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

Автор: Sudev Shetty Размещён: 18.10.2018 05:10

0 плюса

101 Репутация автора

Как насчет: эхо текста | sudo dd status = none of = Privilefile. Я хочу изменить / proc / sys / net / ipv4 / tcp_rmem. Я сделал: sudo dd status = none of = / proc / sys / net / ipv4 / tcp_rmem <<< «4096 131072 1024000» устраняет эхо с помощью однострочного документа

Автор: Marcelo Pacheco Размещён: 23.08.2019 10:55
Вопросы из категории :
32x32