RSS구독하기:SUBSCRIBE TO RSS FEED
즐겨찾기추가:ADD FAVORITE
글쓰기:POST
관리자:ADMINISTRATOR
'서버관리'에 해당되는 글 2
2008/04/05  서버관리TIP 퍼온글-1  (2)
2008/04/05  서버관리TIP 퍼온글  (2)
1. 부팅 디스켓 만들기

먼저 부팅디스켓으로 사용할 커널 이미지를 선택한다.
그리고 선택한 커널 이미지가 root 장치(root mount point)가 재대로 잡혀 있는지
확인한다.

# rdev /boot/vmlinuz
Root device /dev/hda1

만일 루트 장치가 현재 잡혀 있는거랑 틀리다면 아래와 같이 수정한다.

# rdev /boot/vmlinuz /dev/hda3
#

이제 깨끗한 플로피 디스켓 하나 준비하고 포맷한다.

# fdformat /dev/fd0
# dd if=/boot/vmlinuz of=/dev/fd0 bs=8192


2. 일반유저에게 장치 mount 허가하기

특정 장치를 일반유저에게 mount/umount 하게 해주기 위해서는 /etc/fstab 에서
허가할 장치의 옵션에 user 이란 옵션을 추가 해 주어야 한다.
혹은 mount/umount 명령어의 퍼미션을 setuid 로 해주어도 가능하다.

3. 파일 시스템 만들기

mkfs 명령어 사용

# mkfs -t ext2 /dev/hdb1
# mkfs -t ext2 /dev/fd0

플로피 파일 시스템 만들기

# fdformat /dev/fd0
# mkfs -t ext2 -c /dev/fd0 -v

-c : 블럭체크
-v : 진행과정 display

파일시스템 점검 수리

# fsck -t [type] [device]

fsck 파일 점검은 가능한 umount 한 후에 실행한다. 하지만 / 을 mount 하지 않은
면 당근 부팅이 제대로 될수 없기에 / 를 체크할때는 플로피로 부팅을 하던지 아님
single mode 로 부팅한후 체크 한다.

체킹후 mount -t -w -o remount /

해주면 된다.

4.긴급 스왑 메모리 추가 하기

# touch /swap
# dd if=/dev/zero of /swap bs=1024 count=8192
# sync
# mkswap -c /swap 8192
# swapon /swap

하면 8M 의 스왑메모리를 추가 할수 있다.
이밖에 여유공간에 파티션을 나누고 /etc/fstab 에 추가 해 주어도 가능하다.


5. 파일을 묶고 압축하기

리눅스 시스템 관리자가 반드시 숙지하고 있어야 할 기술중 하나가 파일을
묶고, 압축하는 기술이다. 보다 효율적인 안정된 시스템 관리를 위해서는
파일이나 디렉토리를 이동하거나 백업하기 위해 파일의 속성과 디렉토리
구조들을 유지한체 이동하게 하는데 필요한 tar 나 대용량의 파일을 압축
하는 gzip 등의 명령어를 자유자재로 다루어야 할것이다.

[ gzip 사용하기 ]

[root@zzang911 alang]# ls -l tttt
-rw-rw-r-- 1 alang alang 1228 7월 25 13:58 tttt

[root@zzang911 alang]# gzip tttt

[root@zzang911 alang]# ls -l tttt*
-rw-rw-r-- 1 alang alang 747 7월 25 13:58 tttt.gz

위에서 보는 바와 같이 gzip file_name 적으면 file_name.gz 란 압축파일이 만들어
진다. tttt 파일을 압축시켜서 tttt.gz 란 파일을 만들고 tttt 파일을 지워버리게
된다.

하나 유의해야 할점이 있다. gzip 은 zip 처럼 여러개의 파일을 하나로 묶어서 압축
하지 않고 파일별로 gz 란 확장자를 붙이며 압축해 버린다. 그렇기 때문에 파일을
묶는 tar 와 같이 사용해야 한다.

gzip 파일로 묶인것을 확인하기 위해서는 -l 옵션을 사용한다.

