우째이런일이... chown

ㅡ,.ㅡ;;의 이미지

제가 권한설정을 좀 바꿔주다가 아주 큰일날뻔했습니다.

문제는 루트로 특정계정(/home/aaaa/data )에들어가서

그하위의 모든 숨김파일들을 특정유저로

소유권을 변경하려고 했습니다... 그래서 내린명령이..

chown -R xxxx:xxxx .*

이렇게 했는데.. 불과 1초면 끝나야할 작업이.. 수십초가 지나도 끝이 나질
않는것입니다.. 순간 혹시..하는생각에.. 빨리 중단시켰죠..

보아하니 바로 설마했던문제가 발생했더군요...
이넘이 하위의 파일뿐만아니라.. 모든상위 또그하위 시스템전체를 다
바꿔버리는중이었더라고요..

저명령어가 현제 하위뿐아니라.. .의 하위 ..의 하위 까지도 다바꾸고
있었던거죠.. ..의 하위를 바꾸는것은 곧 자기부모의 모든것을 다바꾸고
다시 거기서 ..의 모든것을 바꾸니.. 즉 전체 시스템이 다바뀌게 되는거였던거죠.

다행이 계정아랫쪽이 변경되고.. /dev/ 가 조금 변경된거 같아 괜찮았는데
하마트면..... 큰일날뻔했습니다.. X윈도가 첨에 안되던걸 권한원상태로 최대한
해주려 했는데 이제 되는데 그래도 머가 약간 이상한거 같기도하고..쩝..

그런데... rm -r 명령어는 .과 .. 을 제외하고 행하자나요..
근데 chown 은 이상하게 하위뿐아니라상위까지 행하는것이 이상하네요.. 버그인가요?

파란R2 이거든요.

idlock의 이미지

저도 테스트를 않해봐서 모르겠습니다만 -.-(해서리 엿되면. 않되기 때문에)

옛날에 unix 배울때 선임이 그러더군요..
현재 디록토리에서 작업할때는 꼭 ./로 시작하라고.. 손가락에 아예 버릇을 드리라고...

그래서 전 주로 이렇게 합니다. rf -rf ./.*

./.. 머 이런식이 것도 이겠내요..

chown -R xxxxx:xxxx ./.*이게 맞겠죠? ^^;;;
_________________
'고생은 사람을 고상하게도, 비열하게도 만든다'

monpetit의 이미지

혹시라도 그런 일이 생길수도 있기 때문에, 저는 아예 그 상위 디렉토리에서 작업을 합니다만...
chown -R xxxx:xxxx directory

sangwoo의 이미지

/home/aaaa 에 들어가셔서

chown -R xxxx:xxxx data

이런식으로 하시면 됩니다.
chown의 버그라기보다는 두 유틸의 사용목적이 조금 다르기 때문이 아닌가 합니다.
예로 rm . 또는 rm .. 는, 현재 쉘이 .를 reference하고 있기 때문에, 디렉토리를 지워버린다면 좀 부자연스럽죠. 아마도 그래서 .와 ..인 경우는 지우지 않는 루틴을 넣어놓았을 겁니다. 소스를 안 봐서 확실히는 모르겠네요 :(
하지만 chown . 이나 chown .. 의 경우는 그런 영향을 받지 않습니다. 따라서 정상적인 동작이라고 생각합니다.

----
Let's shut up and code.

ㅡ,.ㅡ;;의 이미지

idlock wrote:

현재 디록토리에서 작업할때는 꼭 ./로 시작하라고.. 손가락에 아예 버릇을 드리라고...

./.. 머 이런식이 것도 이겠내요..

chown -R xxxxx:xxxx ./.*이게 맞겠죠? ^^;;;

위처럼해도 마찬가지 일꺼 같은데요.. 어차피 현제 디렉토리에 .과 .. 이 있으니
마찬가지로 될꺼 같은데.. 아닌가...?? 안해봐서 모르겠네요..

chown에도 .과 ..은 실행하지 않도록 루틴이 들어가 있었으면 좋았을텐데..
상당히 위험하네요..

저도 복구작업을 할때 상위에서 디렉토리네임을 줘서 해줬습니다.


----------------------------------------------------------------------------

서지원의 이미지

ㅡ,.ㅡ;; wrote:
idlock wrote:

현재 디록토리에서 작업할때는 꼭 ./로 시작하라고.. 손가락에 아예 버릇을 드리라고...

./.. 머 이런식이 것도 이겠내요..

chown -R xxxxx:xxxx ./.*이게 맞겠죠? ^^;;;

위처럼해도 마찬가지 일꺼 같은데요.. 어차피 현제 디렉토리에 .과 .. 이 있으니
마찬가지로 될꺼 같은데.. 아닌가...?? 안해봐서 모르겠네요..

chown에도 .과 ..은 실행하지 않도록 루틴이 들어가 있었으면 좋았을텐데..
상당히 위험하네요..

저도 복구작업을 할때 상위에서 디렉토리네임을 줘서 해줬습니다.

.* 나 *, [ab] 등은 프로그램에 직접 전달되는 것이 아니라, 쉘이 확장해서 넘겨줍니다. 쉘마다 조금씩 다르긴 한데, .* 라고 하면 .으로 시작하는 모든 것을 가리키고, 결국 ./ ../ 에서도 작업을 하게 됩니다. ls .* 를 해 보시면 무슨 말인지 아실겁니다.

결국 명령을 잘못 내린 거네요. :)

sangwoo의 이미지

