it-swarm-ko.tech

sudo echo "something">> / etc / privilegedFile이 작동하지 않습니다.

이것은 매우 간단한 질문입니다. Linux에서의 Sudo 사용 권한에 관해서는 꼭 그래야 할 것처럼 보입니다.

/etc/hosts 또는 유사한 파일에 무언가를 추가하려고하지만 루트로도 >>>를 모두 사용할 수 없기 때문에 끝낼 수없는 경우가 많습니다.

Root로 su 또는 Sudo su을하지 않아도이 작업을 수행 할 수 있습니까?

529
David

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
762
Yoo

문제는 쉘이 Sudo 나 echo가 아닌 출력 리디렉션을 수행하므로 일반 사용자로 수행된다는 것입니다.

다음 코드 스 니펫을 시도해보십시오.

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

문제는 리디렉션을 처리하는 것이 귀하의 쉘이라는 것입니다. Sudo에서 실행중인 프로세스가 아닌 사용자 권한으로 파일을 열려고합니다.

다음과 같이 사용하십시오.

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"

작동해야합니다. 문제는>와 >>가 "sudoed"명령이 아닌 쉘에 의해 처리된다는 것입니다. 따라서 사용 권한은 사용자가 아닌 "sudoing"사용자가 아닙니다.

13
agnul

호기심이 많은 사람에게는 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"
9
msanford

Bash에서는 stdout을 깨끗하게 유지하기 위해 > /dev/null와 함께 tee을 사용할 수 있습니다.

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

유의 답 을 사용하여 이것을 ~/.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
}
4
hololeap

sponge 패키지의 moreutils을 사용할 수 있으며 출력을 리디렉션 할 필요가 없습니다 (예 : tee 노이즈를 숨기지 않음).

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

어때요?
에코 텍스트 | Sudo dd status = 없음 = privilegedfile
/proc/sys/net/ipv4/tcp_rmem을 변경하고 싶습니다.
내가했다 :
Sudo dd status = 없음 =/proc/sys/net/ipv4/tcp_rmem <<< "4096 131072 1024000"
한 줄짜리 문서로 에코 제거

0
Marcelo Pacheco

echo 'Hello World'| (Sudo tee -a /etc/apt/sources.list)

0
Sudev Shetty

sed -iwith$ a를 사용하면 마지막 행 뒤에 변수와 특수 문자를 모두 포함하는 텍스트를 추가 할 수 있습니다.

예를 들어, $ NEW_IP와 함께 $ NEW_Host를/etc/hosts에 추가하십시오.

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

sed 옵션 설명 :

  • 내부의 경우 -i
  • $ 마지막 줄
  • 추가를위한 a
0
Noam Manos