[root@zzang911 alang]# gzip -l tttt
compressed uncompressed ratio uncompressed_name
747 1228 41.0% tttt
그리고 압축을 풀기 위해서는 gunzip 이나 gzip -d 를 사용하여 압축을 해제할수가
있다. 그리고 압축을 해제하면 압축된 파일은 제거 되어 진다.

이밖에 gzip 은 표준출력을 바로 압축할수도 있다.

# ls -alR $HOME | gzip > home.gz

이와 같이 하면 $HOME 디렉토리 하위 파일을 home.gz 으로 압축하게 된다.
이밖에 다른 옵션으로 -1 ~ -9 까지의 옵션이 있는데 이는 압축률을 정하는 옵션
이다. gzip -1 file_name 하면 압축속도는 빠르나...압축률은 낮다. 그리고 -9
옵션을 사용하면 압축속도는 느리지만 압축률은 상당히 높게 되어진다.

[ tar 사용하기 ]

tar 는 파일의 허가권이나 소유권등의 정보를 유지하면서 많은 파일들을 하나의 파일로
묶어 주는 기능을 가진 아카이브 유틸리티이다. 예전엔 여러파일을 하나로 묶어 테잎에
백업을 받기 위한 도구로 사용되어졌지만 지금은 여기에 국한되는 것이 아니라 다양한
기능들을 제공한다. 다음 형식으로 사용되어진다.

tar [옵션] [묶은 파일명] [묶을 파일들]

옵션에는

c : 새로운 아카이브의 생성
x : 아카이브로 부터 파일 추출
t : 아카이브에 담긴 내용을 나열
r : 아카이브의 마지막 부분에 파일 추가
u : 아카이브에 있는 기존 파일보다 새로운 파일로 업데이트
d : 아카이브에 있는 파일과 비교
v : 아카이브 생성이나 추출시 과정을 보여준다.
k : 아카이브를 추출시 기존에 같은 파일이 있으면 그 파일을 보존한다.

디들중 c,x,v,t 를 제외한 나머지는 자주 사용되지 않는다.
파일을 묶고 푸는 대표적인 예를 하나씩 들어본다.

# tar cvf file.tar /home/file
/home/file 이란 디렉토리에 있는 모든 파일과 디렉토리를 그대로 file.tar
란 파일로 묶어버린다.

# tar x

# tar cvf bin.tar /bin

로 파일을 묶은후 bin.tar 로 풀때는 다음과 같은 경고 메세지가 출력하게 된다.
tar: Removing leading / from absolute path names in the archive.

이는 만약에 있을 위험을 방지하기 위해서 나타나는 현상이다.
다시말해 bin.tar 를 풀었을때 압축 디렉토리와 같이 /bin 에다가 압축이 풀리면
시스템에 이상이 생길지도 모른다. 그래서 tar 로 파일을 풀때는 현재 디렉토리를
기준으로 하여 파일이 풀리게 되어져 있다. 이점을 유의하길 바란다.

[ tar 와 gzip 같이 사용하기 ]

위에서 본바와 같이 특정 디렉토리나 파일들을 tar 로 묶은후 gzip 을 사용하여
압축하는 방식이다. 과정을 풀어서 본다면 다음과 같다.

# tar cvf file_name.tar /home
# gzip -9 file_name.tar

이와 같이 하면 된다. 하지만 이방법은 번거로울뿐아니라 gzip 으로 압축되기전까지
tar 파일을 보관할 충분한 디스크 공간이 확보되어 있어야 한다.

# tar cvf file_name.tar /home | gzip -9 > file_name.tar.gz

이와 같이 하면 된다.

GNU tar 버젼에서는 gzip 기능을 포함하여 사용할수 있도록 되어져 있다.

# tar czvf file_name.tar.gz /home

위와 같이 z 옵션을 사용하면 된다.

6. 라이브러리에 대하여

라이브러리란 시스템에서 프로그램을 직접 컴파일 할때 많은 프로그램에서 공통으
로 사용할수 있는 유용한 기능을 포함하고 있는 파일이다.
많은 프로그램들이 이런 라이브러리를 각 프로그램마다 포함하고 있지 않고 정보
만 가지고 있다 컴파일 당시 시스템 자체에 있는 라이브러리를 이용하여 컴파일이
되어지는 것이다.