ㅡ,.ㅡ;; wrote:
제가 권한설정을 좀 바꿔주다가 아주 큰일날뻔했습니다.

문제는 루트로 특정계정(/home/aaaa/data )에들어가서

그하위의 모든 숨김파일들을 특정유저로

소유권을 변경하려고 했습니다... 그래서 내린명령이..

chown -R xxxx:xxxx .*


제가 글을 제대로 읽지 않았네요.. 죄송 :-(
원하시는 결과를 얻기 위해서는 다음과 같이 하시면 될 것 같습니다.
cd /home/aaaa
find data -type f -name '\.*' | xargs chown xxxx:xxxx

----
Let's shut up and code.

idlock의 이미지

Quote:
* 나 *, [ab] 등은 프로그램에 직접 전달되는 것이 아니라, 쉘이 확장해서 넘겨줍니다. 쉘마다 조금씩 다르긴 한데, .* 라고 하면 .으로 시작하는 모든 것을 가리키고, 결국 ./ ../ 에서도 작업을 하게 됩니다. ls .* 를 해 보시면 무슨 말인지 아실겁니다.

결국 명령을 잘못 내린 거네요.

ls -R ./.* -.- 않되는군요.. 크헐.. 그럼 쉘 스크립형태만 가능한가 음..

서지원의 이미지

idlock wrote:
Quote:
* 나 *, [ab] 등은 프로그램에 직접 전달되는 것이 아니라, 쉘이 확장해서 넘겨줍니다. 쉘마다 조금씩 다르긴 한데, .* 라고 하면 .으로 시작하는 모든 것을 가리키고, 결국 ./ ../ 에서도 작업을 하게 됩니다. ls .* 를 해 보시면 무슨 말인지 아실겁니다.

결국 명령을 잘못 내린 거네요.

ls -R ./.* -.- 않되는군요.. 크헐.. 그럼 쉘 스크립형태만 가능한가 음..

쉘마다, -그리고 아마도, - 쉘 옵션에 따라 조금씩 다르게 확장됩니다.
zsh에서는 기본으로 .* 이라고 해도 ./이랑 ../ 은 빼고 확장하는데, bash에서는 둘 다 포함되는 것 같습니다.

confide의 이미지

rm -rf * 하는 경우 현재 디렉토리를 지울수가 없을듯 한데요.

만약 삭제 시도를 한다면...

device is busy 와 같은 메시지가 뜨지 않을까요 -_-;

------------------
나는 바보

sangwoo의 이미지

confide wrote:
rm -rf * 하는 경우 현재 디렉토리를 지울수가 없을듯 한데요.

만약 삭제 시도를 한다면...

device is busy 와 같은 메시지가 뜨지 않을까요 -_-;

지울 수 없지는 않습니다. 가령, rm -rf $PWD 와 같은 명령은 퍼미션만 적절하다면 제대로 동작합니다. 다만 몇몇 재미있는 현상이 생기게 되지요.
빈 디렉토리를 만든 뒤에, 거기로 cd하신후 rm -rf $PWD를 합니다. 그다음 ls -al 과 cd . 등을 해 보세요.

----
Let's shut up and code.

realian의 이미지

Quote:

지울 수 없지는 않습니다. 가령, rm -rf $PWD 와 같은 명령은 퍼미션만 적절하다면 제대로 동작합니다. 다만 몇몇 재미있는 현상이 생기게 되지요.
빈 디렉토리를 만든 뒤에, 거기로 cd하신후 rm -rf $PWD를 합니다. 그다음 ls -al 과 cd . 등을 해 보세요.

[solomon:/usr/user5/jhhong] mkdir emp
[solomon:/usr/user5/jhhong] cd emp
[solomon:/usr/user5/jhhong/emp] rm -rf $PWD
rm: cannot remove current directory `/usr/user5/jhhong/emp'

....?

솔라리스 8이고 ksh 입니다.. bash나 tcsh 등에서도 같은 결과네요...

..........No Sig.........|
-------------------+

sangwoo의 이미지

realian wrote:
Quote:

지울 수 없지는 않습니다. 가령, rm -rf $PWD 와 같은 명령은 퍼미션만 적절하다면 제대로 동작합니다. 다만 몇몇 재미있는 현상이 생기게 되지요.
빈 디렉토리를 만든 뒤에, 거기로 cd하신후 rm -rf $PWD를 합니다. 그다음 ls -al 과 cd . 등을 해 보세요.

[solomon:/usr/user5/jhhong] mkdir emp
[solomon:/usr/user5/jhhong] cd emp
[solomon:/usr/user5/jhhong/emp] rm -rf $PWD
rm: cannot remove current directory `/usr/user5/jhhong/emp'

....?

솔라리스 8이고 ksh 입니다.. bash나 tcsh 등에서도 같은 결과네요...

리눅스나 FreeBSD와는 rm의 implementation이 다른 모양이네요. 솔라리스는 제가 액세스할수 있는 머신이 없군요. 소스는 더욱더.. :-( rm의 argument검사시에 $PWD와 비교하는 루틴이 있나봅니다.
그러면, cd emp이후에.. 다른 터미널 창에서 rm -rf /usr/user5/jhhong/emp 를 하면 어떻게 되나요?

PS. 추가합니다. AIX 3.2에서도 current directory는 삭제가 안되네요.
대신에 제가 위에 말씀드린 대로 한 후, 원래의 터미널에서 ls -al 을 하면

$ ls -al
. not found

이런 결과가 나오네요 ^^

----
Let's shut up and code.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.