Linux/SHELL 2006/10/08 17:17
3-4. path(find 명령어 다음의 path)
.
현재 디렉토리(기본값이므로 생략해도 됨)
`pwd`
현재 디렉토리와 결합(?) `은 ~문자가 있는 자판
$(pwd)
위의 `pwd`와 같거나 비슷함
/
최상위 루트 디렉토리에서 하위 모든 디렉토리
/home
특정 /home 디렉토리에서 하위 모든 디렉토리
/{usr,home/{aaa,san2},var}
/usr, /usr/home/aaa /usr/home/san2 /var
3-5. 표현식-연산자
\( 표현식 \)
'표현식'을 우선적으로 먼저 수행
(와 )앞에 \를 넣어야 하며, '표현식'과 공백을 각각 둔다.
\( A + B \) * \( C + D \) 와 같이 \(, \)안을 우선적으로 수행
! 표현식 , -not 표현식
'표현식'을 부정
표현식1 -a 표현식2, 표현식1 -and 표현식2
표현식1과 표현식2의 AND 연산
표현식1 -o 표현식2, 표현식1 -or 표현식2
표현식1과 표현식2의 OR 연산
3. 예제
3-1. 다른 명령어와 결합 형태(ls,xargs)
찾는 것 그 차체 만으로 만족(?) 할 수 도 있지만 그 결과에 대해서
어떤 행동(Actions)을 취할 필요가 있습니다.
형태1. -exec 이용시
# find ..... -exec COMMAND {} \;
형태2. xargs 명령어로 표준 입력받아 COMMAND 수행
# find ..... | xargs COMMAND
형태3. ls 명령어로 최종 결과 출력
# ls -l `find .....[COMMAND]`
또는
# find .... ls
(ls는 ls -dils와 같음)
xargs
xargs rpm 정보보기
# rpm -qi `rpm -qf $(which xargs)`
또는
# rpm -qf `which xargs` | xargs rpm -qi
즉, find 결과에 대해서,
형태1은 -exec를 사용하여 그 인자를 {}로 사용하고,
형태2는 xargs 명령어로 find에서 넘어온 결과(표준출력)에 대해서 COMMAND를 실행하고,
형태3은 오른쪽의 find 결과물에 대해서 ls 명령어를 실행합니다.
간혹 '/bin/ls Argument list too long'이라는 에러를 낸 경우도 있습니다.
이는 검색조건에 너무 많은 와일드카드 문자로 찾을 경우에 그렇습니다.
이를 테면 /*/*/*.*/.*,
`은 ~문자가 있는 자판(역인용부호).
ls -l 명령어를 사용할 경우, 찾는 결과가 없다면 모두 출력됩니다.
(ls -l와 같기 때문에)
ls 명령어와 마찬가지로 다른 명령어(chmod, chmod)를 결합하여 사용할 경우 그 찾는
결과가 없다면 명령어에 대한 에러를 내겠죠.
(chmod 'null')과 같은 예..........
# find /{home,usr/{src,local/src}} -nouser -o -nogroup -exec ls -l {} \; -print | more
# find /{home,usr/{src,local/src}} -nouser -o -nogroup -print | xargs ls -l | more
위의 2개의 명령어 대해서 직접 테스트 해보세요...
전자의 경우, 아마 아무것도 출력되지 않을 겁니다.
# find /{home,usr/{src,local/src}} \( -nouser -o -nogroup \) -exec ls -l {} \; -print | more
위와 같이 해야 맞겠죠...(우선순위)
후자의 경우도 마찬가지로 다음과 같이 우선순위를 정해놓아야 겠지요..
아마 원하는 출력이 이 경우일 것 같군요.
# find /{home,usr/{src,local/src}} \( -nouser -o -nogroup \) -print | xargs ls -l | more
3-2. 퍼미션 관련 예제
othesrs에 쓰기(w:2) 권한이 있는 모든(-기호를 붙임) 파일 리스트를 찾을려면?
# find `pwd` -perm -2 -print | xargs ls -l
여기에서 2는
퍼미션이 -------w- 와 일치하는 파일이며 -의 의미는 rwx-중 하나.
왜 2인가요?
만약 퍼미션이 755 이라면,
700 : rwx------ : user
50 : ---r-x--- : group
5 : ------r-x : others
------------------------
755 : rwxr-xr-x : others는 읽기와 실행 권한
따라서 others의 권한은 8진수로 5(r+x)이다.
그렇다면, others가 쓰기(w:2) 권한은 당연히 -------w-
그룹이나 others에게 쓰기 권한이 있는 파일일 경우
-perm -20 -o -perm -2
그룹과 others에게 모두 쓰기 권한이 있는 파일일 경우
-perm -22
[others에게 w 권한이 있는 파일에 w 권한 없애기]
방법1)
1. others에게 w 권한이 있는 파일 리스트 출력
# find `pwd` -perm -2 -print | xargs ls -l | more
(만약 매치되는 리스트가 없다면 전부 출력함)
2. others에게 w 권한을 없애기
# find `pwd` -perm -2 -print | xargs chmod o-w
(만약 매치되는 리스트가 없다면 chmod에 에러를 냄)
방법2) 방법1)의 과정을 한꺼번에 할 경우
# find `pwd` -perm -2 -exec chmod o-w {} \; -print | xargs ls -l
또는
# ls -l `find $(pwd) -perm -2 -print | xargs chmod o-rwx` | more
이 경우는 퍼미션이 조정된 결과를 출력함.
3-3. 유저와 관련된 예제
UID와 GID에 대한 유저가 없는 파일을 root.root로 바꾸어 보죠.
1) 먼저 리스트를 출력해 보자.(확인해야하니깐)
# find . \( -nouser -o -nogroup \) -print | xargs ls -l | more
2) 확인했으면, chown root.root 명령을 내리자.
# find . \( -nouser -o -nogroup \) -print | xargs chown root.root | more
또는
# find . \( -nouser -o -nogroup \) -exec chown root.root {} \; -print | xargs ls -l
(chown root.root 의 결과를 ls -l)
3-4. 유용한 팁
*주의) ***********************************************
-a'xxxx'
'xxxx'에 대한 Access(접근), 읽기
-c'xxxx'
'xxxx'에 대한 Changes(변경), 마지막으로 Access한 경우에도 변경됨
-m'xxxx'
'xxxx'에 대한 Modify(수정), 파일내용 자체 수정한 경우
*****************************************************
- 최근 하루(1) 동안(-)에 변경(change)된 파일을 찾을려면(-ctime)?
# find / -ctime -1 -a -type f | xargs ls -l | more
- 오래된 파일을 찾을려면(30일 이상 수정(modify))되지 않은)?
# find / -mtime +30 -print | more
- 최근 30일(30) 안에(-) 접근(access)하지 않은 파일과 디렉토리를 리스트로 만들려면(-atime)?
# find / ! \( -atime -30 -a \( -type d -o -type f \) \) | xargs ls -l > not_access.list
- 자신의 홈디렉토리에서 만 검색하려면?
# find $HOM ...
또는
# find ~root ...
- 서브 디렉토리로 내려가지 않고 현재 디렉토리에서만 검색하려면?
# find . -prune ...
- 특정 유저(foobar) 소유의 파일을 찾을려면?
# find / -user foobar -print | more
- 퍼미션이 777인 파일을 찾을려면 ?
# find / -perm 777 -print | xargs ls -l | more
- others에게 쓰기 권한이 있는 파일을 찾을려면?
# find / -perm -2 -print | xargs ls -l | more
- others에게 쓰기 권한이 있는 파일을 찾아 쓰기 권한을 없애려면?
# find / -perm -2 -print | xargs chmod o-w
또는
# find / -perm -2 -exec chmod o-w {} \; -print | xargs ls -l | more
- 유저이름과 그룹이름이 없는 파일을 찾을려면?
# find / \( -nouser -o -nogroup \) -print | more
- 빈 파일을 찾을려면?
# find / -empty -print | more
또는
# find / -size 0 -print | more
- 파일크기가 100M 이상된 파일을 찾을려면?
# find / -size +102400k -print | xargs ls -hl
- *.bak 파일을 찾아 지울려면?
# find / -name "*.bak" -exec rm -rf {} \;
- *.bak 파일을 찾아 특정 디렉토리로 옮길려면?
# mv `find . -name "*.bak"` /home/bak/
- 디렉토리 만 찾을려면?
# find . -type d ...
- root권한으로 실행되는 파일을 찾을려면?
# find / \( -user root -a -perm +4000 \) -print | xargs ls -l | more
- 다른 파일시스템을 검색하지 않을려면?
# find / -xdev ...
- 파일이름에 공백이 들어간 파일을 찾을려면?
# find / -name "* *" -print
- 숨겨진(hidden) 파일을 찾을려면?
# find / -name ".*" -print | more
- 같은 이름을 가진 디렉토리를 찾을려면?
# find / -type d -print | awk -F/ '{printf("%s\t%s\n",$NF,$0);}' | sort| more
*주)'O'Reilly Unix Power Tools' 참고
- 잘못된 링크를 찾을려면?
# find . -type l -print | perl -nle '-e || print' | xargs ls -l
*주)'O'Reilly Unix Power Tools' 참고
.
현재 디렉토리(기본값이므로 생략해도 됨)
`pwd`
현재 디렉토리와 결합(?) `은 ~문자가 있는 자판
$(pwd)
위의 `pwd`와 같거나 비슷함
/
최상위 루트 디렉토리에서 하위 모든 디렉토리
/home
특정 /home 디렉토리에서 하위 모든 디렉토리
/{usr,home/{aaa,san2},var}
/usr, /usr/home/aaa /usr/home/san2 /var
3-5. 표현식-연산자
\( 표현식 \)
'표현식'을 우선적으로 먼저 수행
(와 )앞에 \를 넣어야 하며, '표현식'과 공백을 각각 둔다.
\( A + B \) * \( C + D \) 와 같이 \(, \)안을 우선적으로 수행
! 표현식 , -not 표현식
'표현식'을 부정
표현식1 -a 표현식2, 표현식1 -and 표현식2
표현식1과 표현식2의 AND 연산
표현식1 -o 표현식2, 표현식1 -or 표현식2
표현식1과 표현식2의 OR 연산
3. 예제
3-1. 다른 명령어와 결합 형태(ls,xargs)
찾는 것 그 차체 만으로 만족(?) 할 수 도 있지만 그 결과에 대해서
어떤 행동(Actions)을 취할 필요가 있습니다.
형태1. -exec 이용시
# find ..... -exec COMMAND {} \;
형태2. xargs 명령어로 표준 입력받아 COMMAND 수행
# find ..... | xargs COMMAND
형태3. ls 명령어로 최종 결과 출력
# ls -l `find .....[COMMAND]`
또는
# find .... ls
(ls는 ls -dils와 같음)
xargs
xargs rpm 정보보기
# rpm -qi `rpm -qf $(which xargs)`
또는
# rpm -qf `which xargs` | xargs rpm -qi
즉, find 결과에 대해서,
형태1은 -exec를 사용하여 그 인자를 {}로 사용하고,
형태2는 xargs 명령어로 find에서 넘어온 결과(표준출력)에 대해서 COMMAND를 실행하고,
형태3은 오른쪽의 find 결과물에 대해서 ls 명령어를 실행합니다.
간혹 '/bin/ls Argument list too long'이라는 에러를 낸 경우도 있습니다.
이는 검색조건에 너무 많은 와일드카드 문자로 찾을 경우에 그렇습니다.
이를 테면 /*/*/*.*/.*,
`은 ~문자가 있는 자판(역인용부호).
ls -l 명령어를 사용할 경우, 찾는 결과가 없다면 모두 출력됩니다.
(ls -l와 같기 때문에)
ls 명령어와 마찬가지로 다른 명령어(chmod, chmod)를 결합하여 사용할 경우 그 찾는
결과가 없다면 명령어에 대한 에러를 내겠죠.
(chmod 'null')과 같은 예..........
# find /{home,usr/{src,local/src}} -nouser -o -nogroup -exec ls -l {} \; -print | more
# find /{home,usr/{src,local/src}} -nouser -o -nogroup -print | xargs ls -l | more
위의 2개의 명령어 대해서 직접 테스트 해보세요...
전자의 경우, 아마 아무것도 출력되지 않을 겁니다.
# find /{home,usr/{src,local/src}} \( -nouser -o -nogroup \) -exec ls -l {} \; -print | more
위와 같이 해야 맞겠죠...(우선순위)
후자의 경우도 마찬가지로 다음과 같이 우선순위를 정해놓아야 겠지요..
아마 원하는 출력이 이 경우일 것 같군요.
# find /{home,usr/{src,local/src}} \( -nouser -o -nogroup \) -print | xargs ls -l | more
3-2. 퍼미션 관련 예제
othesrs에 쓰기(w:2) 권한이 있는 모든(-기호를 붙임) 파일 리스트를 찾을려면?
# find `pwd` -perm -2 -print | xargs ls -l
여기에서 2는
퍼미션이 -------w- 와 일치하는 파일이며 -의 의미는 rwx-중 하나.
왜 2인가요?
만약 퍼미션이 755 이라면,
700 : rwx------ : user
50 : ---r-x--- : group
5 : ------r-x : others
------------------------
755 : rwxr-xr-x : others는 읽기와 실행 권한
따라서 others의 권한은 8진수로 5(r+x)이다.
그렇다면, others가 쓰기(w:2) 권한은 당연히 -------w-
그룹이나 others에게 쓰기 권한이 있는 파일일 경우
-perm -20 -o -perm -2
그룹과 others에게 모두 쓰기 권한이 있는 파일일 경우
-perm -22
[others에게 w 권한이 있는 파일에 w 권한 없애기]
방법1)
1. others에게 w 권한이 있는 파일 리스트 출력
# find `pwd` -perm -2 -print | xargs ls -l | more
(만약 매치되는 리스트가 없다면 전부 출력함)
2. others에게 w 권한을 없애기
# find `pwd` -perm -2 -print | xargs chmod o-w
(만약 매치되는 리스트가 없다면 chmod에 에러를 냄)
방법2) 방법1)의 과정을 한꺼번에 할 경우
# find `pwd` -perm -2 -exec chmod o-w {} \; -print | xargs ls -l
또는
# ls -l `find $(pwd) -perm -2 -print | xargs chmod o-rwx` | more
이 경우는 퍼미션이 조정된 결과를 출력함.
3-3. 유저와 관련된 예제
UID와 GID에 대한 유저가 없는 파일을 root.root로 바꾸어 보죠.
1) 먼저 리스트를 출력해 보자.(확인해야하니깐)
# find . \( -nouser -o -nogroup \) -print | xargs ls -l | more
2) 확인했으면, chown root.root 명령을 내리자.
# find . \( -nouser -o -nogroup \) -print | xargs chown root.root | more
또는
# find . \( -nouser -o -nogroup \) -exec chown root.root {} \; -print | xargs ls -l
(chown root.root 의 결과를 ls -l)
3-4. 유용한 팁
*주의) ***********************************************
-a'xxxx'
'xxxx'에 대한 Access(접근), 읽기
-c'xxxx'
'xxxx'에 대한 Changes(변경), 마지막으로 Access한 경우에도 변경됨
-m'xxxx'
'xxxx'에 대한 Modify(수정), 파일내용 자체 수정한 경우
*****************************************************
- 최근 하루(1) 동안(-)에 변경(change)된 파일을 찾을려면(-ctime)?
# find / -ctime -1 -a -type f | xargs ls -l | more
- 오래된 파일을 찾을려면(30일 이상 수정(modify))되지 않은)?
# find / -mtime +30 -print | more
- 최근 30일(30) 안에(-) 접근(access)하지 않은 파일과 디렉토리를 리스트로 만들려면(-atime)?
# find / ! \( -atime -30 -a \( -type d -o -type f \) \) | xargs ls -l > not_access.list
- 자신의 홈디렉토리에서 만 검색하려면?
# find $HOM ...
또는
# find ~root ...
- 서브 디렉토리로 내려가지 않고 현재 디렉토리에서만 검색하려면?
# find . -prune ...
- 특정 유저(foobar) 소유의 파일을 찾을려면?
# find / -user foobar -print | more
- 퍼미션이 777인 파일을 찾을려면 ?
# find / -perm 777 -print | xargs ls -l | more
- others에게 쓰기 권한이 있는 파일을 찾을려면?
# find / -perm -2 -print | xargs ls -l | more
- others에게 쓰기 권한이 있는 파일을 찾아 쓰기 권한을 없애려면?
# find / -perm -2 -print | xargs chmod o-w
또는
# find / -perm -2 -exec chmod o-w {} \; -print | xargs ls -l | more
- 유저이름과 그룹이름이 없는 파일을 찾을려면?
# find / \( -nouser -o -nogroup \) -print | more
- 빈 파일을 찾을려면?
# find / -empty -print | more
또는
# find / -size 0 -print | more
- 파일크기가 100M 이상된 파일을 찾을려면?
# find / -size +102400k -print | xargs ls -hl
- *.bak 파일을 찾아 지울려면?
# find / -name "*.bak" -exec rm -rf {} \;
- *.bak 파일을 찾아 특정 디렉토리로 옮길려면?
# mv `find . -name "*.bak"` /home/bak/
- 디렉토리 만 찾을려면?
# find . -type d ...
- root권한으로 실행되는 파일을 찾을려면?
# find / \( -user root -a -perm +4000 \) -print | xargs ls -l | more
- 다른 파일시스템을 검색하지 않을려면?
# find / -xdev ...
- 파일이름에 공백이 들어간 파일을 찾을려면?
# find / -name "* *" -print
- 숨겨진(hidden) 파일을 찾을려면?
# find / -name ".*" -print | more
- 같은 이름을 가진 디렉토리를 찾을려면?
# find / -type d -print | awk -F/ '{printf("%s\t%s\n",$NF,$0);}' | sort| more
*주)'O'Reilly Unix Power Tools' 참고
- 잘못된 링크를 찾을려면?
# find . -type l -print | perl -nle '-e || print' | xargs ls -l
*주)'O'Reilly Unix Power Tools' 참고
이 글에는 트랙백을 보낼 수 없습니다
0