어떤 경우에는 컴파일시 위와 같은 공유라이브러리를 이용하지 않고 자체적인 라이
브러리 루틴을 사용하기도 하는데 이런 프로그램을 정적으로 링크된(statically
linked) 프로그램이라고 하며 공유 라이브러리를 이용해 만들어진 것은 동적으로
링크된 프로그램이라고 한다.

동적으로 링크된 실행 파일은 공유라이브러리가 디스크에 존재하느냐에 의존한다.
이와 같은 방법으로 구현된 공유 라이브러리로 컴파일돈 프로그램은 일반적으로
현재 라이브러리의 버전에 의존하지 않는다. 즉 공유라이브러리를 업그레이드시
키면 프로그램 역시 업그레이드된 기능을 적용받게 되어져 있다.
단..라이브러리에 큰 변화가 있다면 오래된 프로그램은 새로운 라이브러리와 같
이 작동안할수도 있다. (glic-2.1.x 와 glibc-2.2.x 대에서의 문제와 같이..)

ldd 명령은 실행파일에 의존되는 라이브러리 목록을 보여주는 명령어 이다.

[root@zzang911 /root]# ldd /usr/bin/X11/xterm
libXft.so.1 => /usr/X11R6/lib/libXft.so.1 (0x4002d000)
libfreetype.so.6 => /usr/lib/libfreetype.so.6 (0x40052000)
libXrender.so.1 => /usr/X11R6/lib/libXrender.so.1 (0x40088000)
libXaw.so.7 => /usr/X11R6/lib/libXaw.so.7 (0x4008d000)
libXmu.so.6 => /usr/X11R6/lib/libXmu.so.6 (0x400e2000)
libXt.so.6 => /usr/X11R6/lib/libXt.so.6 (0x400f8000)
libSM.so.6 => /usr/X11R6/lib/libSM.so.6 (0x40145000)
libICE.so.6 => /usr/X11R6/lib/libICE.so.6 (0x4014f000)
libXpm.so.4 => /usr/X11R6/lib/libXpm.so.4 (0x40166000)
libXext.so.6 => /usr/X11R6/lib/libXext.so.6 (0x40175000)
libX11.so.6 => /usr/X11R6/lib/libX11.so.6 (0x40183000)
libncurses.so.5 => /usr/lib/libncurses.so.5 (0x40263000)
libutempter.so.0 => /usr/lib/libutempter.so.0 (0x402a5000)
libc.so.6 => /lib/i686/libc.so.6 (0x402a7000)
/lib/ld-linux.so.2 => /lib/ld-linux.so.2 (0x40000000)

/etc/ld.so.conf 파일은 공유라이브러리 파일을 찾는 ld.so 에 대한 디렉토리
목록을 포함하고 있다.

[root@zzang911 /root]# cat /etc/ld.so.conf
/usr/local/lib
/usr/lib
/usr/kerberos/lib
/usr/X11R6/lib

ld.so.conf 에서 빠진 내용은 각 계정의 환경변수 설정에서 LD_LIBRARY_PATH에
검색경로로 디렉토리를 추가해 주면 된다. 환경변수 설정은 .bash_profile 나
.bashrc 에 추가해주면 된다.

아무튼 ld.so.conf에 새로운 항목을 추가 하였다면 다음명령어를 사용하여 적용
을 시켜 주어야 한다.

# ldconfig

이 명령어는 ld.so 의 검색 경로에서 공유 라이브러리 캐시를 재생성하게 된다.
이캐시 내용을 참조하여 보다 빨리 라이브러리를 찾기위해서 이다.

[ 라이브러리 업그레이드 하기 ]

먼저 /lib 디렉토리 내용을 보도록 하자.

-rwxr-xr-x 1 root root 1236396 4월 7 06:58 libc-2.2.2.so*
lrwxrwxrwx 1 root root 13 5월 5 04:23 libc.so.6 -> libc-2.2.2.so*

라이브러리를 업그레이드 할때는 라이브러리에 부합되는 .a 와 .so.version 파일
을 반드시 대체해야 한다.

.a 파일은 새로운 대체파일로 복사해 주면 되지만 공유라이브러리를 대체할때는
보다 주의를 요한다. .so.version 의 경우는 위에서 보는 바와 같이 libc.so.6 파일이
실제 파일인 libc-2.2.2.so* 에 링크되어져 있다. 새로 업그레이드 하여 libc-2.2.3.so
파일을 적용하기 위해서는 그냥 링크를 깨난던지 아님 파일 이름을 바꾼다던지 하면
시스템의 모든 명령어가 먹히지 않는 경우가 발생하게 된다. 그렇기 때문에 새로 업그레
이드 된 파일을 /lib 디렉토리에 옮겨놓고 ln -sf 명으로 링크의 연결을 새로운 파일이
있는곳으로 한번에 가도록 변경한다.

# ln -sf libc-2.2.3.so libc.so.6

7. 백업 하기

데이타 백업하기에 대해서 간단히 적겠습니다.

보통 데이타 백업은 하드나 테잎장치,혹은 플로피 디스켓등에 하는데...
플로피는 빼도록 하죠...요즘에 플로피 쓰는 곳은 없으니깐..

[ 테잎장치에 빽업하기..]

보통 백업은 tar, gzip 을 이용하여 백업을 합니다. 상용 백업 프로그램이라고
하더라도..이 두 명령어를 잘 이용한거라고 볼수 있습니다.

테잎에 백업하는 대표적인 예는 ..

# tar cvf /dev/rft0 /home

와 같은 형식입니다.

/dev/rft0 는 테잎 디바이스 명입니다.

테잎 하나에 tar 파일 하나 저장하는 사람은 없을거라 봅니다. 여러개의 tar
파일을 하나의 테잎에 저장할 경우 첫번째 tar 파일이 테잎에 저장된후 다시
처음으로 감기는 것을 방지하기 위해 다음 파일의 시작점을 표시해 두게 됩니다.
테잎이 다시 감기는 것을 방지하려면, 플로피 테잎 드라이브인 경우 /dev/nrft0
, /dev/nrft1을, SCSI 테잎 드라이브라면 /dev/nrst0 와 /dev/nrst1 이라는
이름으로 된 테잎 장치를 사용해야 합니다.

이렇게 자동으로 감기지 않는 테잎 장치를 사용한다면 용량이 허락하는 만큼의
많은 파일을 저장할수 있다.

이런 테잎 장치에서 테잎을 다시 감을려면...

# mt /dev/nrtf0 rewind 혹은
# mt /dev/nrtf0 reten

테잎의 다음 파일로 건너뛰기는(테잎은 순차적 접근 방식이기 때문에...)

# mt /dev/nrft0 fsf 1

두개의 파일 건너뛰기..

# mt /dev/nrft0 fsf 2

이런식으로 제어 하면 된다.


대부분의 리눅스 서버 관리자들은 테잎은 안쓰는 걸루 안다..^^;; 왜~~
느리니깐...귀찮아서...새로운 장비 살 돈이 없어서...여러가지 이유가
있지만...속도문제가 큰거 같더군요..가끔 한번식하는 전체 백업같은
경우엔 상관없지만..웹호스팅 업체나 매일 백업을 해야 하는 자료 업로드
량이 많은 사이트 경우엔..비합리적일수도 있는거 같더군요.

그냥 싼 IDE 하드 하나 달아 놓고...백업장치로 사용하는게 속 편한거 같네요.

그럼..실질적인 백업 기법에 대해서 설명하도록 하겠습니다.

일단 파일을 묶는 tar 에 대해서 알아보자..
tar 는 단순히 파일이나 디렉토리들을 속성을 유지한체 하나의 파일로 만드는
기능을 합니다. 옵션에 따라 ..gzip처럼 압축도 할수 있습니다.


# tar cvf test.tar /home/test

/home/test 디렉토리를 test.tar 이란 파일로 묶는다.

# tar czvf test.tar.gz /home/test

/home/test 디렉토리를 test.tar 로 묶은 다음 gzip 으로 압축한다.

# tar czvfp test.tar.gz /home/test

/home/test 디렉토리를 모든 속성과 권한을 현재 그대로 유지한체 압축한다.


이정도면 압축하는데 무리가 없을것이다.

누적 백업시에는 find 명령어를 잘 활용해야 한다.

먼저 날짜별로 변경된 파일을 찾아서 리스트를 만들고 이 리스트를 참조하여
백업을 할수 있다.

# find /home/test -mtime -1 \! -type d -print > filelist
# tar -cv -T "filelist" -f test.tar

위의 예문은 find 로 /home/test 밑의 파일들중 하루(-mtime -1) 동안 변경된
모든 파일을 검색하고 그중 디렉토리는 제외 (\! -type d)하여 출력하고 출력
내용을 filelist 에 저장하라는 뜻이다.

그런후 작성된 filelist 속의 기재된 파일들을test.tar 로 묶으라는 의미입니다.

이와 같은 명령어를 잘 응용하면 여러가지 백업스크립트를 만들수 있을것입니다

크리에이티브 커먼즈 라이센스
Creative Commons License
2008/04/05 17:40 2008/04/05 17:40
http://cafeall.com/trackback/398
아래 시스템 관리상 꼭 필수적인 명령어 몇개를 소개하고자 합니다. 시스템
관리자라는 흔히 사용하는 명령어 들입니다. 하지만 대부분이 명령어의 기
능을 다 활용하진 않으시는거 같더군요.
여기에 소개하는 내용이 이 명령의 들의 모든 기능이라고 말하진 않습니다.
다만..이 명령어를 이용하여 시스템을 관리하는 방법을 보다 깊게 소개하고
자 합니다. 어떤분에겐 이정도는 기초이자 기본이라 생각하시는 분들도 계실
것이고 어떤분에겐 자신의 기반을 더더욱 확장시킬수 있는 좋은 자료가 되실
거라 생각이 됩니다. 그럼..천천히 한번 읽어보세요.

작성자 : 서 진우 (alang@sysmng.com)
-------------------------------------------------------------------------

1. 시스템 관리 명령 [1] - grep (egrep,fgrep)

다들 아시다 시피 grep 은 입력에서 주어진 패턴을 포함하고 있는 줄을 찾아
주는 명령이다. 많은 시스템 관리 명령들과 파이프(pipe)를 이용해서 사용할
수 있다. 흔히 사용하는 것은 프로세스 확인이다.

# ps aux | grep httpd

위와 같이 현재 시스템의 프로세스중 httpd 만 검색해 낸다.
만일 pipe 를 이용하여 검색할경우 검색 패턴이 한개 이상일 경우엔 egrep
을 이용하여 검색할수 있다.

# ps aux | egrep 'httpd|mysql'

이밖에 grep 는 file 내용증에 특정 pattern 이 들어 있는 행을 찾아서 출력
해 준다 option 을 이용하여 보다 다양한 pattern을 선택하여 검색할수 있다.

option :
----------------------------------------------
-i : 대소문자 구별을 하지 않는다.
-v : pattern 을 포함하지 않는 행만 출력한다.
-n : 행번호를 출력한다.
-l : 파일명만 출력한다.
-c : 패턴과 일치하는 라인의 갯수만 보여준다.
----------------------------------------------

몇가지 예를 들어 보겠다.

# grep [option] "pattern" 파일명

대표적인 사용방법이다. 파일에 pattern 이란 단어를 포함하는 행을 출력한다.

# grep -v "^[ ^I]*$" 파일명

위는 공백을 제거한 파일 내용 살펴보기

# grep -v "^#*$" 파일명

위는 주석을 제거한 파일 내용 살펴보기

이밖의 패턴과 정확히 일치하는 것만을 찾아주는 fgrep 가 있다.
grep,egrep,fgrep 의 옵션으론 위의 옵션을 공통적으로 사용한다.

마지막으로 유용한 팁 하나 소개하죠. grep 는 현재 디렉토리에 존재하는 파일
만을 검색한다. 만일 현재 디렉토리와 그 하위 디렉토리까지 grep 패턴 검색을
하고자 할땐 find 명령을 이용하면 된다.

# find . -exec grep "pattern" {} \;

2. 시스템 관리 명령어[2] - awk

awk 는 grep 과 같이 출력된 문장에서 필요한 부분한 걸려내는 필터역활을 하는
명령어의 일종입니다. 사용하기에 따라서 매우 유용하지요..

[root@zzang911 /]# ls -al
drwxr-xr-x 2 root root 0 11월 3 10:16 misc/
drwxr-xr-x 4 root root 4096 8월 9 00:41 mnt/
drwxr-xr-x 2 root root 4096 8월 24 1999 opt/
dr-xr-xr-x 113 root root 0 11월 3 10:16 proc/

위의 출력문은 tab (공백)으로 각 컬럼을 구분하는데 다음과 같이 하면 원하는 컬럼
값만을 선택하서 출력이 가능합니다.

[root@zzang911 /]# ls -al | awk '{print $1 $5 $9}'

drwxrwx--- 4096 root/
drwxr-xr-x 4096 sbin/
drwxr-xr-x 4096 temp/
drwxr-xr-x 4096 tftpboot/
drwxrwxrwt 4096 tmp/
drwxr-xr-x 4096 usr/
drwxr-xr-x 4096 var/

위와 같이 1,5,9 번째 컬럼값만 출력이 되어집니다. 후후후

이밖에 awk 는 연산 기능을 가지고 있다.

# find /home/design -user design -ls | \
awk '{sum+=$7}; END {print "User design total disk use = " sum }'

User design total disk use = 86072036

이와 같이 design 권한의 파일들의 크기를 합친값을 보여준다.

이 명령라인은 find 로 검색한 파일을 ls -al 형식으로 출력한후 여기서
바이트 수를 가지고 있는 7번째 열의 합계를 누적한다. 그리고 마지막줄
에 최종 결과값을 출력한다. 이밖에 awk 는 평균값도 구할수 있는데...
END 절의 sum 를 sum/NR 로 대체하면 구할수 있다. NR 은 awk 내부 변수
로서 현재까지의 입력 라인수를 갖는다.

3. 시스템 관리 명령 [3] - find

find 명령어는 시스템 관리 명령중 가장 많이 사용되는 명령어 중 하나이다.
이 명령어의 다양한 기능을 많이 알수록 관리자의 불필요한 삽질을 최대한 줄일수
있을것이다.

option :

-atime n : 정확히 n 일 전에 access 된 파일
-mtime n : 정확히 n 일 전에 수정된 파일
-newer [file] : file 보다 최근에 수정된 파일
-size n : 정확히 n x 512 byte 의 길이를 갖는 파일
-type c : 파일의 종류를 기술. f: 파일 d: 디렉토리
-fstype [filesystem] : 파일 시스템 종류
-name [pattern] : 파일 이름 검색
-perm p : 파일 접근 퍼미션이 p 인 경우
-user [user] : 파일 소유권이 user 인 파일
-group [group] : 파일 그룹이 group 인 파일
-nouser : 파일 소유자가 /etc/passwd 에 없는 경우
-nogroup : 파일 소유그룹이 /etc/group 에 없는 경우
-uid n : 파일 uid 가 n 인 경우
-gid n : 파일 gid 가 n 인 경우


단순히 위의 옵션되로 사용하면 그렇게 유용해 보이지 않을수 있겠죠.
예를 들어 누가 정확히 3일전에 접근한 파일들을 검색하겠습니까..?
하지만 +, - 기호를 이용하여 기간,시간,크기와 같은 수치들의 범위를
지정할수가 있습니다.
+ 는 ~~보다 큰 경우, - 는 ~~ 보다 작은 경우

-mtime +7 : 수정 된지 7일이 지난 파일
-mtime -7 : 수정 된지 7일이 안된 파일
-size +100 : 50kbyte 보다 큰 파일

-name 뒤엔 인용부호 (와일드 카드 문자) 를 같이 사용할수 있다.

-name *.dat : 확장자가 dat 인 모든 파일

이런 옵션들을 차례로 기술하여 파일을 찾을 경우 AND 연산이 적용된다.
하지만 -o 옵션을 이용하여 OR 을 적용할수도 있고 ( ) 를 이용하여 그
룹을 지어 적용할수도 있다. 이밖에 NOT 연산도 가능한데 옵션 앞에 !
부호를 달아 주면 된다. 밑의 몇가지 예를 살펴 보자.

# find ./ -atime +60 -mtime 120
( AND 논리연산으로 접근한지 60일 지난 파일중 수정한지 120 일 지난 파일 )

# find ./ \( -user design -o -group design \)
(OR 논리연산으로 소유자나 그룹이 design 인경우 )

# find ./ \( ! -user design -o ! -group design \)
(NOT 논리연산으로 소유자나 그룹이 design 이 아닌 경우 )

-perm 옵션은 숫자형태의 특정 접근 모드를 이용하여 파일을 검색하는 옵션이다.
옵션별 사용예를 들어 보자.

-perm 75 : permission = 755
-perm -002 : 모든 사람들이 기록할수 있는 파일
-perm -4000 : SUID 액세스 설정
-perm -2000 : SGID 액세스 설정

이밖에 지원 되는 내부 옵션이 있다.

-print : 대응되는 파일의 경로명을 출력
-ls : 대응되는 파일에 대한 긴 디렉토리 목록을 출력
-exec commands : 대응대는 파일에 대해 commands 명령 수행
-ok commands : 파일에 대한 commands 명령 수행전에 입력 대기 상태
-xdev : 검색 시작 디렉토리가 속해 있는 파일 시스템에 대해서만 검색 제한
-mount : IRIX 와 SCO UNIX 에서 -xdev 옵션
-prune : 서브 디렉토리는 검색을 하지 않음

-print 옵션은 근래는 기본으로 들어간다. 굳이 붙일 필요는 없고, -exec, -ok
옵션 사용시에는 반드시 마지막에 \; 으로 구문을 마감해야 한다.

예를 들어서 find 로 검색한 파일을 지우기 위해서는 다음과 같이 한다.

# find ./ -name *.* -exec rm -f {} \;

이와 같이 find 명령어를 이용한 시스템 관리 방법 예를 몇가지 들어 보겠다.

1. 파일 크기가10M 이상이며 한달 이상동안 수정되지 않은 파일을 찾는다.
# find / -type f -size +20480 -mtime +30 -ls
# find / -type f -size +20480 -mtime +30 -exec rm -f {} \;
(대응되는 파일삭제)

2. 보안에 관련된 팁이다. 모든 setuid, setgid 를 검색한다.
# find / -type f \( -perm -4000 -o -perm -2000 \)
# find / -type f \( -perm -4000 -o -perm -2000 \) | diff - setuidlist
(찾아된 setuid,setgid를 기존에 작성한 목록과 비교하여 새로 추가 된것이 있는지
를 확인한다. )




단순히 이와 같은 명령어들을 달달 외운다고 해서 시스템 관리를 잘하는것은 아니다.
하지만 시스템 관리자로써의 유연성과 독창성을 가지기 위해서는 위의 명령어 숙달은
필수라고 할수 있을것이다.
이제 어떤 작업이든간의 여러분이 생각하는 방법으로 보다 빠르고 정확한 검색과 결
과를 얻을수 있을거라 생각이 되네요.그럼..이만.
크리에이티브 커먼즈 라이센스
Creative Commons License
2008/04/05 17:38 2008/04/05 17:38
http://cafeall.com/trackback/397
겔롱:리눅스와 Rc 전동비행기 그리고 지극히 개인적인 공간, 오토캠핑 이야기
리눅스와 Rc 전동비행기 그리고 지극히 개인적인 공간, 오토캠핑 이야기
전체 (494)
Linux (38)
Rc 이야기 (32)
오토캠핑 (60)
여행&소풍 (79)
나의 이야기 (275)
마눌님 이야기 (0)
겔롱이 궁금하신분 (1)
동영상 (3)
사진이야기 (5)
«   2012/05   »
    1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31