'개발/UNIX 계열'에 해당되는 글 5건
- 2008.08.23 AIX 명령어 모음
- 2008.06.25 AIX 서버 기초
- 2008.06.24 AIX 기본 명령어 - vi 명령어 포함
- 2008.06.24 AIX 점검 명령어
- 2008.06.24 AIX 시스템 명령어 모음
제 1 장 System Access
▒▒ 운영 시스템으로 로그인 ▒▒
사용자 시스템에서 작업을 시작하기 전에 먼저 세션을 시작해야 한다. 사용자 시스템을 시작한 후에 바로 시스템에 로그인 하여 세션을 시작한다. 하루중 특정 시간 동안만 또는 한 주의 특정 요일에만 로그인 할 수 있도록 시스템을 설정할 수 있다. 사용자가 허용된 시간 이외의 시간에 로그인하려고 하면, 사용자 액세스를 거절하게 된다. 시스템 관리자는 로그인 시간이 언제인지 검증할 수 있다.
로그인 프롬프트에서 사용자 ID와 Password를 입력하면 운영시스템으로 로그인 하게 되고 사용자의 홈 디렉토리에 들어가게 된다.
▒▒ 시스템이 켜지지 않았을 경우 ▒▒
1. 접속된 각 장치의 시위치를 킨다.
2. 시스템 장치의 키 모드 스위치를 정상으로 설정한다.
3. 전원 시위치를 on으로 설정하여 시스템을 시작한다.
4. 시스템 front의 LED 창에 세자리 표시를 확인한다. 오류없이 완료 된다면 세자리 표시가 나오지 않는다.
주의를 요청하는 오류가 발생하면, 세자리 숫자 코드가 남아 있고 시스템은 정지 된다.
자가 테스트 완료가 성공적이면 다음과 같은 로그인 프롬프트가 사용자 화면에 나타난다.
login:
▒▒ 시스템이 이미 시작되었을 경우 ▒▒
1. login: 프롬프트 뒤에 로그인 이름을 입력한 후 Enter 키를 누른다.
▶ login : [계정이름]
예를 들어, 사용자 로그인 이름이 eibm 일 경우
▶ login : eibm
2. password : 프롬프트가 나타나면, 암호를 입력한 후 Enter를 누란다.(화면에는 사용자가 입력한 것이 표지되지 않는다.)
▶ password : [사용자 암호]
암호 프롬프트가 나타나지 않으면, 사용자는 정의된 암호를 가지지 않은 것이다. login에 계정이름을 넣은 즉시 프롬프트를 만나게 될 것이다. 사용자가 로그인한 후, 운영 시스템이 시작되는 방법에 따라, 사용자 시스템은 명령행(쉘) 또는 그래픽 인터페이스(예를 들어, AIX windows 또는 상용 데스크탑 환경(CDE))로 시작할 수 있다.
▒▒ 한번 이상 로그인(login 명령) ▒▒
사용자는 한번 이상 로그인 할 수 있다. 사용자 시스템으로 로그인 하기 위해 동일한 로그인 이름을 사용하거나 다른 로그인 이름을 사용하여 동시에 여러번 로그인 한다. 이는 하나 이상의 작업을 하고 계정을 분히하여 유지하고 싶을 경우에 유용하다.
주:각각의 시스템은 주어진 시간 내에 언제라도 활성할 수 있는 로그인 이름의 최대 수를 갖고 있다. 이 수는 사용자의 사용권 계약에 의해 판별되며 설치에 따라 다양하다.
예를 들어, 로그인 이름이 eibm이면 프롬프트에서 다음과 같이 입력한다.
$login eibm
password: 프롬프트가 나타나며, 암호를 입력한 후 Enter를 누른다. 역시 사용자가 입력한 문자가 화면에 표지되지 않는다.)
▒▒ 시스템에서 다른 사용자 되기(su 명령) ▒▒
사용자가 로그인 이름을 알고 있을 경우 su(switch user)명령을 통해 세션과 연관이 있는 사용자 ID로 변경 할 수 있다.
예를 들어, 사용자 user1으로 전환하려면 프롬프트에서 다음과 같이 입력한다.
$su user1
password: 프롬프트가 나타나면, user1의 암호를 입력한 후 Enter를 누른다. 암호를 모른다면 su 요청은 거절 된다.
사용자가 전환 되고 현재의 사용자 ID를 확인하려면 id 명령을 입력하면 된다.
사용자의 환경설정을 적용하여 사용자 user2로 전환 하려면 프롬프트에서 다음과 같이 입력하면 된다.
$su - user2
정확한 구문은 명령어 사전을 참고한다.
▒▒ 로그인 메시지 억제 ▒▒
로그인에 성공하면, login 명령은 해당 사용자의 마지막으로 성공하거나 실패한 로그인 시도 날짜와 시간을 표시하고, 인증 정보(일반적으로 암호)의 최종 변경 이후에 이 사용자의 실패한 로그인 시도 총계를 표시한다. 그러나 사용자의 홈 디렉토리에 .hushlogin 파일이 있으면 이들 메시지는 억제된다.
홈 디렉토리의 프롬프트에서 다음과 같이 입력한다.
$touch .hushlogin
다음번에 사용자가 로그인하면, 모든 로그인 메시지는 억제된다. 사용자는 다른 로그인 메시지는 억제하면서 그날의 메시지는 보유하도록 시스템에 지시할 수 있다.
▒▒ 운영 시스템에서 로그아웃 (exit 및 logout 명령) ▒▒
프롬프트에서 다음 중 하나를 수행한다.
EOF 제어키(Ctrl+D)를 누른다. 또는
exit 를 입력하고 Enter를 누른다. 또는
logout을 입력하고 Enter를 누른다.
로그아웃한 후, 시스템은 login: 프롬프트를 표시한다.
▒▒ 운영 시스템 종료 (shutdown 명령) ▒▒
사용자가 루트 사용자 권한을 갖고 있으면, shutdown 명령을 사용하여 시스템을 종료시킬 수 있다. shutdown 명령을 사용하지 않고 사용자 시스템에서 전원을 끄면 안된다. 이는 데이터의 손실을 야기 시킬 수 있고, 파일 시스템의 손상을 가져 올 수 있다. shutdown 명령을 사용할 권한이 없다면, 그냥 운영 시스템에서 로그아웃 하고 수행되도록 두어야 한다.
프롬프트에 다음과 같이 입력한다.
$shutdown
시스템은 1분 동안 대기후에 사용자 터미널에 경고 메시지를 내보낸 후 정지 절차를 수행한다. 정확한 구문과 옵션은 명령어 사전을 찾아보기 바란다.
모든 정지절차가 완료되면 화면에 다음과 같은 메시지를 보여준다.
....Shutdown Completed....
동시에 여러 이름으로 로그인 되어 있을 때 로그인 이름을 추적하거나 특히 어떤 순간에 사용된 로그인 이름을 잊기 쉽다.
어떤 로그인 이름이 사용 중인지 알아보려면, 프롬프트에서 다음과 같이 입력한다.
$whoami
user1
$
이 예에서 로그인 이름은 user1 이다.
who 명령의 변형인 who am i 명령은 로그인 이름, 터미널 이름 및 로그인 시간을 표시한다.
프롬프트에 다음과 같이 입력하고 아래와 같은 정보를 확인 할 수 있다.
$who am i
user1 pts/2 Aug 4 10:12 (192.168.1.2)
$
이 예에서, 로그인 이름은 user1이고, 터미널 이름은 pts/2 이며, 이 사용자는 8월 4일 오전 10시 12분에 ip 192.168.1.2 로부터 로그인 하였음을 알 수 있다.
사용자를 식별하는데 사용되는 명령어는 위의 예 외에 logname 명령, who 나 w, id 명령등이 쓰일 수 있다. 자세한 옵션과 구문은 명령어 사전을 참고하면 된다.
▒▒ 사용자 시스템의 이름 표시 ▒▒
옵션 없이 사용되는 uname 명령은 운영 시스템의 이름을 표시한다. 기본적으로 AIX 일 것이다. 그러나 사용자가 네트워크 상에 있을 경우 사용자 시스템의 이름을 표시하려면 -n 옵션을 사용하여 식별한다. 이는 사용자 로그인 ID와는 다른 것이다.
예를 들어 프롬프트상에 다음과 같이 입력하면 아래와 같은 정보를 얻을 수 있을 것이다.
$uname -n
eibm
$
이 예에서 시스템 이름은 eibm 이다. 이는 hostname 명령으로도 확인 가능하다.
$hostname
eibm
$
알려지지 않은 암호를 사용하여 사용자 ID를 보안해야 한다. 사용자 이름이나 생일과 같은 개인 정보로 된 암호는 좋지 않다.
▶암호를 선택할 때는 다음과 같은 지침을 사용하는게 좋다.
- 암호를 기록해 두지 않는다. 그러나, 암호를 기록해야만 하는 경우, 잠금 장치가 되어 있는 캐비넷과 같은 안전한 장소에 둔다.
- 사용자 ID를 암호로 사용하지 않는다. 철자를 거꾸로, 두 번 반복해서 또는 수정해서 암호를 사용하지 않는다.
- 암호를 재사용하지 않는다. 시스템이 암호의 재사용을 거부할 수도 있다.
- 사람의 이름을 암호로 사용하지 않는다.
- 온라인 철자 검사 사전에서 찾을 수 있는 단어는 암호로 사용하지 않는다.
- 6문자 이하의 암호는 사용하지 않는다.
- 예의에 어긋난 단어를 암호로 사용하지 않는다. 이는 암호를 생각할 때 가장 먼저 고려해야 한다.
- 문자와 숫자를 모두 사용하며 대문자와 소문자가 모두 있는 암호를 사용한다.
- 숫자로 분리한 두 단어를 암호로 사용한다.
- 발음할 수 있는 암호를 사용해야 기억하기 쉽다.
프롬프트에서 다음과 같이 입력한다.
$passwd
암호가 있다면 다음과 같은 프롬프트가 나타난다.
Changing password for "user"
user1's Old password:
이 요청은 사용자가 없을 때 허가되지 않은 사용자가 사용자의 암호를 변경하지 못하도록 한다. 현재 암호를 입력한 후 Enter를 누르면 다음과 같은 프롬프트가 나타난다.
user's New password:
원하는 새 암호를 입력한 후 Enter를 누르면, 새로운 암호를 다시 확인하는 프롬프트가 나타난다. 이 요청은 사용자가 재작성 할 수 없는 잘못 입력된 문자열을 사용자의 암호로 설정하지 않도록 해준다.
Re-enter user's new password:
암호를 재 입력한 후 Enter를 누르면 다시 프롬프트로 빠져 나올 수 있다. 만약 일정시간동안 입력이 없다면 사용자는 다음과 같은 메시지와 함께 기본 프롬프트를 보게 될 것이다.
Error changing password for "user".
로그인 할 때마다 암호를 입력하지 않으려면 사용자 암호를 널(NULL)로 설정한다. 널로 설정하려면 passwd 명령후에 새 암호를 입력하라는 프롬프트에서 Enter 혹은 Ctrl+D를 입력하면 된다.
▒▒ 사용자의 시스템에 있는 장치 나열 ▒▒
lscfg 명령을 사용하여 읾, 위치 및 현재 구성설정된 장치에 대한 설명을 표시한다. 리스트는 장치 위치에 따라 분류된다. 예를 들어, 시스템에 구성설정된 장치를 나열하려면 프롬프트에서 다음과 같이 입력하고, 아래와 같은 정보를 표시한다.
$lscfg
INSTALLED RESOURCE LIST
The following resources are installed on the machine. +/- = Added or deleted from Resource List. * = Diagnostic support not available.
Model Architecture: rs6k Model Implementation: Uni-Processor, MCA bus
* sys0 00-00 System Object + sysplanar0 00-00 System Planar + ioplanar0 00-00 I/O Planar * bus0 00-00 Microchannel Bus * sio0 00-00 Standard I/O Planar + fda0 00-00-0D Standard I/O Diskette Adapter + fd0 00-00-0D-00 Diskette Drive + sioka0 00-00-0K Keyboard Adapter + kbd0 00-00-0K-00 PS/2 keyboard + sioma0 00-00-0M Mouse Adapter .. .. .. ▒▒ 중략 ▒▒ |
특정 장치에 대한 정보를 표시하기 위해, -l 플래그를 사용할 수 있다. 예를들어, 장치 sysplanar0 에 대한 정보를 나열하려면 다음을 입력한다. 아래와 유사한 메시지를 볼 수 있다.
$lscfg -l sysplanar0
DEVICE LOCATION DESCRIPTION
sysplanar0 00-00 System Planar
lscfg 명령을 사용하여 부품 번호, 일련 번호 및 엔지니어링 변경 레벨과 같은 주요 제품 데이터(VPD)를 표시 한다. 일부 장치의 경우 자동으로 VPD가 수집되어 시스템 구성설정에 추가 된다. 기타 장치의 경우, VPD정보를 수동으로 입력한다. 테이터 앞의 ME 는 데이터가 수동으로 입력되었음을 의미한다.
예를 들어, 시스템에 구성설정되어 있는 장치를 중요 제품 데이터와 함께 나열하려면 다음과 같이 입력하고 Enter를 누르면 아래와 유사한 메시지를 확인 할 수 있다.
$lscfg -v
INSTALLED RESOURCE LIST WITH VPD
The following resources are installed on your machine.
Model Architecture: rs6k Model Implementation: Uni-Processor, MCA bus
sys0 00-00 System Object sysplanar0 00-00 System Planar
Part Number.................040H5658 EC Level....................00D28062 Processor Identification....00430746 ROS Level and ID............IPLVER1.3 LVL3.01,065G8318 Processor Component ID......0800004800000050 Device Specific.(Z0)........000000 Device Specific.(Z1)........000000 Device Specific.(Z2)........000000 Device Specific.(Z3)........000000 Device Specific.(Z4)........000000 Device Specific.(Z5)........000000 Device Specific.(Z6)........000000 Device Specific.(Z7)........000000 .. .. .. ▒▒ 중략 ▒▒
|
▒▒ 콘솔 이름 표시 ▒▒
lscons 명령은 보통 화면인 표준 출력에 현재 콘솔 장치의 이름을 표시한다.
예를 들어, 프롬프트 상태에서 다음과 같이 입력하면 아래와 유사한 메시지를 확인할 수 있다.
$lscons
/dev/lft0
▒▒ 사용자 터미널 이름 표시 ▒▒
tty 명령은 사용자의 터미널 이름을 표시한다.
예를 들어, 프롬프트 상태에서 다음과 같이 입력한다
$tty
Enter를 누르면 다음과 같은 정보를 얻을 수 있다.
/dev/pts/2
이 예에서 tty06은 터미널 이름이고, /dev/tty06은 현재 터미널에 해당하는 인터페이스를 포함하는 장치 파일이다.
▒▒ 사용 가능한 표시장치 나열 ▒▒
lsdisp 명령은 표시장치 식별 이름, 슬롯 번호, 표시장치 이름 및 표시장치의 설명을 제공하면서, 사용자의 시스템에 현재 사용 가능한 표시장치를 나열한다.
예를 들어 사용가능한 표시장치를 모두 나열하려면 다음과 같이 입력한다.
$lsdisp DEV_NAME SLOT BUS ADPT_NAME DESCRIPTION ======== ==== === ========= =========== nep0 00-03 mca GXT150M Graphics Adapter
Default display = nep0
|
▒▒ 사용가능한 폰트 나열 ▒▒
lsfont 명령은 사용자의 표시장치에 사용 가능한 폰트 리스트를 나열한다.
예를 들어, 표시장치에 사용 가능한 모든 폰트를 리스트 형식으로 나열하려면 다음과 같이 실행한다.
$lsfont
FONT FILE GLYPH FONT ID NAME SIZE ENCODING ==== ============== ===== ========= 0 Erg22.iso1.snf 12x30 ISO8859-1 1 Erg11.iso1.snf 8x15 ISO8859-1
|
▒▒ 키보드 맵 나열 ▒▒
lskbd 명령은 사전 정의된 키보드 식별 이름과 번호를 표시하여 현재 사용 가능한 키보드 맵을 나열한다.
예를 들어, 모든 키보드 맵을 나열하려면 다음과 같이 실행한다.
$lskbd
Enter를 누르면 다음과 같은 화면을 출력한다.
The current software keyboard map = /usr/lib/nls/loc/ko_KR.lftkeymap.
▒▒ 소프트웨어 제품 나열 ▒▒
lslpp 명령은 사용자 시스템에서 사용 가능한 제품 정보를 표시한다.
예를 들어, 시스템에 있는 모든 소프트웨어 제품을 나열하려면 시스템 프롬프트에서 다음과 같이 실행한다.
$lslpp -l -a |more Fileset Level State Description ---------------------------------------------------------------------------- Path: /usr/lib/objrepos IMNSearch.rte.httpdlite 2.0.0.1 COMMITTED NetQuestion Web Server Java.rte.bin 1.1.8.0 COMMITTED Java Runtime Environment Executables 1.1.8.8 APPLIED Java Runtime Environment Executables Java.rte.classes 1.1.8.0 COMMITTED Java Runtime Environment Classes 1.1.8.8 APPLIED Java Runtime Environment Classes Java.rte.lib 1.1.8.0 COMMITTED Java Runtime Environment Libraries 1.1.8.8 APPLIED Java Runtime Environment Libraries OpenGL.html.ko_KR.gl32 4.3.3.0 COMMITTED GL3.2 Guides - Korean OpenGL.html.ko_KR.opengl 4.3.3.0 COMMITTED OpenGL Guides - Korean PEX_PHIGS.html.ko_KR.graPHIGS_gd 4.3.3.0 COMMITTED graPHIGS Guides - Korean PEX_PHIGS.html.ko_KR.graPHIGS_libs 4.3.3.0 COMMITTED graPHIGS Reference - Korean X11.Dt.ToolTalk 4.3.3.0 COMMITTED AIX CDE ToolTalk Support
... ... ... ▒▒ 중략 ▒▒ |
리스트가 너무 길면, 상단 위치를 화면에서 볼 수 없기 때문에 이를 방지하려면, lslpp 명령을 pg 명령이나 more 명령과 파이프로 연결하여 사용하면 된다. 예를 들면 다음과 같다.
$lslpp -l -a |pg 또는
$lslpp -l -a |more
▒▒ 사용자 터미널용 제어 키 지정 나열 ▒▒
stty 명령은 사용자 터미널 설정을 표시한다. 이들 설정의 대부분을 무시해도 좋지만, 중요한 정보는 사용자 터미널에 사용할 제어키이다. 예를 들어 프롬프트 상태에서 다음과 같이 입력한다.
$ stty -a speed 9600 baud; 25 rows; 80 columns eucw 1:1:0:0, scrw 1:1:0:0: intr = ^C; quit = ^\; erase = ^H; kill = ^U; eof = ^D; eol = ^@ eol2 = ^@; start = ^Q; stop = ^S; susp = ^Z; dsusp = ^Y; reprint = ^R discard = ^O; werase = ^W; lnext = ^V -parenb -parodd cs8 -cstopb hupcl cread -clocal -parext -ignbrk brkint ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl -iuclc -ixon -ixany -ixoff imaxbel isig icanon -xcase echo echoe echok -echonl -noflsh -tostop echoctl -echoprt echoke -flusho -pending iexten opost -olcuc onlcr -ocrnl -onocr -onlret -ofill -ofdel tab3 $ |
위의 예에서, intr = ^C; quit = ^\; erase = ^H; 와 같은 행이 사용자 제어키 설정이다. ^H 키는 백스페이스 키이며 erase 는 키가 수행하도록 설정되는 함수이다. 마찬가지로 리스트가 너무 길면 pg 명령이나 more 명령과 함께 사용한다.
▒▒ 모든 사용자 환경 변수 나열 ▒▒
env 명령을 통해 현재 환경 변수를 표시할 수 있다. 사용자의 모든 프로세스에 액세스할 수 있는 변수를 전역 변수라 한다.
실행을 시작할 때 명령에 알려진 모든 변수(연관 값과 함께)가 실행 환경을 조성한다. 이 환경에는 명령이 상위 프로세스로부터 상속받은 변수 및 명령을 호출하는 명령행의 키워드 매개변수로서 지정된 변수에서부터 받은 변수도 포함된다. 쉘은 몇 가지 방법으로 환경과 상호작용을 한다. 시작될 때, 쉘은 환경을 탐색하여 매개변수에 대응하는 값을 주고 그것을 반출용으로 표시하면 발견된 각각의 이름에 대한 매개변수를 작성한다. 실행된 명령이 환경을 상속하게 된다.
다음과 같이 사용할 수 있다.
$env _=/usr/bin/env LANG=c LOGIN=test IMQCONFIGCL=/etc/IMNSearch/dbcshelp AIX_LOCKKEY=38 PATH=/usr/bin:/etc:/usr/sbin:/usr/ucb:/home/test/bin:/usr/bin/X11:/sbin:. LC__FASTMSG=true IMQCONFIGSRV=/etc/IMNSearch CGI_DIRECTORY=/var/docsearch/cgi-bin LOGNAME=test MAIL=/usr/spool/mail/test LOCPATH=/usr/lib/nls/loc AIX_LOCKBITS=00 DOCUMENT_SERVER_MACHINE_NAME=localhost USER=test ... ... ▒▒ 중략 ▒▒ # |
▒▒ 양방향 언어로 작업 ▒▒
aixterm 명령은 양방향 언어인 아랍어 및 히브루어를 지원한다. 양방향 언어는 왼쪽에서 오른쪽, 오른쪽에서 왼쪽으로의 두 방향으로 읽고 쓸 수 있는 언어이다. 아랍 또는 히브루어를 지정하는 창을 열어 아랍어 및 히브루어 응용프로그램으로 작업 할 수 있다.
정확한 구문은 명령어 사전을 참고하라.
제 3 장 Command and Process
명령은 조작을 수행하거나 또는 프로그램을 수행하기 위한 요청이다. 명령을 사용하여 운영 시스템에게 수행 하고 싶은 작업이 무엇인지 지시할 수 있다. 명령이 입력되면, 쉘로 해석되어 작업이 수행된다.
실제 컴퓨터에서 수행중인 프로그램이나 명령은 프로세스이다. 운영 시스템은 동시에 서로 다른 많은 프로세스를 수행 할 수 있다. 또한 운영 시스템을 통해 사용자는 고유의 I/O 명령 및 기호를 사용하여 사용자 시스템의 입출력 데이터를 조작할 수 있다. 데이터를 수집할 위치를 지정하여 입력을 제어할 수도 있다. 예를들어, 데이터가 키보드(표준입력)에 입력될 때 입력을 읽거나 파일에서 입력을 읽을 수 있도록 지정할 수 있다. 데이터를 표시하거나 저장할 장소를 지정하여 출력을 제어할 수 있다. 예를들어, 화면(표준출력)으로 출력 데이터를 쓰고 또는 파일에 데이터를 쓸 수 있도록 지정할 수 있다.
3-1. 명령 개요
한 단어만 입력하여 실행되는 명령도 있다. 또한, 하나의 명령에서의 출력이 다른 명령에 대한 입력이 될 수 있도록 명령을 결합할 수도 있다. 이것을 파이핑이라 한다.
플래그(옵션)는 명령의 활동을 더 상세히 정의한다. 플래그는 명령행에서 명령 이름과 함께 사용되는 수정자이며, 부통 대쉬"-"가 앞에 나온다.
명령은 또한 그룹으로 묶여 파일에 저장될 수 있다. 이것을 쉘 프로시저 또는 쉘 스크립트라 한다. 이는 명령을 개별적으로 실행하는 대신 명령이 포함된 파일을 실행한다.
3-1-1. 명령 구문
한 단어만 타이프하여 입력되는 명령도 있지만 다른 명령들은 플래그 및 매개변수를 사용한다. 각각의 명령에는 필수 및 선택 플래그와 매개변수를 지정하는 구문이 있다. 명령의 일반적인 형식은 다음과 같다.
commandName Flag(s) parameter(s)
명령의 일반적인 규칙은 다음과 같다.
$CommandOne;CommandTwo
쉘은 순차적으로 명령을 수행한다.
$ls Mail info temp \ (Enter 키 입력)
▒▒ diary ....
▒▒ 문자는 2차 프롬프트($은 비루트 사용자의 디폴트 1차 프롬프트)이며 현재 행이 이전 행의 연속임을 나타낸다. csh는 2차 프롬프트를 제공하지 않고, 단어 경계에서 단어를 분리해야 하며, 기본 프롬프트는 % 이다.
- 명령 이름 -
모든 명령의 첫 단어가 명령 이름이다. 명령 이름만 있는 명령도 있다.
- 명령 플래그 -
명령 이름 뒤에 몇 개의 플래그가 올 수 있다. 플래그를 옵션이라고 할 때도 있다. 플래그는 빈칸 또는 탭으로 끊고, 보통 대쉬"-"로 시작한다. 예외적으로 ps, tar, ar 등은 플래그 앞에 대쉬를 필요로 하지 않는다. 글래그는 명령의 작동을 변경 한다. 다음 명령을 예로 들면,
$ls -a -F
ls는 명령 이름이고, -a -F는 플래그 이다.
명령이 플래그를 사용할 때는 명령 이름 다음에 놓인다. 명령에서 단일 문자 플래그는 한 개의 대쉬로 결합된다. 예를 들면, 이전 명령을 다음과 같이 쓸 수 있다.
$ls -aF
어떤 환경에서는 실제로 매개변수가 대쉬로 시작하는 경우도 있다 이런 경우, 매개변수 앞에 분리문자 --를 사용한다. --는 명령에 뒤에 오는 것이 플래그가 아니라 매개변수임을 알려준다. 예를 들어, -tmp라는 디렉토리를 작성하기 위해 다음 명령을 입력한다.
$mkdir -tmp
시스템은 다음과 유사한 오류 메시지를 표시할 것이다.
mkdir:Not a recognized flag: t
Usage:mkdir [-p] [-m] Directory ...
올바른 명령은 다음과 같다.
$mkdir -- -tmp
위와 같이 실행하면 새로운 디렉토리 -tmp가 작성된다.
- 명령 매개변수 -
명령 이름 뒤에 몇 개의 플래그가 오고 그 뒤에 매개변수가 올 수 있다. 매개변수를 인수 또는 피연산자라고 할 때도 있다. 매개변수는 명령 수행에 필요한 정보를 지정한다. 매개변수를 지정하지 않으면, 명령이 디폴트 값을 취할 수도 있다. 예를 들어,
$ls -a temp
ls는 명령 이름, -a는 플래그, temp는 매개변수이다. 이 명령은 디렉토리 temp안에 있는 모든 (-a)파일을 표시한다. 또한 매개변수가 없을 때에는 디폴트 값으로 현재 디렉토리의 파일을 표시한다. 다음과 같이 하나이상의 매개변수를 지정할 수도 있다.
$ls temp mail
위와 같이 실행하면 서로다른 두 디렉토리에 포함된 파일들을 모두 표시하게 된다.
매개변수 또는 옵션 인수가 숫자값이거나 숫자값을 표함한 경우 그 숫자는 달리 지정되어 있지 않는 한 십진수로 해석된다. /usr/include/sys/limits.h에 정의된 대로 0에서 INT_MAX 까지 범위의 수는 구문상 수치값으로 인식된다.
사용하려는 명령이 매개변수 또는 옵션 인수로 음수를 수용할 경우, /usr/include/sys/limits.h에서 정의한 대로 INT_MIN - INT_MAX 범위의 수를 사용할 수 있다. 그러나 이것이 범위 안의 모든 수가 의미론적으로 반드시 맞다는 뜻은 아니다. 어떤 종류의 인쇄 명령과 같이 더 작은 범위의 수를 허용하는 내장된 스펙을 갖는 명령도 있다. 오류가 발생할 경우, 오류 메시지로 인해 해당 값이 지원되는 범위를 벗어났다는 것은 알 수 있지만 해당 명령이 구문상 맞지 않다는 것은 알 수 없다.
3-1-2. 사용법 문장 읽기
사용법 문장은 명령 구문을 표현 할 수 있는 다른 방법이다. 구문 도표와 마찬가지로 사용법 문장은 명령행에서 명령을 입력하는 방법을 지시한다. 사용법 문장이 도료와 동일한 유형의 구문 정보를 제공하더라도 도표 형식으로 되어 있지는 않다. 오히려, 대괄호"[]", 중괄호"{}" 및 수직 표시줄"|" 같은 기호로 구성된다. 다음은 unget 명령에 대한 사용법 문장의 샘플이다.
unget [ -r SID ] [ -s ] [ -n ] File ...
굵은체 및 기울임체에 대한 규약은 구문 도표의 경우와 같다. 다음은 명령 사용법 문장에 사용되는 추가 규약이다.
3-1-3. 웹 기반 시스템 관리자 사용
웹 기반 시스템 관리자는 국지적으로 접속된 표시장치에서 또는 웹 브라우저가 설치된 다른 시스템이나 개인용 컴퓨터에서 시스템을 원격으로 관리할 때 사용하는 그래픽 사용자 인터페이스 이다. 다음과 같은 다양한 방법으로 웹 기반 시스템 관리자를 시작할 수 있다.
3-1-4. 유용한 Command
▒▒ 명령 또는 프로그램 찾기 ▒▒
whereis 명령은 지정된 파일의 소스, 2진 및 매뉴얼 영역을 찾는다. 이 명령은 표준 위치 리스트에서 원하는 프로그램을 찾으려고 한다.
문서가 없는 현재 디렉토리에서 파일을 찾으려면 다음과 같이 입력하고 Enter를 누른다.
$whereis -m -u *
또한 , Mail 이라는 이름이 들어 있는 모든 파일을 찾으려면 다음과 같이 입력한다.
$whereis Mail
다음과 유사한 결과를 얻을 수 있을 것이다.
Mail : /usr/bin/Mail /usr/lib/Mail.rc
▒▒ 명령에 대한 정보 표시 ▒▒
man 명령은 명령, 서브루틴 및 파일에 대한 정보를 표시한다. man 명령의 일반 형식은 다음과 같다.
$man CommandName
pg 명령에 대한 정보를 얻으려면 다음과 같이 입력한ㄷ.
$man pg
시스템은 다음과 유사한 정보를 표시한다.
pg Command
Purpose
Formats files to the display.
Syntax
pg [ -Number ] [ -c ] [ -e ] [ -f ] [ -n ] [ -p String ] [ -s ] [ +LineNumber ] [ +/Pattern/ ] [ File ... ]
Description
The pg command reads a file name from the File parameter and writes the file to standard output one screen at a time. If you specify a - (dash) as the File parameter, or run the pg command without options, the pg command reads standard input. Each screen is followed by a prompt. If you press the Enter key, another page is displayed. Subcommands used with the pg command let you review or search in the file. |
또한, InfoExplorer 프로그램을 사용하여 man 명령이 제공하는 정보를 얻을 수 있다.
▒▒ 명령의 기능 표시 ▒▒
whatis 명령은 catman -w 명령을 사용하여 작성한 데이터베이스에서, Command 매개변수에 지정된 대로 지정된 명령, 시스템 호출, 라이브러리 함수 또는 특수 파일 이름을 찾는다. whatis 명령은 매뉴얼 영역의 헤더 행을 표시한다. whatis 명령은 man -f 명령과 동일한 수행을 하게 된다.
ls 명령의 수행 내용을 알아보려면 다음과 같이 입력한다.
$whatis ls
Enter 키를 누르면 다음과 유사한 정보를 확인 할 수 있다.
ls(1) -Displays the contents of a directory.
▒▒ 이전에 입력된 명령 나열 ▒▒
history 명령은 마지막으로 입력된 16개 명령을 나열하는 Korn 쉘 내장 명령이다. Korn 쉘은 보통 $HOME/.sh_history 라는 명령 히스토리 파일에 사용자가 입력한 명령을 저장한다. 이는 이전 명령을 반복 수행해야 할 때 시간을 절약하게 해준다. 디폴트는 Korn 쉘이 마지막 128개 명령의 텍스트를 저장하는 것이다. 히스토리 파일 크기가 너무 크면 Korn 쉘의 시작이 늦어질 수 있지만, 히스토리 파일 크기(HISTSIZE 환경 변수로 지정)의 제한은 없다.
note : history 쉘 명령은 INet 편집기와 함께 사용되는 history 명령과 같지 않다. 또한 Bourne 쉘은 명령 내역을 지원하지 않는다는 것을 명심해야한다. |
이전에 입력했던 명령을 나열하려면 프롬프트 상에서 다음과 같이 입력하면 된다.
$history
아래와 같은 출력을 얻을 수 있을 것이다.
35 ls
36 smit
37 stty -a
38 tty
39 lscons
40 lsdisp
41 lskbd
42 ls -al
43 ls |pg
44 pwd
45 man pg
46 mail
47 whereis Mail
48 vi .sh_history
49 clear
50 history
이전 다섯 개의 명령을 나열하려면 프롬프트에서 다음과 같이 입력한다.
$history -5
또한 이전 100 번째부터 사용한 모든 명령어들을 나열하려면 다음과 같이 입력한다.
$history 100
▒▒ 쉘 history 명령을 사용한 명령 반복 ▒▒
Korn 쉘 별명 r을 사용하여 이정 명령을 반복할 수 도 있다. r을 입력한 후 Enter를 누르면, 명령의 번호나 첫 번째 문자를 지정할 수 있다. r 명령은 가장 최근에 입력된 명령을 다시 수행한다. 또한 r 명령을 매개변수와 함께 사용할 수 있는데, 다음과 같이 사용할 수 있다.
$r ls
위 명령은 지정된 문자 "ls"로 시작하는 가장 최근의 명령을 찾는다.
▒▒ 쉘 history 명령을 사용한 문자열 대체 ▒▒
명령이 수행되기 전에 변경하기 위해 r 명령을 사용할 수도 있다. 이 경우, 수행하기 전에 Old=New 양식의 대체 매개변수를 사용하여 명령을 수정할 수 있다.
예를 들어, 100 명령행이 ls *.txt 인데 sl *.exe를 수행하려는 경우, 프롬프트에서 다음과 같이 입력한다.
$r txt=exe 100
위와같이 입력후 Enter를 누르면 txt를 exe로 대체한 100행의 명령이 수행된다.
▒▒ 명령 내역 편집 ▒▒
Korn 쉘 내장 명령 fc를 사용하여 명령 히스토리 파일 일부를 나열 또는 편집할 수 있다. 파일의 일부를 선택하여 나열하거나 편집하려면, 명령의 문자나 최초 문자 또는 번호를 지정한다. 단일 명령 또는 명령의 범위를 지정할 수 있다.
Korn 쉘 내장 명령 fc에 대한 인수로서 편집 프로그램을 지정하지 않는 경우, FCEDIT 변수에 의해 지정된 편집기가 사용된다. FCEDIT 변수가 정의되어 있지 않은 경우, /usr/bin/ed 편집기가 사용된다. 편집기 종료시 편집된 명령이나 명령들이 인쇄되고 수행된다. printenv 명령을 사용하여 FCEDIT 변수 값을 표시할 수 있다.
예를 들어, 명령행100 이 "cd /usr/include/sys" 이고, "cd /usr/tmp" 와 같은 명령을 실행하고 싶은 경우 프롬프트에 다음과 같이 입력한다.
$fc 100
이때, 사용자의 디폴트 편집기가 실행되어 명령행 100을 화면에 나타낸다. tmp에 include/sys를 변 경할 수 있고 편집기를 종료하면 편집된 명령이 수행된다.
fc 명령에서 사용하려는 편집기를 지정할 수도 있다. 예를 들어, /usr/bin/vi 편집기를 사용하여 명령을 편집하려는 경우, 프롬프트에서 다음과 같이 입력한다.
$fc -e vi 100
또한 편집할 명령의 범위를 지정할 수도 있다. 예를 들어, 90에서 110 까지의 명령을 편집 하려는 경우, 프롬프트에서 다음과 같이 입력한다.
$fc 90 110
이때 사용자의 디폴트 편집기가 실행되어 명령행 90에서 110에 걸쳐 모두 화면에 나타낸다. 편집기를 종료하면 편집기에 나타나는 모든 명령은 순차적으로 수행된다.
▒▒ 명령 별명 작성 ▒▒
alias 명령을 사용하여 명령, 파일 이름 또는 쉘 텍스트에 대한 단축 명령을 작성 할 수도 있다. 별명을 사용하면 작업을 빈번히 수행할 때 많은 시간이 절약된다. Korn 쉘 내장 명령 alias는 단어를 일부 명령에 대한 별명으로서 정의한다. 내장 명령 재정의에 별명을 사용할 수 있지만 전용어 재정의에는 사용할 수 없다.
별명의 최초 문자는 메타문자 외의 인쇄 가능한 모든 문자가 될 수 있다. 나머지 문자들은 파일 이름으로 유효한 문자와 동일해야 한다. 별명을 작성하는 형식은 다음과 같다.
alias Name=String
Name 매개변수는 별명의 이름을 지정하고 String 매개변수가 문자열을 지정한다. String 에 공백이 있으면, 인용부호로 묶어야 한다. 예를 들어 ls -al 이라는 명령을 dir 로 대체해서 사용하고 싶다면 다음과 같이 해주면 된다.
$alias dir="ls -al"
위 명령 이후에 프롬프트에서 dir을 입력하면 ls -al을 입력하는 것과 마찬가지의 결과를 얻을 수 있다.
현재 사용자에게 정의된 모든 별명을 표시하려면 프롬프트에서 alias를 인수 없이 입력하면 된다.
3-1-5. 텍스트 포맷 명령에 대한 작업
텍스트 포맷 명령을 사용하여, 유럽 언어에 사용되는 국제 확장 문자 집합으로 구성된 텍스트에 대해 작업 할 수 있다.
▒▒ 텍스트 형식으로 국제 문자 지원 ▒▒
국제 확장 문자 집합은 영어 문자, 숫자 및 구두점으로 구성된 ASCII 부분집합 뿐 아니라, 다수 유럽 언어에 사용되는 문자와 기호를 제공한다.
유럽 확장 문자 집합의 모든 문자는 ASCII 양식을 가진다. 이런 양식을 사용하여 입력에서 확장 문자를 표시하거나, 유럽 확장 문자 지원 키보드와 같은 장치로 문자를 직접 입력할 수 있다.
다음의 텍스트 포맷 명령은 단일 바이트 문자를 사용하는 모든 국제 언어를 지원한다. 이런 명령은 /usr/bin/에 존재한다. 별표(*)로 식별되는 명령은 복수 바이트 언어에 대한 텍스트 처리를 지원한다.
addbib* hyphen pic* pstext
checkmm ibm3812 ps4014 refer*
checknr* ibm3816 ps630 roffbib*
col* ibm5587G* psbanne soelim*
colcrt ibm5585H-T* psdit sortbib*
deroff* indxbib* psplot tbl*
enscript lookbib* psrev troff*
eqn* makedev* psroff vgrind
grap* neqn* psrv xpreview*
hplj nroff*
위 리스트에 없는 텍스트 포맷 명령 및 매크로 패키지로는 국제 문자를 처리할 수 없다.
▒▒ 확장 단일 바이트 문자 입력 ▒▒
입력 장치가 유럽 언어 확장 문자 집합의 문자를 지원할 경우, 문자를 직접 입력할 수 있다. 그렇지 않을 경우에는 이 문자를 표시하는 다음과 같은 ASCII escape 순서를 사용한다.
\[N] 형식이며, 여기서 N은 문자에 대한 2자리 또는 4자리 16진 코드이다.
note : NCesc 양식 \▒▒ xx ▒▒은 더 이상 지원되지 않는다. |
확장 문자를 표함한 텍스트는 사용중인 언어 포맷 규약에 따라 출력된다. 특정 출력 장치에 대한 인터페이스용으로 정의되지 않은 문자는 출력 또는 오류 표시를 할 수 없다.
매크로 패키지 및 명령의 이름이 영어에 기반을 두고 있더라도, 대부분의 이름은 유럽 확장 문자 집합의 문자로 된 입력(파일 이름 및 매개변수와 같이)이 가능하다.
nroff 및 troff 명령과 그 프리프로세서의 경우, 명령 입력은 ASCII여야 한다. 그렇지 않으면 복구 할 수 없는 구문 오류가 발생한다. 단일 또는 복수 바이트의 국제 문자는 인용 부호로 묶고 포맷할 다른 텍스트가 없어야 입력할 수 있다. 예를 들어, 다음과 같이 pic 명령에서 매크로를 사용한다.
define foobar % SomeText %
define 지시문 다음에, 첫 번째 이름인 foobar는 ASCII여야 한다. 그러나 대체 텍스트 SomeText 는 비 ASCII 문자를 표함할 수 있다.
▒▒ 텍스트 포맷의 복수 바이트 문자 지원 ▒▒
특정 텍스트 포맷 명령이 다중 바이트 언어로 된 텍스트 처리에 사용될 수 있다. 이런 명령은 위에서 살펴본 -텍스트 형식으로 국제 문자 지원- 아래의 리스트에서 별표(*)로 식별된다. 리스트에 없는 텍스트 포맷 명령은 국제 문자를 처리할 수 없다.
▒▒ 다중 바이트 문자 입력 ▒▒
입력 장치가 지원할 경우에는 복수 바이트 문자를 직접 입력할 수 있다. 그렇지 않을 경우에는 복수 바이트 문자를 ASCII양식 \[N]으로 입력 할 수 있으며, 여기서 N은 해당 문자에 대한 2, 4, 6, 7 또는 8 자리 16진 문자이다. 매크로 패키지 및 명령의 이름이 영어에 기반을 두고 있을 지라도 대부분의 이름은 모든 유형의 다중 바이트 문자로 된 입력(파일 이름 및 매개변수와 같이)이 가능하다.
이미 단일 바이트 텍스트에 텍스트 포맷 명령 사용에 익숙할 경우, 다음 리스트는 다중 바이트 포케일에 고유 하거나 주목할 만한 문자를 요약한다.
- 텍스트는 하이픈으로 연결되지 않는다. 다중 바이트 숫자 출력에 특수 형식 유형이 필요하다. 일본어 형식 유형을 사용할 수도 있다. 텍스트는 왼쪽에서 오른쪽으로 가득차게 수평으로 출력된다. 문자 공간은 일정하기 때문에 문자는 자동으로 열별로 정렬된다. 특정 출력 장치에 대한 인터페이스용으로 정의되지 않은 문자는 출력 또는 오류 표시를 할 수 없다.
3-2. 프로세스 개요
실제 컴퓨터에서 수행중인 프로그램이나 명령은 프로세스이다. 프로세스는 상위-하위 계층에 존재한다. 프로그램 또는 명령으로 시작되는 프로세스는 상위 프로세스이다. 서브프로세스는 상위 프로세스의 산출물이다. 상위 프로세스에는 여러 서브프로세스가 있을 수 있지만, 서브프로세스에는 단 하나의 상위만 있을 수 있다.
시작될 때, 시스템은 프로세스 식별 번호(PID 번호)를 각각의 프로세스에 지정한다. 동일한 프로그램을 여러번 시작하면, 프로그램은 매번 서로 다른 PID 번호를 갖게 된다.
프로세스가 시스템에서 시작될 때, 프로세스는 사용 가능한 시스템 자원의 일부를 사용한다. 하나 이상의 프로세스가 수행되는 중에, 운영 시스템에 내장되어 있는 스케줄러가 구축된 우선순위에 따라, 각각의 프로세스에 컴퓨터 시간의 공유를 제공한다. 이들 우선순위는 nice 또는 renice 명령을 사용하여 변경 될 수 있다.
주: 루트 사용자 권한이 있는 일부 사용자만이 프로세스 우선순위를 보다 높은 프로세스 우선순위로 변경 할 수 있다. 모든 사용자는 nice 명령을 사용하여 시작한 프로세스나 renice 명령을 사용하여 이미 시작한 프로세스의 우선순위를 낮출 수 있다.
3-2-1. 백그라운드 및 포어그라운드 프로세스
시작 후 사용자와의 상호작용을 필요로 하는 프로세스가 포어그라운드 프로세스이다. 사용자와의 상호작용 없이 수행된 프로세스는 백그라운드 프로세스이다. 프로그램과 명령은 디폴트로 포어그라운드로 수행된다. 백그라운드에서 프로세스를 수행하려면, 앰퍼샌드(&)를 사용자가 프로세스를 시작하는 데 사용한 명령 이름의 끝에 놓아야 한다.
3-2-2. 데몬
daemon은 무인 수행 프로세스이다. daemon은 항상 백그라운드에 존재하며 언제든지 사용 가능하다. daemon은 일반적으로 시스템이 시작되면 시작되며 시스템이 정지할 때 까지 수행된다. daemon 프로세스가 시스템 서비스를 수행하여 언제든지 하나 이상의 작업이나 사용자를 지원할 수 있다. daemon 프로세스는 루트 사용자나 루트 쉘에 의해 시작되고 루트 사용자에 의해서만 정지될 수 있다.
3-2-3. 좀비 프로세스
좀비 프로세스는 더 이상 실행할 수는 없지만 프로세스 테이블에 여전히 인식되는 (즉, PID 번호를 갖고 있는) 폐기된 프로세스이다. 좀비 프로세스가 좀비 프로세스에 할당된 다른 시스템 영역을 갖고 있지는 않다. 좀비 프로세스는 종료하였거나 종료되었으며, 상위 프로세스가 종료하거나 시스템이 종료되고 재시작될 때까지 프로세스 테이블에 계속 존재한다. 좀비 프로세스는 ps 명령으로 나열될 때, ▒▒ defunct ▒▒ 로 나타난다.
3-2-4. 프로세스 시작
사용자가 프로그램 이름이나 명령 이름을 시스템 프롬프트에 입력하여 표시장치에서 포어그라운드 프로세스를 시작한다. 일단 포어 그라운드 프로세스가 시작되었으면, 프로세스는 완료될 때까지 사용자의 표시장치에서 사용자와 대화한다. 이는 프로세스가 종료 되었거나 사용자가 프로세스를 정지시킬 때까지는 표시장치에 다른 상호작용(예를 들어, 다른 명령 입력)이 발생할 수 없다는 의이미다.
▒▒ 포어그라운드에서 프로세스 시작 ▒▒
포어그라운드에서 프로세스를 수행하려면 다음과 같이 해당 매개변수 및 플래그와 함께 명령 이름을 입력한다.
$CommandName
▒▒ 백그라운드에서 프로세스 시작 ▒▒
백그라운드에서 프로세스를 수행하려면 모든 해당 매개변수 및 플래그와 함께 명령 이름을 입력한 후 앰퍼샌트(&)를 입력하고, Enter를 누른다.
$CommandName &
프로세스가 백그라운드에서 수행중이면, 표시장치에 다른 명령을 입력하여 추가 작업을 수행할 수 있다. 일반적으로 백그라운드 프로세스는 수행하는데 시간이 오래 걸리는 명령에 매우 유용하다. 그러나, 이들은 프로세서가 수행하고 있는 총 작업량을 증가시키기 때문에 결국 백그라운드 프로세스도 시스템을 느리게 할 수 있다.
대부분의 프로세스가 백그라운드로 수행 될 때도 이들의 출력을 표준 출력으로 지정한다. 재지정되지 않으면, 표준 출력이 표시장치로 이동한다. 백그라운드 프로세스로 인한 출력이 시스템에서 사용자의 다른 작업을 방해할 수 있으므로 일반적으로 백그라운드 프로세스의 출력을 파일이나 프린터로 재지정 하는 것이 좋다.
note : 특정 환경에서는, 프로세스가 포어그라운드에서 수행될 때와 백그라운드에서 수행될 때 서로 다른 순서로 출력을 작성할 수도 있다. fflush 서브루틴을 사용하면 프로세스가 포어그라운드 또는 백그라운드에서 수행되는지 여부에 상관없이 올바른 출력을 얻을 수 있다. |
백그라운드 프로세스가 수행중인 동안에 ps 명령을 사용하여 명령의 상태를 검사할 수 있다.
3-2-5. 프로세스 검사
어느 때고 시스템이 수행중이면, 몇 개의 프로세스도 수행중이다. ps 명령을 사용하여 어떤 프로세스가 수행 중인지 알아보고 해당 프로세스에 대한 정보를 표시할 수 있다.
▒▒ ps 명령 ▒▒
ps 명령은 어떤 프로세스를 나열할지 그리고 각각의 프로세스에 어떤 정보를 표시할지 지정하는 몇 개의 플래그를 갖고 있다.
시스템에서 수행중인 모든 프로세스를 표시하려면 프롬프트에서 다음과 같이 입력한다.
$ps -ef
시스템은 다음과 유사한 정보를 표시할 것이다.
USER PID PPID C STIME TTY TIME CMD root 1 0 0 Jun 28 - 3:23 /etc/init root 1588 6963 0 Jun 28 - 0:02 /usr/etc/biod 6 root 2280 1 0 Jun 28 - 1:39 /etc/syncd 60 mary 2413 16998 2 07:57:30 - 0:05 aixterm mary 11632 16998 0 07:57:31 lft/1 0:01 xbiff mary 16260 2413 1 07:57:35 pts/1 0:00 /bin/ksh mary 16469 1 0 07:57:12 lft/1 0:00 ksh /usr/lpp/X11/bin/xinit mary 19402 16260 20 09:37:21 pts/1 0:00 ps -ef ... ... |
위 열의 표제는 다음과 같다.
USER 사용자 로그인 이름
PID 프로세스 ID
C 프로세스의 CPU 활용
STIME 프로세스의 시작 시간
TTY 프로세스를 제어하는 워크스테이션
TIME 프로세스의 총 실행 시간
CMD 실행 명령
위의 예에서, ps -ef 명령의 프로세스 ID는 19402이다. 상위 프로세스 ID는 16260 이고, /bin/ksh에서 수행되었다.
시스템에서 수행중인 모든 프로세스의 상태를 표시하려면 다음 표와 같이 실행한다.
$ps gv PID TTY STAT TIME PGIN SIZE RSS LIM TSIZ TRS %CPU %MEM COMMAND 0 - A 10:30 7 268 7784 xx 0 7528 0.0 6.0 swapper 1 - A 1:41 203 964 620 32768 26 36 0.0 0.0 /etc/init 516 - A 35971:47 0 264 7772 xx 0 7528 99.1 6.0 kproc 774 - A 0:52 6 272 7784 xx 0 7528 0.0 6.0 kproc 1032 - A 117:52 0 320 7820 xx 0 7528 0.3 6.0 kproc 1290 - A 0:05 0 272 7796 xx 0 7528 0.0 6.0 kproc 2142 - A 2:32 104 744 764 xx 102 104 0.0 1.0 /usr/dt/b 2332 - A 0:00 0 272 7780 xx 0 7528 0.0 6.0 kproc 2884 - A 61:12 782 392 300 xx 2 4 0.2 0.0 /usr/sbin 3252 - A 0:00 0 616 888 32768 314 188 0.0 1.0 telnetd - 3442 pts/2 A 0:00 1 380 668 32768 202 240 0.0 1.0 -ksh 3810 pts/1 A 0:00 0 368 652 32768 202 240 0.0 1.0 -ksh 4410 - A 0:00 74 716 512 xx 55 40 0.0 0.0 /usr/lib/ 4924 - A 0:00 85 584 424 32768 37 12 0.0 0.0 /usr/sbin 5260 - A 0:27 115 592 528 32768 30 32 0.0 0.0 /usr/sbin 5448 - A 0:00 128 908 644 32768 32 36 0.0 1.0 /usr/sbin 5972 - A 0:21 182 572 376 32768 25 20 0.0 0.0 /usr/sbin 6192 - A 0:00 38 604 428 32768 25 16 0.0 0.0 /usr/sbin ... ... ▒▒ 중략 ▒▒ $ |
위와 같이 각각의 활성중인 프로세스에 대한 많은 통계 수치를 나열하여 볼 수 있다.
프로세스의 상태를 확인 하는 명령에는 이 외에도 smit 툴을 이용할 수도 있다. smit process 또는 smit monitors 명령을 입력하여 확인 해 볼 수 있다.
3-2-6. 프로세스 관련 유용한 명령어
▒▒ 프로세스의 초기 우선순위 설정 ▒▒
nice 명령으로 프로세스를 시작하여 프로세스의 초기 우선순위를 기본 시케줄링 우선순위 보다 낮은 값으로 설정 할 수 있다.
주: 높은 우선순위에서 프로세스를 수행하려면 사용자는 루트 사용자 권한을 갖고 있어야 한다. |
프로세스의 초기 우선순위를 설정하려면 다음과 같이 입력한다.
$nice -n Number CommandString
여기서, Number는 0에서 39까지의 범위이며, 39가 가장 낮은 우선순위이다. 번호가 클수록 우선 순위는 낮아진다. 0을 사용하면, 프로세스는 기본 스케줄링 우선순위에서 수행된다. CommandString은 사용자가 수행하려는 명령, 플래그 및 매개변수 이다.
이 명령은 smit nice 명령을 통해서도 가능하다.
▒▒ 수행중인 프로세스의 우선순위 변경 ▒▒
명령행에서 renice 명령을 사용하여, 수행 중인 프로세스의 스케줄링 우선순위를 기본 시케줄링 우선순위보다 높거나 낮은 값으로 변경할 수 있다. 이 명령이 프로세스의 nice 값을 변경한다.
note : 높은 우선순위에서 프로세스를 수행하거나 사용자가 시작하지 않은 프로세스의 우선순위를 변경하려면, 사용자는 루트 사용자 권한을 갖고 있어야 한다. |
수행중인 프로세스의 초기 우선 순위를 변경하려면, 다음과 같이 입력한다.
$renice Priority -p processID
여기서, Priority는 -20에서 20 까지의 범위의 수이다. 번호가 클수록 우선순위는 낮아진다. 0을 사용하면 프로세스는 기본 스케줄링 우선순위에서 수행된다. ProcessID는 사용자가 우선순위를 변경하려는 PID이다.
▒▒ 포어그라운드 프로세스 취소 ▒▒
사용자가 포어그라운드 프로세스를 시작한 다음에 포어 그라운드 프로세스를 완료시키지 않기로 결정하면, INTERRUPT를 눌러서 이를 취소할 수 있다. 일반적으로 Ctrl+C 또는 Ctrl+backspace 이다.
note : INTERRUPT(Ctrl+C)는 백그라운드 프로세스를 취소하지 않는다. 백그라운드 프로세스를 취소하려면 kill 명령을 사용해야 한다. |
대부분의 간단한 명령들은 사용자가 명령을 취소할 시간을 갖기 전에 너무 빨리 수행되어 종료되기 때문에, 프로세스를 취소할 방법을 설명하는데 있어 좋은 예가 되지 못한다. 따라서 이 절의 예에서는 수행 시간이 몇 초 이상 되는 find / -type f 명령을 사용할 것이다. 이 명령은 사용자 시스템에 있는 모든 파일의 경로 이름을 표시한다.
다음 예에서, find 명령은 프로세스를 시작한다. 프로세스를 수 초 동안 수행한 후, 사용자는 INTERRUPT 키를 눌러 프로세스를 취소할 수 있다.
$find / -type f /var/adm/ras/codepoint.cat /var/adm/ras/errtmplt /var/adm/ras/bootlog /var/adm/ras/devinst.log /var/adm/ras/bosinst.data /var/adm/ras/bosinstlog /var/adm/ras/BosMenus.log /var/adm/ras/image.data /var/adm/ras/conslog /var/adm/ras/errlog /var/adm/ras/diag_log ^C$ |
위의 예에서 ^C는 INTERRUP(Ctrl+C)를 의미한다.
▒▒ 포어그라운드 프로세스 정지 ▒▒
프로세스를 정지시클 수는 있지만 프로세스 테이블에서 제거된 프로세스 ID를 갖지는 못한다. 키보드에서 Ctrl+Z로 포어그라운드 프로세스를 정지할 수 있다.
note : Ctrl+Z는 Korn 쉘(ksh) 및 C 쉘(csh)에서는 작동하지만, Boune 쉘(bsh)에서는 작동하지 않는다. |
▒▒ 정지된 프로세스 재시작 ▒▒
사용자 시스템에 수행중이거나 정지되었지만 종료하지 않은 모든 프로세스를 표시하려면 "ps -ef"를 사용하여 가능하였다. 이 명령으로 사용자는 재시작하려는 프로세스를 찾고 프로세스 PID 번호를 확인해야 한다. 프로세스 PID를 확인 하였다면 다음 명령으로 CONTINUE 신호를 프로세스로 전송한다.
$kill -19 PIDNumber
이 명령은 백그라운드에서 프로세스를 재시작한다. 프로세스를 포어그라운드로 수행해야 할 경우 사용자는 다음 명령을 사용한다.
$fg PIDNumber
▒▒ 이후 조작을 위한 프로세스 스케줄 ▒▒
스케줄된 시간에 백그라운드에서 수행하려면 프로세스를 일괄처리 프로세스로 설정해야 한다. at 및 smit 명령을 통해 사용자는 나주에 수행될 명령 이름을 입력할 수 있고, 명령이 언제 수행될 지를 지정할 수 있다.
note : /var/adm/cron/at.allow 및 /var/adm/cron/at.deny 파일에서 사용자가 at 명령을 사용할 수 있는지 여부를 제어한다. 루트 사용자 권한이 있는 사용자가 이들 파일을 작성, 편집 또는 삭제할 수 있다. 이 파일의 입력사항은 로그인 이름이 한 행에 하나씩 있다. |
at.allow 파일이 있을 경우, 파일에 로그인 이름으로 표시된 사용자만이 at 명령을 사용할 수 있다. 시스템 관리자가 at.deny파일에 사용자의 로그인 이름을 나열하여 사용자의 at 명령 사용을 명시적으로 중지시킬 수 있다. at.deny 파일만 있을 경우, 이름이 파일에 나타나지 않는 사용자는 at 명령을 사용할 수 있다.
다음중 하나가 참이면 at 명령을 사용할 수 없다.
at.allow 파일이 없고 at.deny 파일은 없거나 공백인 경우, 루트 사용자 권한이 있는 사용자만 at 명령으로 작업을 실행 할 수 있다.
at 명령 구문을 통해 사용자는 프로세스를 수행하려는 날짜 문자열, 시간과 요일 문자열 또는 증분 문자열을 지정할 수 있다. 어떤 쉘이나 대기행렬을 사용할지 지정할 수도 있다.
자세한 구문은 명령어 사전을 찾아보기 바란다.
▒▒ 모든 스케줄된 프로세스 나열 ▒▒
at 명령의 -l 플래그나 atq 명령으로 스케줄된 모든 프로세스를 나열할 수 있다. 두 개의 명령이 동일한 출력을 제공하지만, atq명령은 at 명령이 실행되었던 시간순으로 프로세스를 나열할 수 있고 대기행렬에 있는 프로세스의 수만을 표시할 수 있다.
프롬프트에서 다음을 입력하여 확인 할 수 있다.
$at -l
이 명령은 사용자의 대기행령에 스케줄된 모든 프로세스를 나열한다. 사용자가 루트 사용자일 경우, 이 명령은 모든 사용자를 위해 스케줄된 모든 프로세스를 나열한다.
$atq
위 명령은 대기행렬에 스케줄된 모든 프로세스를 나열한다. 사용자가 루트 사용자일 경우, 사용자는 다음과 같이 입력하여 특정 사용자의 대기행렬에 스케줄된 프로세스를 나열 할 수 있다.
$atq UserName
대기 행렬에 스케줄된 프로세스의 수를 나열하려면 다음을 입력한다.
$atq -n
▒▒ 프로세스를 스케줄에서 제거 ▒▒
at 명령에서 -r 플래그를 사용하여, 스케줄된 프로세스를 제거할 수 있다. 명령행에서 스케줄된 프로세스를 제거하려면, 프로세스 번호를 알아야 한다. at -l 명령이나 atq 명령을 사용하여 프로세스 번호를 알 수 있다. 프로세스번호를 확인 하였으면 다음과 같이 실행한다.
$at -r ProcessNumber
이 작업은 smit rmat 명령을 통해서도 가능하다.
▒▒ 백그라운드 프로세스 제거 ▒▒
INTERRUPT가 사용자의 포어그라운드 프로세스를 정지시키지 못하거나 백그라운드 프로세스를 시작한 후에 프로세스를 완료하지 않기로 결정했을 경우, kill 명령으로 프로세스를 취소할 수 있다. kill 명령을 사용하여 프로세스를 취소하려면, 사용자가 PID 번호를 알아야 한다. 다음은 kill 명령의 일반 형식이다.
$kill ProcessID
note : 프로세스를 제거하려면, 사용자는 루트 사용자 권한이 있어야 하거나 프로세스를 시작한 사용자여야 한다. kill 명령에서 프로세스에 대한 디폴트 신호는 -15(SIGTERM)이다. |
3-3. SMIT (System Management Interface Tools)
3-3-1. SMIT 의 개요
SMIT는 시스템 관리 작업을 단순화 시키기 위해 고안된 대화식 인터페이스 프로그램으로, AIX에서는 SMIT를 통하여 대부분의 시스템 관리업무를 수행할 수 있다.
smit 명령은 다른 명령 수행에 사용할 수 있는 하나의 도구이다. smit 명령의 매개 변수로 명령 이름을 입력하면 해당 명령에 대한 서브 메뉴 또는 패널로 이동 된다. 예를 들어 smit lsuser를 입력하면 시스템에서 사용자의 속성을 나열하는 모든 사용자 리스트로 직접 이동한다.
SMIT는 메뉴를 계층적으로 표시한다. SMIT양식에서 정보를 입력하게 되면, SMIT는 그 정보를 이용하여 작업을 수행하기위한 명령파일을 작성한다. 여기서 사용된 명령들과 명령에 따라 display된 정보들은 로그파일로 남게 된다.
SMIT는 다음과 같은 장점을 가지고 있다.
*사용의 용이성 -- SMIT는 작성할 명령에 대한 해당정보를 신속하게 수집하기 위해 메뉴, 대화양식, 기능키 등을 사용한다.
*강력한 기능 -- SMIT에는 거의모든 시스템 관리작업을 수행할 수 있는 능력을 가지고 있다.
*기능키 --SMIT는 간단하면서 유연한 사용자 인터페이스를 사용한다.
3-3-2. SMIT의 사용 및 호출
SMIT를 사용하기 위해서는 프롬프트상에서 'smit'를 입력하기만 하면 된다. Xwindows 상에서 SMIT를 사용한다면 다음과 같은 두가지 모드로 사용 가능하다.
*프롬프트상에서 smit 입력 -- HFT(High Function Terminal)에서 Xwindow를 사용시에 마우스 클릭만으로 메뉴이동이 가능한 윈도우 모드를 사용한다.
*프롬프트상에서 smitty 입력 -- TTY 사용시나 HFT사용시에 같은 창에서 키보드 만으로 설정이 가능한 TEXT모드의 메뉴를 제공한다.
AIX4.3 버전에서 기본 메뉴는 다음과 같인 나타난다.
System Management
Move cursor to desired item and press Enter.
Software Installation and Maintenance Software License Management Devices System Storage Management (Physical & Logical Storage) Security & Users Communications Applications and Services Print Spooling Problem Determination Performance & Resource Scheduling System Environments Processes & Subsystems Applications Using SMIT (information only)
F1=Help F2=Refresh F3=Cancel F8=Image F9=Shell F10=Exit Enter=Do |
위와 같이 메뉴의 상단에는 top_menu가 자리한다. 그리고 아래 세부메뉴가 나온다. 맨아래 는 사용가능한 기능키들이 나오게 된다. 예를 들면 "F3"을 누르면 전 메뉴로 이동하고, "F10"을 누르면 위 화면에서 완전히 빠져나와 프롬프트 화면으로 나오게 된다. 자세한 도움말을 보고 싶다면 "F1"을 입력하면 된다.
- SMIT는 세부메뉴로 바로 갈 수 있는 FastPath를 지원하는데, 예를 들면 시스템백업메뉴로 바로 가고 싶다면 다음과 같이 입력하면 된다.
#smit mksysb or #smitty mksysb
- SMIT에서는 각 설정메뉴의 필드 마다 사용유형을 구분 해놓은 기호가 붙어 있는 경우가 있다. 각 기호의 의미는 다음과 같다.
[] |
괄호안에 입력할 수 있음. |
▒▒ , ▒▒ |
왼쪽이나 오른쪽에 내용이 더 있음. |
* |
값이 필요함. 필수 입력코드임. |
# |
숫자가 필요함. |
X |
16진 숫자가 필요함. |
/ |
파일명이나, 경로명이 필요함. |
+ |
옵션리스트가 있음. |
SMIT 메뉴중에는 옵션링(Option Ring)이라는 화면의 오른쪽에 다른 패널이 있는 경우가 있는데, 표시는 "+"로 나타나있다. 해당 항목에서 "F4"를 눌러 List를 열람하고, 선택할 수 있다. 필드값 변경은 "Tap" 키를 이용하여도 가능하다.
- SMIT에서 모든 명령의 실행은 "Enter" 키를 사용한다. 명령이 수행되고, 완료되면 화면의 좌측 상단 Command 부분에 "OK" 또는 "Failed" 라는 메시지가 떨어지게 된다.
3-3-3. SMIT로 작성된 파일
- smit.log
SMIT는 SMIT에서 행한 모든 것에 한 로그를 남긴다. 이 레코드의 파일명은 default로 smit.log 라는 이름을 갖지만, smit -l 옵션으로 파일명을 변경할 수 있다. 예를 들면 mysmit.log로 바꾸고 싶다면 다음과 같이 입력하면 된다.
#smit -l mysmit.log
SMIT 로그파일에는 다음과 같은 정보를 담고 있다.
*SMIT를 실행한 시간
*실행된 메뉴의 단축경로
*실제로 실행했는지 여부
*실행된 결과
▒▒ 그림 ▒▒실제 smit.log 파일 형식
[Feb 17 2003, 11:45:36] Starting SMIT
(Menu screen selected as FastPath, id = "top_menu", id_seq_num = "050", next_id = "commo", title = "Communications Applications and Services".)
(Menu screen selected, FastPath = "commo", id_seq_num = "050", next_id = "commo", title = "Communications Applications and Services".)
[Feb 17 2003, 11:45:38] Exiting SMIT
[Feb 17 2003, 12:26:57] Starting SMIT |
바로전에 언급한 SMIT 기능키중에는 F8=image 라는 것이 있다. 이는 지금 화면에 나온 그대로를 smit.log 파일에 그대로 옮겨 놓는 거와 같은 기능이다.
- smit.script
smit.script 파일은 smit가 수행한 실제 명령에대한 기록이다.레코드에는 다음과 같은 정보가 들어있다.
* 명령이 수행된 시간
* 모든옵션과 함께 수행된 실제 명령
smit.script파일에 실행 퍼미션을 주어 실행하게되면 실제 smit를 통한 명령과 똑같은 수행을 하게된다.
smit.log와 smit.script 파일은 각각 사용자의 홈 디렉토리에 위치해 있다.
3-3-4. SMIT의 작업
SMIT의 top_menu에서 각 항목의 기능은 다음과 같다.
* Software Installation and Maintenance --- 프로그램 제품 선택 설치, 소프트웨어 필수 파일 데이터 확인, 향후 설치를 위한 백업작업, 프로그램 제품 선택 화면표시, 이상 파일셋의 제거, 시스템 유지보수 모드 설정 등.
* Software License Management --- 시스템의 라이선스에 관한 설정 및 표시
* Devices --- 장치 추가 및 변경, 제거, 표시
* System Storage Management (Physical & Logical Storage) --- 저널된 파일시스템, CDROM 파일시스템과 페이징 스페이스를 추가 변경, 삭제,표시. 파일시스템의 마운트와 언마운트, 파일시스템의 백업 및 복구 와 검증, 네트워크 파일시스템(NFS)과 네트워크정보시스템(NIS)에 대한 작업, 논리적 볼륨의 관리.
* Security & Users --- 사용자와 그룹의 추가와 설정, 제거, 표시.
* Communications Applications and Services --- TCP/IP, NFS, SNA 등의 통신 적용 업무에 대한 구성과 관리 작업.
* Print Spooling --- 인쇄작업의 시작과 , 취소, 상태표시, 인쇄작업이외의 큐(queue)처리, 큐와 큐장치 등과 가상인쇄기 등을 포함하는 국지 인쇄기 부속시스템을 구성, 큐와 큐장치 가상인쇄기등을 포함하는 네트웤 인쇄기의 부속 시스템을 구성.
* Problem Determination --- 시스템 오류 로그의 분석, 추적 데몬(Daemon)의 시작과 정지 그리고 결과표시, 시스템 이상 분석, 시스템 하드웨어 진단 분석.
* Performance & Resource Scheduling --- 시스템 실행시간 레벨설정, 선택된 시스템 활동 보고서 표시, 일괄 처리 작업 대기행렬 넣기.
* System Environments --- 컴퓨터를 끄거나 잠시 중단, 시스템의 시간설정, 시스템 매개변수의 구성설정, 키보드와 사용자 언어 환경등의 구성설정.
* Processes & Subsystems --- 현재 실행중인 작업 확인과 작업정지, 서브시스템의 사용과 정지, 프로세스와 프로세서간의 바인드와 언 바인드 등.
* Applications --- SMIT를 이용하여 관리하고 싶은 어플리케이션의 추가.
* Using SMIT (information only) --- SMIT의 사용에 대한 상세한 도움말.
제 4 장 I/O redirect
4-1. 표준 입력, 표준 출력 및 표준 오류
명령이 수행을 시작할 때, 명령은 일반적으로 세 개의 파일이 표준 입력, 표준출력 및 표준 오류(종종 오류 출력이나 진단 출력으로 불린다)가 이미 열려있을 거라고 예상한다. 파일 설명자인 수는 이들 각각의 파일과 다음과 같이 연관된다.
파일설명자 0 -- ▒▒ 표준 입력
파일설명자 1 -- ▒▒ 표준 출력
파일설명자 2 -- ▒▒ 표준 오류(진단) 출력
서브 프로세스가 정상적으로 상위 프로세스에서 이들 파일을 상속한다. 세 개의 파일이 모두 워크스테이션(키보드에 0, 표시장치에 1과 2)에 최초로 지정된다. 제어가 명령에 전달되기 전에 쉘은 이 파일들이 어느 위치로든 재지정되도록 허용한다.
명령을 입력할 때 파일 이름을 지정하지 않으면, 키보드가 표준 입력이며, 때로 stdin 이라 선언된다. 명령이 종료되면 결과가 화면에 표시된다.
화면은 표준 출력이며, 때로 stdout 으로 선언된다. 기본으로 명령이 표준 입력에서 입력을 취하여 표준 출력으로 결과를 전송한다.
때로 stderr 이라 선언되는 표준 오류에 오류 메시지가 들어간다. 기본으로 표준 오류는 사용자의 화면이 된다.
이들 입출력의 조치는 변경할 수 있고, 파일을 입력으로 사용하고 명령의 결과를 파일에 기록하게 된다. 이를 I/O redirect 라 하며 이는 UNIX 운영시스템의 강력한 특징중의 하나이다.
터미널로 정상적으로 이동한 명령의 출력을 화면 대신 파일에 쉽게 재지정 할 수 있다. 이는 출력 재지정이라하고 이는 사용자가 화면에서 읽기 어려운 많은 양의 출력을 갖고 있을 때나 파일들을 종합하여 좀더 큰 파일로 만들고 싶을 때 유용하게 쓰인다.
출력 재지정 만큼 사용되ㅐ지 않더라도 정상적으로 키보드에서 행하는 명령에 대한 입력을 파일에도 가능하도록 재지정할 수도 있다. 이는 입력 방향 재지정이라고 한다. 입력 방향 재지정을 통해 사용자는 파일을 미리 준비하여 명령에서 그 파일을 읽도록 할 수 있다.
4-1-1. 표준 입출력 재지정
" ▒▒filename" 표기가 명령의 끝에 추가되면, 명령의 출력은 지정된 파일 이름에 기록된다. " ▒▒" 기호는 출력 재지정 연산자라고 한다.
▒▒ 출력을 파일로 재지정 ▒▒
예를 들어, who 명령의 결과를 users 라는 파일에 전송하려면 다음과 같이 입력한다.
$who ▒▒ users
note :파일 users가 이미 존재한다면, set 내장 Ksh(Korn 쉘) 또는 csh(C쉘) 명령의 noclobber 옵션을 지정하지 않으면 겹쳐 쓰여진다. |
users 파일의 내용을 보려면 다음과 같이 입력한다.
$cat users
▒▒ 출력 재지정 및 파일에 추가 ▒▒
" ▒▒ ▒▒ filename" 표기를 명령 끝에 추가하면, 명령의 출력이 기존 데이터 위에 쓰여지지 않고 지정된 파일 이름에 추가가 된다. " ▒▒ ▒▒" 기호를 추가 재지정 연산자라 한다.
예를 들어, file2를 file1에 추가하려면 다음과 같이 입력한다.
$cat file2 ▒▒ ▒▒ file1
주:파일 file1이 없으면, set 내장 ksh(Korn 쉘) 또는 csh(C 쉘) 명령의 noclobber 옵션을 지정하지 않는 한 파일은 새로 작성된다.
▒▒ 키보드에서 재지정하여 택스트 파일 작성 ▒▒
단독으로 사용될 경우, cat 명령은 키보드에서 입력한 대로 받아들인다. 이 입력을 파일에 재지정할 수도 있다. 이 경우 Ctrl + D를 입력하여 텍스트의 끝임을 신호한다.
$cat ▒▒ filename
file message or text
^D
▒▒ 텍스트 파일 병합 ▒▒
여러 파일을 연결하여 하나의 파일로 만드는 것을 병합이라고 한다.
예를 들어, 시스템 프롬프트에서 다음과 같이 입력한다.
$cat file1 file2 file3 ▒▒ file4
위의 예에서는 지정된 순서대로 추가된 file1, file2, 및 file3로 구성된 file4를 작성한다.
▒▒ 표준 입력 방향 재지정 ▒▒
▒▒ filename 표기가 명령의 끝에 추가될 때, 명령의 입력은 지정된 파일 이름에서 읽혀진다 ▒▒ 기호는 입력 방향 재지정 연산자이다.
note :정상적으로 키보드로부터 입력을 수용한 명령만이 입력을 재지정할 수 있다. |
예를 들어, mail 명령을 사용하여 사용자 user1에게 text1 파일을 메시지로 전송하려면 다음과 같이 입력한다
$mail user1 ▒▒ text1
▒▒ /dev/null 파일로 출력 폐기 ▒▒
/dev/null 파일은 특수파일이다. 이 파일은 고유한 특성을 갖고 있다. 즉 항상 비어있다. 사용자가 /dev/null로 전송한 데이터를 폐기하는 용도로 쓰이고 이 특징은 사용자가 무시하려는 출력을 작성하는 명령이나 프로그램을 수행할 때 매우 유용하다.
예를 들어, 사용자가 화면에서 입력을 승인한 myprog 프로그램이 있는데 이 프로그램에서 수행중에 무시할 만한 메시지를 생성하였다. myscript 파일에서 입력을 읽고 표준 출력 메시지를 폐기하려면 다음과 같이 입력한다.
$myprog ▒▒ myscript ▒▒ /dev/null
위의 예에서 myprog는 myscript 파일을 입력으로 사용하고 모든 표준 출력을 폐기한다.
4-1-3. 표준 오류 및 기타 출력 재지정
표준 입출력 외에도, 명령은 진단 출력으로 알려진 오류 메시지나 상태 메시지와 같은 기타 출력 유형을 작성한다. 표준 출력과 마찬가지로, 표준 오류 출력은 재지정되지 않을 경우에는 화면에 기록된다.
표준 오류나 기타 출력을 재지정하려면, 파일 설명자를 사용해야 한다. 파일 설명자가 표준 입력과 표준 출력 재지정에 지정될 수도 있지만 이미 디폴트 값이 있다.
파일 설명자란 명령이 처음에 사용한 각각의 I/O파일과 연관되어 있는 번호이다. 다음 번호가 표준 입력, 출력 및 오류와 연관이 있다.
0 표준입력(키보드)
1 표준출력(표시장치)
2 표준오류(표시장치)
표준 오류 출력을 재지정하기 위해 파일 설명자 번호 2를 출력 앞에 입력하거나 재지정 기호( ▒▒ 또는 ▒▒ ▒▒) 그리고 파일 이름을 기호 다음에 추가해야 한다. 예를들어, 다음 명령은 testfile.c 컴파일에 사용되는 cc 명령에서 표준 오류 출력을 읽어 Error 파일 끝에 추가하게 된다.
$cc testfile.c 2 ▒▒ ▒▒ Error
파일 설명자 0에서 9사이의 번호를 사용하여 다른 출력 유형을 재지정할 수도 있다. 예를 들어, cmd 명령이 출력을 파일 설명자 9에 기록하면, 다음과 같은 명령으로 그 출력을 savedata 파일로 재지정할 수 있다.
$cmd 9 ▒▒ savedata
명령이 하나 이상의 출력을 기록하면, 각각의 출력을 별도로 재지정할 수 있다. 명령이 표준 출력을 파일 설명자 1에 지정하며 표준 오류 출력은 파일 설명자2에 지정하고 데이터 파일은 파일 설명자9에서 구축한다고 가정한다. 다음의 명령행은 이들의 각각의 출력을 서로 다른 파일로 재지정한다.
$command ▒▒ standard 2 ▒▒ error 9 ▒▒ data
4-1-4. 인라인 입력 문서
명령의 양식은 다음과 같다.
$command ▒▒ ▒▒ eofstring
패턴 대응 문자를 포함하지 않은 임의의 문자열 eofstring에서, 쉘은 eofstring(하나 이상의 탭 문자 다음에 오는)으로만 이루어진 행을 읽을 때까지는 후속 행을 표준 입력으로 간주한다. 최초 eofstring과 두 번째 eofstring 사이의 행은 인라인 입력 또는 here 문서로 간주된다. 하이픈(-)이 ▒▒ ▒▒ 재지정 문자 바로 뒤에 있을 경우, 쉘은 명령에 행을 전달하기 전에 here 문서의 각 행에서 선행 탭 문자를 제거한다.
쉘이 문서를 포함하는 임의의 파일을 작성하고 파일을 명령에 전달하기 전의 내용으로 변수와 명령 대체를 수행 한다. 명령 대체에서 명령행의 일부인 파일 이름으로 패턴 대응을 수행한다. 모든 대체를 금지하려면, eofstring의 임의의 문자를 다음과 같이 인용해야 한다.
$command ▒▒ ▒▒ \eofstring
here 문서는 입력 데이터의 양이 적어서 별도의 파일에(예를 들어, 편집기 스크립트) 보관하기 보다는 쉘 프로시저에 두는 것이 더 편리한 경우에 데이터에 특히 유용하다. 예를 들어, 다음과 같이 입력할 수도 있다.
$cat ▒▒ ▒▒ - xyz
This message will be shown on the
display with leading tabs removed.
xyz
이 특징은 쉘 프로시저에 매우 유용하다.
4-1-5. 파이프 및 필터
UNIX를 통해 하나의 명령 표준 출력을 다른 명령의 표준 입력으로 사용하여 두 개 이상의 명령을 연결할 수 있다. 이런 방법으로 연결된 명령의 집합이 파이프라인이다. 명령을 결합하는 연결이 파이프이다. 파이프는 한가지 목적의 많은 명령들을 강력한 하나의 명령으로 결합할 수 있게 하는 UNIX의 중요한 또 한가지 기능이다.
파이프라인을 통해 하나의 명령에서 출력을 지정하여 다른 명령의 입력으로 사용할 수 있다. 명령은 파이프(|) 기호를 통해 연결된다.
필터란 명령이 다른 명령의 입력을 받아들인 다음 수정하여 입력의 결과를 표준 출력으로 전송하는 것이다. 필터는 단독으로 사용될 수 있지만 파이프라인 으로 사용하는 것이 매우 유용하다. 가장 일반적인 필터는 다음과 같다.
* sort
* more
* pg
예를 들어, sl 명령이 현재 디렉토리의 내용을 하나의 스크롤링 데이터 스트림의 화면에 기록한다. 하나 이상의 화면 정보가 표시될 때, 일부 데이터는 넘어가서 볼 수 없다. 출력을 제어해서 내용을 한 화면씩 화면에 표시하려면 파이프라인을 사용하여 ls명령의 출력을 pg 명령에 지정할 수 있고 이 명령은 다음 예에서 보여주는대로 화면의 출력 양식을 제어한다.
$ls |pg
이 예에서, ls 명령의 출력은 pg 명령의 입력으로 간주된다.
파이프라인은 한 방향으로만 조작된다.(왼쪽에서 오른쪽으로). 파이프라인에서 각각의 명령들은 별도의 프로세스로 수행되며 모든 프로세스는 동시에 수행된다. 읽을 입력이 없거나 다음 프로세스에 파이프가 가득차 있으면 프로세스는 일시 정지한다.
다음은 grep명령을 사용한 파이프의 또다른 예이다. grep이 특정한 패턴의 문자열을 포함하고 있는 행을 찾기 위해 파일을 탐색한다. 7월에 작성하였거나 수정한 모든 파일을 표시하려면, 다음과 같이 입력한다.
$ls -l |grep Jul
이 예에서, ls 명령의 출력은 grep 명령의 입력으로 간주된다.
4-2. 관련 명령어
4-2-1. 프로그램 출력을 표시 및 파일에 복사
파이프와 함께 사용된 tee 명령이 표준 입력을 읽은 다음에 프로그램의 출력을 표준 출력에 기록하며 동시에 이를 지정된 파일이나 파일들로 복사한다. 사용자는 출력을 즉시 열람할 수 있고 동시에 저장할 수 있다.
예를 들어, 동시에 명령으로부터 출력을 보고 저장하려면 다음과 같이 입력한다.
$ps -ef |tee program.ps
이렇게 하면, ps -ef 명령의 표준 출력을 워크스테이션에 표시함과 동시에 program.ps 파일에 표준 출력의 사본을 저장한다. program.ps 파일은 이미 있는데 내장 set 명령의 noclobber 옵션이 지정되어 있지 않으면, 파일은 삭제되고 대체 된다.
예를 들어, 명령의 출력을 열람하고 기존의 파일에 저장하려면, 다음과 같이 입력한다.
$ls -l |tee -a program.ls
이렇게 하면 ls -l 의 표준 출력이 워크스테이션에 표시됨과 동시에 program.ls 의 끝에 표준 출력의 사본이 추가된다. program.ls 파일은 없고 내장 set 명령의 noclobber 옵션이 지정되어 있지 않으면, 파일이 작성된다.
시스템은 다음과 같은 정보를 표시하며, program.ls 파일에 동일한 정보가 들어간다.
-rw-rw-rw- 1 jones staff 2301 Sep 19 08:53 161414
-rw-rw-rw- 1 jones staff 6317 Aug 31 13:17 def.rpt
-rw-rw-rw- 1 jones staff 5550 Sep 10 14:13 try.doc
tee 명령의 정확한 구문은 명령어 사전을 참고하면 된다.
4-2-2. 사용자의 화면 지움
clear 명령을 사용하여 메시지와 키보드 입력 화면을 비어있게 할 수 있다. 프롬프트에 다음과 같이 입력하면 된다.
$clear
위와 같이 실행하면 시스템이 화면을 지우고 프롬프트를 표시한다.
4-2-3. 메시지를 표준 출력으로 전송
echo 명령을 사용하여 메시지를 화면에 표시할 수 있다.
예를 들어, 표준 출력에 메시지를 기록하려면, 프롬프트에서 다음과 같이 입력한다.
$echo Message typing ...
위와 같이 입력한 후 Enter를 누르면 화면에 다음과 같이 표시된다.
Message typing ...
예를 들어, echo 명령과 함께 패턴 대응 문자를 사용하려면, 프롬프트에서 다음과 같이 입력한다.
$echo The back-up files are: *.bak
위와 같이 입력 후 Enter를 누르면 시스템은 .bak 으로 끝나는 현재 디렉토리에서 파일 이름 앞에 The back-up files are: 메시지를 표시한다.
echo 명령의 정확한 구문은 명령어 사전을 참고하기 바란다.
4-2-4. 텍스트의 한 행을 파일에 추가
추가 재지정 연산자와 함께 사용된 echo 명령으로 텍스트 한 행을 파일에 추가할 수 있다.
예를 들어, 프롬프트 상태에서 다음과 같이 입력한다.
$echo Remember to backup mail files by end of week. ▒▒ ▒▒ notes
위와 같이 실행 후 Enter를 누르면 위의 Remember to backup mail files by end of week. 메시지를 notes 파일의 끝에 추가한다.
4-2-5. 화면을 파일에 복사
VT100 터미널을 에뮬레이트하는 capture 명령을 사용하여 터미널에 인쇄된 모든 것을 사용자가 지정하는 파일에 복사할 수 있다.
VT100 터미널을 에뮬레이트 하지 않고, script 명령을 통해 터미널에 인쇄된 모든 것을 사용자가 지정한 파일로 복사할 수 있다.
두 개의 명령은 터미널 대화의 하드카피 레코드를 작성하는 데 유용하다.
예를 들어, VT100을 에뮬레이트 하는 동안 터미널의 화면을 캡처하려면 프롬프트에서 다음과 같이 입력한다.
$capture screen.01
Enter를 누르면 시스템은 다음과 유사한 정보를 표시할 것이다.
Capture command is started. The file is screen.01.
Use ^P to dump screen to file screen.01.
You are now emulating a vt100 terminal.
Press Any Key to continue.
데이터를 입력하고 화면 내용을 덤프한 후, Ctrl-D를 누르거나 exit를 입력한 다음 Enter 키를 눌러 capture 명령을 정지시면 시스템은 다음과 유사한 정보를 보여줄 것이다.
Capture command is complete. The file is screen.01.
You are NO LONGER emulating a vt100 terminal.
cat 명령을 사용하여 사용자의 파일 내용을 확인 하면 된다.
예를 들어, 터미널의 화면을 캡처하려면 프롬프트에서 다음과 같이 입력한다.
$script
시스템은 다음과 같은 정보를 표시할 것이다.
Script command is started. The file is typescript.
화면에 표시된 모든 것이 현재 typescript 파일로 복사 된다.
script 명령을 정지하려면, Ctrl-D를 누르거나 exit를 입력한 후 Enter를 누른다. 그러면 다음과 같은 정보를 표시할 것이다.
Script command is complete. The file is typescript.
cat 명령을 사용하여 사용자의 파일 내용을 확인 할 수 있다.
4-2-6. 큰 문자의 텍스트를 사용자 화면에 표시
banner 명령은 ASCII 문자를 큰 문자로 사용자의 화면에 표시한다. 출력의 각 행 길이는 대문자나 소문자 최대 10자이다.
예를 들어, 프롬프트 상에서 다음과 같이 입력한다.
$banner Hellow Guy!
Enter를 누르면 시스템에는 Hellow Guy! 가 큰 문자로 화면에 나올 것이다.
제 5 장 Filesystem and Directory
5-1. 파일 시스템
파일 시스템은 파일 및 디렉토리의 계층 구조(파일 트리)이다. 이 구조 유형은 맨 위에 루트가 있고, 밑에 가지가 있는 거꾸로 된 나무 모양이다. 이 파일 트리는 디렉토리를 사용하여 데이터와 프로그램을 그룹으로 편성하므로 많은 디렉토리와 파일을 한번에 관리할 수 있다.
일부 작업은 파일 시스템 내의 각 디렉토리에서 보다 파일 시스템 위에서 더욱 효과적으로 수행될 수도 있다. 예를 들어, 전체 파일 시스템을 백업, 이동 또는 보안 할 수 있다.
파일 시스템의 기본 유형을 저널 파일 시스템(JFS)이라 한다. 이런 파일 시스템은 구조적 일관성 유지를 위해 데이터베이스 저널링 기술을 사용한다. 이 저널링 기술 사용으로 파일 시스템이 비정상적으로 정지될 때 파일 시스템이 손상되는 것을 막아준다.
매우 중요한 일부 시스템 작업은 특별히 파일 시스템으로 작업해야 한다.
* 논리적 볼륨에 파일 시스템 영역 할당
* 파일 시스템 작성
* 시스템 사용자에게 사용 가능한 파일 시스템 영역 만들기
* 파일 시스템 영역 사용법 모니터
* 시스템 장애시 데이터 유실에 대비한 파일 시스템 백업
* 지속적인 상태로 파일 시스템 유지
이와같은 작업은 시스템 관리자가 수행하여야 한다.
5-1-1. 파일 시스템 유형
운영 시스템은 여러 파일 시스템 유형을 지원한다. 지원되는 유형은 다음과 같다.
*저널 파일 시스템 (JFS) - 기본 파일 시스템 유형으로, 파일 시스템 명령 전체 집합을 지원한다.
*네트워크 파일 시스템(NFS) - 원격 시스템에 있으면서 국지 시스템에 파일이 상주하는 것처럼 액세스하는 파일 시스템 유형
*CD-ROM 파일 시스템(CDRFS) - 정상 파일 시스템 인터페이스(열기, 읽기 및 닫기)를 통한 CD-ROM 내용 액세스를 허용하는 파일 시스템 유형
5-1-2. 파일 시스템 구조
독립형 시스템에서 다음의 파일 시스템은 기본으로 생성된다.
/dev/hd1 |
/home |
/dev/hd2 |
/usr |
/dev/hd3 |
/tmp |
/dev/hd4 |
/(root) |
/dev/hd9var |
/var |
파일 트리의 특성은 다음과 같다.
* 동일한 하드웨어 구조의 기계에서 공유할 수 있는 파일은 /usr 파일 시스템에 있다.
* 스풀 및 메일 파일과 같이 클라이언트 전용 변수 파일은 /var 파일 시스템에 있다.
* /(root) 파일 시스템에는 시스템 운용에 필요한 중요한 파일과 디렉토리가 있다. 예를 들어, 장치 디렉토리(/dev)나 /mnt와 같이 파일 시스템을 루트 파일 시스템에 마운트 할 수 있는 마운트 지점같은 것들이 있다.
* /home 파일 시스템은 사용자의 홈 디렉토리를 위한 마운트 지점이다.
* 서버의 경우, /export 디렉토리에는 페이징 공간 파일, 클라이언트 전용(공유되지 않는) 루트 파일 시스템, 덤프, 홈 및 디스켓이 없는 클라이언트용 /usr/share 디렉토리 뿐 아니라 반출된 /usr 디렉토리도 있다.
다음 리스트는 /(root) 파일 시스템의 하위 디렉토리의 일부 내용에 대한 정보이다.
/bin - /usr/bin 디렉토리에 대한 심볼 링크. 이전 UNIX 파일 시스템에서는, 사용자 명령이 /bin 디렉토리에 있었지만. 이 새로운 파일 구조에서는 /usr/bin에 있다.
/dev - 국지 장치를 위한 특수 파일용 장치 노드를 포함한다. /dev 디렉토리는 테이프 장치, 프린터, 디스크 보류 및 터미널에 대한 특수 파일을 포함한다.
/etc - 각 장치에 대한 다양한 구성 파일을 포함한다. /etc/hosts 파일이나 /etc/passwd 파일등이 있다. /etc 디렉토리에는 시스템 관리에 일반적으로 사용되는 파일이 있다. /etc 디렉토리에 상주했던 대부분의 명령이 이제는 /usr/sbin 디렉토리로 옮겨 왔지만 호환성을 위해 실행 파일의 새로운 위치에 대한 심볼 링크를 포함한다. 다음은 그 예이다.
(예: /etc/chown은 /usr/bin/chown에, /etc/exportvg는 /usr/sbin/exportvg에 대한 심볼 링크이다.)
/export - 원격 클라이언트에 대한 서버의 디렉토리 및 파일을 포함한다.
/home - 사용자 홈 디렉토리를 포함하는 파일 시스템에 대한 마운트 지점 역할을 한다. /home 파일 시스템은 각각의 사용자의 파일 및 디렉토리를 포함한다. 독립형 기계에서 별도의 국지 파일 시스템은 /home 디렉토리 위에 마운트 된다. 네트워크에서, 서버는 몇 개의 기계에서 액세스되어야 하는 사용자 파일을 포함할 수도 있다. 이런 경우, 서버의 /home 디렉토리 사본은 /home 파일 시스템에 원격적으로 마운트 된다.
/lib - 이름의 형식이 lib*.a 인 구조 독립형 라이브러리가 있는 /usr/lib 디렉토리에 대한 심볼 링크
/sbin - 시스템을 부트하고 /usr 파일 시스템을 마운트 할 때 필요한 파일이 있다. 부팅중에 사용되는 대부분의 명령은 부트 이미지 RAM 디스크 파일 시스템이기 때문에 /sbin 디렉토리에 상주하는 명령은 극소수이다.
/tmp - 시스템 작성 임시 파일을 포함하는 파일 시스템에 대한 마운트 지점 역할을 한다.
/u - /home 디렉토리에 대한 심볼 링크
/usr - 변경되지 않고 시스템에서 공유될 수 있는 파일 (실행 및 ASCII 문서)을 포함하는 파일 시스템을 위한 마운트 지점의 역할을 수행한다. 독립형 시스템은 별도의 국지 파일 시스템을 /usr 디렉토리 위에 마운트 시킨다. 디스크가 없거나 디스크가 적은 기계의 원격 서버의 디렉토리를 /usr 파일 시스템 위에 마운트 한다.
/var - 각각의 기계를 연결 변환하는 다양한 파일에 대한 마운트 지점 역할을 한다. 포함하고 있는 파일이 커지기 쉬운 파일이므로, /var 파일 시스템은 파일 시스템으로 구성된다. 예를들어, 임시 작업파일을 포함하는 /usr/tmp 디렉토리에 대한 심볼 링크이다.
5-1-3. 파일 시스템의 사용 가능한 영역 표시
df 명령은 파일 시스템의 총 공간 및 사용 가능 공간에 대한 정보를 표시한다. filesystem매개변수는 파일 시스템이 상주하는 장치 이름, 파일 시스템이 마운트된 디렉토리 또는 파일 시스템의 상대 경로 이름을 지정한다. filesystem 매개변수를 지정하지 않을 경우, df 명령은 현재 마운트된 모든 파일 시스템에 대한 정보를 표시한다. 파일 또는 디렉토리가 지정될 경우, df 명령은 현재 마운트된 모든 파일 시스템애 대한 정보를 표시한다. 파일 또는 디렉토리가 지정될 경우, df 명령은 해당 파일이나 디렉토리가 상주하고 있는 파일 시스템에 대한 정보를 표시한다.
보통 df 명령은 수퍼 블록에 있는 프리 카운트를 사용한다. 특정 예외 조건 아래에서는, 이런 카운트에 오류가 발생할 수 있다. 예를 들어, df 명령이 수행되는 동안 파일 시스템이 수정되는 중이라면, 프리 카운트가 정확하지 않을 수 있다.
note: 네트워크 파일시스템(NFS)과 같은 원격 파일 시스템은 서버가 정보를 제공하지 않으면 열이 공백으로 나올 때도 있다. 예를 들어, 마우늩된 모든 파일 시스템에 대한 정보를 표시하려면, 다음과 같이 입력한다. $df /, /usr, /site 및 /usr/venus 디렉토리가 별도의 파일 시스템에 상주하도록 시스템이 구성설정된 경우, df 명령의 출력은 다음과 같다. $df Filesystem 512-blocks Free %Used Iused %Iused Mounted on /dev/hd4 98304 67440 32% 1576 7% / /dev/hd2 3522560 53160 99% 61452 14% /usr /dev/hd9var 16384 10648 36% 860 42% /var /dev/hd3 49152 44584 10% 96 2% /tmp /dev/hd1 16384 8272 50% 107 6% /home
예를 들어, 현재 디렉토리가 상주하는 파일 시스템의 사용 가능 공간을 표시하려면, 다음과 같이 입력한다. $df . |
5-2. 디렉토리
디렉토리는 파일 또는 다른 디렉토리에 액세스할 때 필요한 정보만을 포함하는 하나의 독특한 파일 유형이다. 결과적으로 디렉토리는 파일의 다른 유형보다 적은 공간을 차지한다. 또한 파일 시스템 구조를 우연성 있고 깊이있게 만든다. 디렉토리를 사용하여 파일 및 다른 디렉토리를 그룹화할 수 있고, 파일 시스템을 모듈 방식의 계층에 편성할 수 있다. 다른 파일 유형과는 달리, 디렉토리를 제어하는 특수한 명령 세트가 있다.
디렉토리에는 디렉토리 항목이 있다. 각 항목에는 파일 또는 서브 디렉토리 이름 및 색인 노드 참조 번호(i-node number)가 있다. 디스크 공간 사용의 속도를 높이고 향상시키기 위해, 파일의 데이터는 컴퓨터 메모리의 다양한 위치에 저장된다. i-node 번호에는 파일과 관련된 데이터의 모든 분산된 블록을 찾을 때 사용하는 주소가 있다. 또한 i-node 번호는 수정 및 액세스 시간, 액세스 모드, 링크 수, 파일 소유자 및 파일 유형 등 기타 파일 정보를 기록한다. ln 명령으로 디렉토리 항목을 작성하여 한 파일의 여러 이름을 동일한 i-node 번호에 링크할 수 있다.
디렉토리가 시스템의 모든 사용자가 사용할 수 없는 정보를 포함할 때도 많기 때문에, 디렉토리 액세스는 보호 될 수 있다. 디렉토리의 사용권한을 설정하여 디렉토리에 대한 액세스 제어를 할 수 있고, 또한 사용자가 있다면 그들로 하여금 디렉토리의 정보를 변경할 수 있게 할 것인지를 결정할 수 있다.
5-2-1. 디렉토리 유형
디렉토리는 운영 시스템, 시스템 관리자 또는 사용자가 정의할 수 있다. 시스템 정의 디렉토리는 명령과 같은 시스템 고유의 파일을 포함한다. 파일 시스템 계층의 최상위에는 시스템 정의 /(root) 디렉토리가 있다. / 디렉토리에는 항상 다음과 같은 표준 시스템 관련 디렉토리를 포함한다.
*/dev - I/O 장치를 위한 특수 파일이 들어 있다.
*/etc - 시스템 초기화 및 시스템 관리를 위한 파일이 들어 있다.
*/home - 시스템 사용자를 위한 로그인 디렉토리가 들어 있다.
*/tmp - 임시 파일 및 지정된 날짜가 지나면 삭제될 수 있는 파일이 들어 있다.
*/usr - lpp, include 및 다른 시스템 디렉토리가 있다.
*/usr/bin - 사용자 실행 가능 프로그램이 들어 있다.
로그인 또는 홈 디렉토리($HOME)와 같은 디렉토리는 시스템 관리자에 의해 정의되고 조정된다. 운영 시스템에 로그인할 때는 로그인 디렉토리가 현재 디렉토리가 된다. 사용자가 작성한 디렉토리는 사용자 정의 디렉토리라고 한다. 이러한 디렉토리를 이용하면 파일 편성 및 유지 보수에 도움이 된다.
5-2-2. 디렉토리 작성
디렉토리에는 파일, 하위 디렉토리 또는 파일과 하위 디렉토리의 조합이 들어 있을 수 있다. 하위 디렉토리는 디렉토리 내에 있는 디렉토리 이다. 하위 디렉토리를 포함하는 디렉토리가 상위 디렉토리이다.
디렉토리를 추적 및 찾는 운영 시스템에서, 각각의 디렉토리는 작성된 상위 디렉토리에 대한 항목인 .. 및 디렉토리 그 자체에 대한 항목인 . 을 갖는다. 대부분의 디렉토리 나열에서 이러한 파일은 숨겨져 있다.
▒▒ 디렉토리 트리 ▒▒
상위 디렉토리, 하위 디렉토리 및 파일의 구조를 파일 시스템이라고 한다. 디렉토리 구조는 역 트리에 비유 될 대가 많다. /(슬래쉬) 기호로 표시되는 루트 디렉토리는 디렉토리 트리의 기준이며 최상위에 있다 하위 디렉토리 및 파일은 루트 디렉토리 아래로 분기된다.
디렉토리의 파일 시스템 구조는 복잡해지기 쉽다. 파일 및 디렉토리 구조를 가능한 한 단순하게 유지하는 것과 파일 및 디렉토리를 인식하기 쉬운 이름으로 만드는 것은 수월한 작업을 위해 권장되는 사항이다.
▒▒ 상위 디렉토리 ▒▒
/(root)를 제외한 각 디렉토리에는 한 개의 상위 디렉토리가 있고 하나 이상의 하위 디렉토리가 있을 수 있다.
▒▒ 홈 디렉토리 ▒▒
로그인 하면, 시스템은 사용자를 홈 디렉토리 또는 로그인 디렉토리에 위치시킨다. 홈디렉토리는 시스템 관리자가 각각의 사용자에 대해 설치한다. 홈 디렉토리는 개인용 파일을 보관하는 곳이다. 보통 사용자 자신을 위해 만든 디렉토리는 홈 디렉토리의 하위 디렉토리가 된다. 언제든지 홈 디렉토리로 돌아가려면 프롬프트에서 cd 명령을 입력한 후 Enter를 누르면 된다.
▒▒ 작업 디렉토리 ▒▒
사용자는 항상 한 다렉토리 안에서 작업하게 된다. 현재 작업중인 다렉토리를 현재 또는 작업 디렉토리라 한다. pwd(작업 디렉토리 표시) 명령은 사용자의 작업 디렉토리 이름을 알려준다. cd 명령으로 작업 디렉토리를 변경할 수 있다.
5-2-3. 디렉토리 명명 규약
각 디렉토리 이름은 저장되어 있는 디렉토리 내에서 고유해야 한다. 이름이 고유해야 또한 디렉토리가 파일 시스템에서 고유한 경로 이름을 가지고 있음을 보장할 수 있다. 또한 디렉토리는 파일 명명규약에 설명된 파일과 같은 명명 규약을 따른다.
5-2-4. 디렉토리 경로 이름
각 파일 및 디렉토리는 파일 시스템 트리 구조 전반에 걸쳐 경로 이름이라고 하는 고유한 경로에 의해 이를 수 있다. 경로 이름은 파일 시스템 내에서 디렉토리 또는 파일의 위치를 지정한다.
note : 경로 이름은 1023문자를 초과할 수 없다. 파일 시스템은 두 가지 유형의 경로 이름을 사용한다. 절대 경로 이름 : /(root) 디렉토리에서부터 경로를 추적한다. 절대 경로 이름은 항상 /(슬래쉬) 기호로 시작한다. 상대 경로 이름 : 현재 디렉토리에서 상위 또는 하위 디렉토리 또는 파일에 걸쳐 경로를 추적한다. |
절대 경로 이름은 /(root) 디렉토리에서부터 아래 방향으로 디렉토리 또는 파일의 완전한 이름을 말한다. 파일 시스템 어디에서 작업하든지 해당 절대 경로 이름을 지정하여 파일 또는 디렉토리를 찾을 수 있다. 절대 경로 이름은 루트를 표시하는 /(슬래쉬)로 시작한다. 경로 이름 /A/D/9는 9의 절대 경로 이름이다. 최초 /(슬래쉬)는 탐색의 시작 위치인 /(root) 디렉토리를 표시한다. 경로 이름의 나머지는 A, 그 다음 D, 마지막으로 9의 탐색을 지시한다.
9라는 이름의 파일 두 개가 있을 때 이는 파일에 대한 절대 경로 이름이 파일 시스템 내에서 고유한 이름을 파일에 지정하기 때문에 가능하다. 경로 이름 /A/D/9 및 /C/E/G/9는 9라는 고유한 두 파일을 지정한다.
전체 경로 이름과는 달리 상대 경로 이름은 현재의 작업 디렉토리를 기준으로 해서 디렉토리 또는 파일을 지정한다. 상대 경로 이름의 경우, .. 표기법을 사용하여 파일 시스템 계층의 위쪽으로 이동할 수 있다. 이 표시(..)는 상위 디렉토리를 나타낸다. 상대 경로 이름은 현재 디렉토리에서 시작 경로를 지정하므로 /(슬래쉬)로 시작하지 않는다. 상대 경로 이름은 현재 디렉토리의 파일 또는 파일 시스템의 현재 디렉토리의 위 또는 아래 레벨의 파일 또는 디렉토리의 경로 이름을 지정할 때 사용된다. D가 현재 디렉토리일 경우, 10에 액세스하기 위한 상대 경로 이름은 F/10 이지만, 절대 경로 이름은 항상 /A/D/F/10 이다. 또한 3을 액세스하기 위한 상대 경로 이름은 ../../B/3 이다.
또한 . 표기법을 사용하여 현재 디렉토리의 이름을 나타낼 수 있다. 점(.) 표기법은 보통 현재 디렉토리 이름을 읽는 프로그램을 수행할 때 사용된다.
5-2-5. 디렉토리 약어
약어는 특정 디렉토리 지정에 빠르고 편리한 방법을 제공한다. 다음은 약어 리스트 이다.
. |
현재 작업 디렉토리 |
.. |
현재 작업 디렉토리의 상위 디렉토리 |
~ |
홈 디렉토리(bourn 쉘에는 적용안됨) |
$HOME |
홈 디렉토리 |
5-3. 디렉토리 처리 프로시저
디렉토리와 그 내용을 가지고 작업하는 데에는 다양한 방법이 있다.
5-3-1. 디렉토리 작성
mkdir 명령은 디렉토리 매개변수에 의해 지정된 한 개 이상의 새로운 디렉토리를 작성한다. 각각의 새로운 디렉토리에는 표준 입력항목 . 및 .. 이 포함된다. 새로운 디렉토리에 대한 사용권한을 -m Mode 플래그로 지정할 수 있다.
새로운 디렉토리가 실행되는 경우, 파일 시스템의 다른 위치에 절대 경로 이름을 지정하지 않는 한 현재 또는 작업 디렉토리 내에 작성된다.
예를 들어, 현재 작업 디렉토리에 기본 사용권한을 갖는 Test라는 새로운 디렉토리를 작성하려면, 다음과 같이 입력한다.
$mkdir Test
예를 들어, rwxr-xr-x 사용권한이 있는 Test 라는 새로운 디렉토리를 이전에 작성된 /home/demo/sub1 디렉토리에 작성하려면, 다음을 입력한다.
$mkdir -m 755 /home/demo/sub1/Test
예를 들어, 기본 사용권한이 있는 Test 라는 새로운 디렉토리를 /home/demo/sub2 디렉토리에 작성하려면, 다음과 같이 입력한 후 Enter를 누른다.
$mkdir -p /home/demo/sub2/Test
-p 플래그는 /home, /home/demo 및 /home/demo/sub2 디렉토리가 기존에 없다면 작성한다.
5-3-2. 디렉토리 이동 또는 재명명
mvdir 명령은 디렉토리를 이동 또는 재명명한다.
예를 들어, 디렉토리를 이동하려면 다음과같이 입력한 후 Enter를 누른다.
$mvdir book manual
이 경우 manual 이라는 디렉토리가 존재한다면 book 디렉토리가 manual 디렉토리 아래로 이동한다. 또는 book 디렉토리가 manual 로 재 명명 될 수도 있다. 예를 들어 디렉토리를 이동하여 재명명 하려면, 다음과 같이 입력한다.
$mvdir book3 proj4/manual
위와 같이 실행하면 book3는 proj4라는 디렉토리로 이동되고 이름이 manual 로 다시 지정된다.(manual이 존재하지 않을 경우)
5-3-3. 현재 디렉토리 표시
pwd 명령은 표준 출력에 /(root) 디렉토리로부터 현재 디렉토리의 표준 전체 경로이름을 쓴다. 모든 디렉토리는 /(슬래쉬)로 분리된다. /(root) 디렉토리는 첫 번째 /(슬래쉬) 로 표현되며, 명명된 최종 디렉토리는 현재 디렉토리가 된다.
예를 들어, 현재 디렉토리를 표시하려면, 다음과 같이 입력한 후 Enter를 누른다.
$pwd
다음과 유사한 현재 디렉토리의 전체 경로 이름이 표시된다.
/home/User1
5-3-4. 다른 디렉토리로 변경
cd 명령은 현재의 디렉토리에서 다른 디렉토리로 이동시켜 준다. 사용자는 지정된 디렉토리의 실행(탐색) 사용권한을 가지고 있어야 한다.
Directory 매개변수를 지정하지 않은 경우, cd 명령을 사용하면 로그인 디렉토리로 이동한다.(ksh 및 bsh 환경에서는 $HOME 또는 csh 환경에서는 $home). 디렉토리 이름을 전체 경로 이름으로 지정한 경우, 이 디렉토리 이름이 현재 디렉토리가 된다. 전체 경로 이름은 /(root) 디렉토리를 가리키는 /(슬래쉬), 현재 디렉토리를 가리키는 . 과 상위 디렉토리를 가리키는 .. 으로 시작한다. 디렉토리 이름이 전체 경로 이름이 아닐 경우, cd 명령은 $CDPATH 쉘 변수(또는 $cdpath csh 변수)에 의해 지정된 경로 중 하나에 관련된 경로를 탐색 한다. 이 변수는 $PATH 쉘 변수(또는 $path csh 변수)와 동일한 구문 및 유사한 의미를 갖는다. 예를들어, 홈 디렉토리로 변경하려면, 다음을 입력한 후 Enter를 친다.
$cd
예를 들어, /usr/include 디렉토리로 변경하려면, 다음을 입력한다.
$cd /usr/include
위와 같이 실행하면 현재 디렉토리에서 /usr/include로 작업 디렉토리 위치가 변경된다.
현재 디렉토리에서 한 레벨 아래의 sys 디렉토리로 내려가려면 다음과 같이 입력하면 된다.
$cd sys
위와 같이 실행하면 현재 디렉토리가 /usr/include이고 이 디렉토리에 sys라는 하위 디렉토리가 있을 경우, /usr/include/sys가 현재 디렉토리가 된다.
디렉토리 트리에서 한 레벨 위로 가려면, 다음과 같이 입력한다.
$cd ..
특수 파일 이름 ( .. )은 현재 디렉토리 바로 위의 디렉토리 즉, 상위 디렉토리를 말한다.
5-3-5. 디렉토리 복사
cp 또는 copy명령은 SourceFile 또는 SourceDirectory 매개변수에 지정된 파일이나 디렉토리의 목차 사본을 TargetFile 또는 TargetDirectory 매개변수로 지정된 파일이나 디렉토리에 작성한다. TargetFile로 지정된 파일이 존재할 경우, 사본은 파일의 원래 내용 위에 겹쳐쓴다. 두 개 이상의 SourceFile을 복사하려면, 목표는 디렉토리이어야 한다.
SourceFile의 사본을 디렉토리에 두려면, 기존 디렉토리의 경로를 TargetDirctory 매개변수에 지정한다. 경로 끝에 새로운 파일 이름을 지정하지 않는한, 파일은 디렉토리에 복사되어도 각자의 이름을 유지한다. 또한 cp 명령은 -r또는 -R 플래그를 지정할 경우 전체 디렉토리를 다른 디렉토리에 복사한다.
디렉토리내에 있는 모든 파일을 새로운 디렉토리에 복사하기 위해서는 다음과 같이 실행한다.
$cp /home/janet/clients/* /home/nic/customers
위에서는 clients 디렉토리에 있는 파일들이 customers 디렉토리에 복사된다.
모든 파일 및 하위 디렉토리를 포함하여 하나의 디렉토리를 다른 디렉토리에 복사하려면 다음과 같이 입력한다.
$cp -R /home/nick/clients /home/nic/customers
그러면 모든 파일, 하위 디렉토리 및 하위 디렉토리의 파일을 포함하여 clients 디렉토리가 customers 디렉토리 아래에 복사된다.
5-3-6. 디렉토리 내용 표시
ls 명령을 사용하여 디렉토리의 내용을 표시할 수 있다.
▒▒ ls 명령 ▒▒
ls명령은 플래그로 요청한 정보와 함께 지정된 디렉토리 내용 및 지정된 파일의 이름을 표준 출력에 쓴다. 파일 또는 디렉토리를 지정하지 않을 경우, ls 명령은 현재 디렉토리의 내용을 표시한다. 디폴트로. ls 명령은 파일 이름의 알파벳 순으로 모든 정보를 표시한다. 루트 권한이 있는 사용자가 명령을 실행할 경우, 디폴트로 -A 플래그를 사용하여 . 과 ..을 제외한 모든 항목이 나열된다. 점(.)으로 시작하는 파일을 포함하여 파일에 대한 모든 항목을 표시하려면, ls -a 명령을 사용한다.
다음은 출력의 형식을 정하는 세가지 주요 방법이다.
* -l 플래그를 사용하여 행당 한 항목을 나열한다.
* -C 또는 -x 플래그를 지정하여 여러 열에 항목을 나열한다. -C 플래그는 tty로 출력될 때 디폴트 형식이다.
* -m 플래그를 지정하여 쉼표로 분리되게 항목을 나열한다.
출력 행에서 문자 위치 수를 결정하기 위해 ls 명령은 $COLUMNS 환경 변수를 사용한다. 이 변수를 설정하지 않으면, 명령은 terminfo 파일을 읽는다. 이 두가지 방법으로도 ls 명령이 문자 위치 수를 결정할 수 없을 경우 디폴트 값 80을 사용한다.
-e와 -l 플래그로 표시된 정보중 최초 문자(퍼미션의 맨 앞문자)가 의미하는 바는 다음과 같다.
d |
디렉토리. |
b |
블록 특수 파일. |
c |
문자 특수 파일. |
l |
심볼 링크 파일. |
p |
선입선출(FIFO) 파이프 특수 파일. |
s |
국지 소켓 |
- |
보통 파일. |
다음 9개 문자는 각각 3 문자로 분류된 3개의 집합으로 나누어진다. 최초 3개의 문자는 소유자의 사용권한을 나타낸다. 다음의 3개 문자는 소유 그룹에 대한 사용권한이다. 마지막 3개의 문자 집합은 파일에 액세스할 수 있는 기타 다른 사용자의 사용권한이다. 각 집합의 3개의 문자는 해당 파일에 대한 읽기, 쓰기 및 실행 권한을 표시한다. 디렉토리의 실행 사용권한으로 사용자는 지정된 파일에 대해 디렉토리를 탐색할 수 있다.
각각의 사용권한의 문자 표시는 다음가같이 표시한다.
r |
읽기 권한 부여 |
t |
다른 사용자들이 디렉토리에 대한 쓰기 권한이 있더라도 디렉토리 소유자 또는 파일 소유자만이 해당 디렉토리 내의 파일을 삭제 또는 재명명할 수 있음. |
w |
쓰기(편집) 권한 부여. |
x |
실행(탐색) 권한 부여. |
- |
상응하는 권한이 부여되지 않음. |
-e 플래그로 표시된 정보는 추가된 11번째 문자가 다음과 같이 해석되는 것을 제외하고는 -l 플래그와 같다.
+ |
파일이 확장된 보안 정보를 가지고 있음을 가리킨다. 예를 들어, 파일이 모드에서 ACL, TCB 또는 TP 속성을 확장했을 수 있다. |
- |
파일이 확장된 보안 정보를 가지지 않음을 가리킨다. |
디렉토리의 파일 크기가 나열될 때, ls 명령은 간접 블록을 포함한 블록의 전체 계수를 나열한다. 예를 들어, 현재 디렉토리의 모든 파일을 나열하려면 다음을 입력한다.
$ls -a
이는 . 와 .. 그리고 . 으로 시작 또는 시작하지 않는 기타 파일 등을 나열한다.
5-3-7. 디렉토리 삭제 또는 제거
rmdir 명령은 시스템에서부터 directory 매개변수에 의해 지정된 디렉토리를 제거한다. 디렉토리를 제거하려면 비어 있어야 하고( . 및 .. 만 포함), 상위 디렉토리에 대해 쓰기 사용권한이 있어야 한다. ls -a Directory 명령을 사용하여 디렉토리가 비었는지 미리 검사해야 한다.
디렉토리를 비우고 제거하려면 다음과 같이 입력한다.
$rm mydir/* mydir/.*
$rmdir mydir
이는 mydir 의 내용을 제거한 후, 빈 디렉토리를 제거한다. rm 명령은 디렉토리 . 과 .. 제거 시도에 대한 오류 메시지를 표시하고, rmdir 명령이 이들과 디렉토리 자체를 제거한다.
rmmydir/* mydir/.* 은 먼저 점으로 시작하지 않는 이름을 가진 파일을 제거한 후, 점으로 시작하는 이름을 가진 파일을 제거함을 주의해야 한다. ls 명령은 -a 플래그를 지정하지 않으면, 보통 점으로 시작하는 파일들을 나열하지 않기 때문에 점으로 시작하는 파일 이름이 디렉토리에 있다는 것을 인식하지 못할 수 있다.
예를 들어, /tmp/jones/demo/mydir 디렉토리 구조와 그 아래의 모든 디렉토리들을 제거하려면, 다음을 입력하라.
$cd /tmp
$rmdir -p jones/demo/mydir
이는 /tmp 디렉토리로부터 jones/demo/mydir 디렉토리를 제거한다. 디렉토리가 비어있지 않거나 그 디렉토리에 쓰기 권한이 없다면, 제거될 때 적절한 오류 메시지와 함께 명령이 종료 된다.
5-3-8. 디렉토리 내용 비교
dircmp 명령은 Directory1 과 Directory2 매개변수로 지정된 두 디렉토리를 비교하고 그 내용에 대한 정보를 표준 출력으로 쓴다. 우선 , dircmp명령은 각각의 디렉토리에 있는 파일 이름들을 비교한다. 같은 파일 이름이 양쪽에 나타나면, dircmp 명령은 두 파일의 내용을 비교한다.
출력에서, dircmp 명령은 각 디렉토리에 고유한 파일을 나열한다. 그런 다음 양쪽 디렉토리에서 이름은 같고 내용은 다른 파일을 나열한다. 플래그가 지정되지 않은 경우, 양쪽 디렉토리에서 이름과 내용이 같은 파일을 나열한다.
예를 들어, proj.ver1 과 proj.ver2 디렉토리의 파일들 간의 차이점을 요약하려면, 다음을 입력한다.
$dircmp proj.ver1 proj.ver2
그러면 proj.ver1 과 proj.ver2 디렉토리 사이의 차이점이 요약되어 표시된다. 한 디렉토리, 다른 디렉토리, 양쪽 디렉토리에 있는 파일들을 별도로 나열한다. 양쪽 디렉토리에 있는 파일이 발견될 경우, dircmp 명령은 두 개의 사본이 일치하는지 기록해 둔다.
예를 들어, proj.ver1 과 proj.ver2 디렉토리 사이의 차이점의 세부사항을 표시하려면 다음을 입력한다.
$dircmp -d -s proj.ver1 proj.ver2
-s 플래그는 일치하는 파일에 관한 정보를 보이지 않게 한다. -d 플래그는 양쪽 디렉토리에서 발견된 파일을 비교하여 구별해 놓은 diff 리스팅을 보여준다.
제 6 장 File
파일은 운영 시스템에서 정보를 입/출력할 때 사용된다. 소프트웨어 및 하드웨어 모두에 대한 액세스를 표준에 맞춘다. 파일 내용이 변경되거나 쓰여지면 입력이다. 파일 내용이 읽혀지거나 또는 다른 파일로 전송되면 출력이다. 예를들어, 파일을 하드 카피로 출력하기 위해, 시스템은 텍스트 파일에서 정보를 읽고, 읽은 정보를 프린터 표시 파일에 작성한다.
6-1. 파일 유형
파일의 기본 유형에는 다음과 같은 세 가지가 있다.
* 정규파일 - 데이터(텍스트, 2진 및 실행가능한)를 저장한다.
* 디렉토리 - 다른 파일 및 액세스에 사용되는 정보를 포함한다.
* 특수파일 - FIFO(선입선출) 파이프 파일 또는 물리적 장치를 정의한다.
파일 시스템에서 인식하는 파일 유형은 이 세가지 중 하나에 해당한다. 그런, 운영 시스템은 이 기본 유형을 변형하여 사용한다.
▒▒ 정규 파일 ▒▒
정규 파일이 가장 흔한 파일이다. 정규 파일의 다른 이름은 보통 파일이다. 정규 파일은 데이터를 저장한다.
▒▒ 텍스트 파일 ▒▒
텍스트 파일은 사용자가 읽을 수 있는 정보를 포함하는 정규 파일이다. 이 정보는 ASCII로 저장된다. 이런 텍스트 파일을 표시 및 인쇄할 수 있다. 텍스트 파일의 행에는 NUL 문자가 있으면 안되며, 개행 문자(NL)를 포함하여 길이가 {LINE_MAX} 바이트를 초과할 수 없다.
텍스트 파일 항은 제어 또는 인쇄 불가능(NUL이외) 문자가 포함되는 것을 막을 수 없다. 그러므로, 텍스트 파일을 입력 또는 출력으로서 나열하는 표준 유틸리티는 특수 문자를 원할히 처리할 수 있거나 이러한 한계에 대해 명시적으로 각각의 섹션에서 설명한다.
▒▒ 2진 파일 ▒▒
2진 파일은 컴퓨터가 읽을 수 있는 정보를 포함하는 정규 파일이다. 2진 파일은 시스템에 작업 완료를 지시하는 실행 파일이 될 수도 있다. 명령 및 프로그램이 실행가능 즉 2진 파일에 저장된다. 특수 컴파일 프로그램은 ASCII텍스트를 2진 코드로 변환한다.
텍스트 파일과 2진 파일 사이의 유일한 차이점은 텍스트 파일에는 {LINE_MAX}바이트 미만의 행이 있고 NUL 문자는 없으며, 각각의 개행 문자로 종료 된다는 점이다.
▒▒ 디렉토리 파일 ▒▒
디렉토리 파일은 모든 유형의 파일에 액세스하기 위해 시스템에서 필요로 하는 정보를 포함하지만, 실제 파일 데이터가 들어 있는 것은 아니다. 그러므로, 디렉토리는 정규 파일보다 적은 공간을 차지하고, 파일 시스템 구조를 더욱 유연성 있고 깊이 있게 만들어 준다. 각 디렉토리 항목은 파일 또는 하위 디렉토리를 나타낸다. 각 항목에는 파일 이름 및 파일의 색인 노드 참조 번호(i-node 번호)가 있다. i-node 번호는 파일에 지정된 고유 색인 노드를 가리킨다. i-node 번호는 파일과 연관된 데이터의 위치를설명한다. 디렉토리는 별도의 명령 집합에 의해 작성 및 제어된다.
▒▒ 특수 파일 ▒▒
특수 파일은 프로세스에 의해 작성된 시스템 또는 임시 파일에 대한 장치를 규정한다. 특수 파일에는 FIFO(선입선출법), 블록 및 문자 등의 세 개의 기본 유형이 있다. FIFO 파일을 파이프라고도 한다. 파이프는 다른 프로세스와의 통신을 임시로 허용하기 위해 한 프로세스에 의해 작성된다. 이런 파일은 최초 프로세스가 끝나면 사라진다. 블록 및 문자 파일이 장치를 정의한다.
모든 파일은 파일의 읽기, 변경 또는 실행할 수 있는 사용권한의 집합(액세스 모드라고 함)을 갖는다.
6-1-1. 파일 명명 규약
파일 이름은 저장되어 있는 디렉토리 내에서 고유해야 한다. 파일이 파일 시스템에서 고유한 경로 이름을 가지고 있음을 보장한다. 파일 명명 지침은 다음과 같다.
* 파일 이름은 최대 255까지 가능하며, 문자, 숫자 및 밑줄이 포함될 수 있다.
* 운영 시스템은 대소문자를 구분한다. 즉, 파일 이름에서 대문자와 소문자를 구별한다. 따라서 FILEA, fileA와 Filea는 같은 디렉토리에 있더라도 서로 다른 세 개의 파일이다.
* 파일 이름은 가능한 설명적이고 의미가 있어야 한다.
* 디렉토리는 파일과 동일한 명명 규약을 따른다.
* 특정 문자는 운영 시스템에 특별한 의미를 가지므로, 파일 이름을 정할 때 피해야 한다. 이러한 문자에는 다음과 같은 것들이 있다. ( / \ " ' * ; - ? [ ] ( ) ~ ! $ { } ▒▒ ▒▒ # @ & | )
* 파일 이름이 . 으로 시작되면 보통의 디렉토리 리스트에서는 보이지 않는다. ls 명령을 -a 플래그와 함께 사용하면, 숨겨진 파일이 정규 파일 및 디렉토리와 함께 나열된다.
6-1-2. 파일 경로 이름
파일 시스템의 각 파일과 디렉토리에 대한 경로 이름은 트리 구조에서 해당 경로 앞에 나오는 모든 드렉토리 이름으로 이루어진다.
파일 시스템의 모든 경로가 /(root) 디렉토리에서 비롯하므로, 파일 시스템의 각 파일에는 절대 경로 이름이라 하는 루트 디렉토리와의 고유한 관계가 있다. 절대 경로 이름은 /(슬래쉬) 기호로 시작한다. 예를 들어 어떤 파일 시스템안에 h 라는 파일은 /B/C/h 라는 절대 경로 이름을 가질 수 있다. 이런 파일 들은 절대경로인 /B/h와 /B/C/h 가 서로 다르므로, 시스템 안에서 h 라느 파일은 각기 고유한 이름을 갖는다. 경로 이름은 마지막 구성요소를 제외하고 디렉토리만 구성된다.경로 이름의 마지막 구성요소는 파일 이름이다.
또한 파일 경로 이름은 1023 문자를 초과할 수 없다.
6-1-3. 와일드 카드 문자 및 메타 문자를 사용한 패턴 대응
와일드 카드를 사용하면 한 문자로 여러 개의 파일을 편리하게 지정할 수 있다. 두 와일드 카드 문자는 별표(*)와 물음표(?)이다. 메타 문자로는 좌우 대괄호([]), 하이픈(-) 및 느낌표(!) 가 있다.
▒▒ * 와일드 카드 ▒▒
일련 또는 단일 문자를 대응하는데 *를 사용한다. * 는 문자가 없는 경우를 포함하여 모든 문자를 의미한다. 예를 들어, 디렉토리에 test1, test2, test3, file1, file2, file3, file4, afile1, afile2 등의 파일이 있을 때, file로 시작하는 파일만을 참조하려면 file*을 사용하면 된다.
▒▒ ? 와일드 카드 ▒▒
하나의 문자에 대응하려면 ?를 사용한다. ?는 단일 문자를 의미한다. 예를 들어 file?을 입력하면 이에 대응하는 file1 file2 file3 ...등이 선택된다. file로 시작하고 두 문자로 끝나는 파일만 참조하려면 file?? 과 같이 사용하면 file10 file11 ... 등이 선택된다.
▒▒ [] 쉘 메타 문자 ▒▒
메타 문자는 원하는 단어를 [ ] 에 넣는 또다른 유형의 총칭 문자 표기법을 사용한다. ? 의 사용과 비슷하지만, 이 문자는 대응에 특정 문자를 선택할 수 있다. 또한 []에서 하이픈(-)을 사용하여 값의 범위를 지정할 수 ㅇ도 있다. 모든 알파벳을 지정하려면, [[:alpha:]]를 사용한다. 모든 알파벳 소문자를 지정하려면, [[:lower:]]를 사용한다.
1이나 2로 끝나는 파일만 참조하려면 다음과 같이 입력한다.
*file[12]
위와 같이 실행하면 aaafile1, afile2, bbfile1, file2 .. 등과 같이 1이나 2로 끝나는 파일만 선택된다. 또한 숫자로 시작하는 파일만을 참조할 수 있는데 [0123456789]* 또는 [0-9]*를 사용하면 된다.
a로 시작되지 않는 파일만을 참조하려면, [!a]*를 사용한다.
6-1-4. 패턴 대응 대 정규식
정규식에서는 문자열 집합에서 특정 문자열을 선택하는 것이 가능하다. 정규식의 사용은 일반적으로 텍스트 처리와 연관이 있다.
정규식은 가능한 문자열을 광범위하게 표현할 수 있다. 많은 정규식이 현재 로케일에 따라 다르게 해석되기 때문에, 국제화 기능은 로케일 전반에 걸쳐 문맥상 불변성을 제공한다.
다음은 파일 대응 패턴 및 정규식을 비교한 예이다.
Pattern Matching |
Regular Expression |
* |
.* |
? |
. |
[!a] |
[^a] |
[abc] |
[abc] |
[[:alpha:]] |
[[:alpha:]] |
6-2. 파일 처리 프로시저
시스템에서 파일 작업을 하는 데에는 많은 방법이 있다. 보통 문서 편집기로 텍스트 파일을 작성할 수 있다. UNIX 환경에서는 vi 및 ed편집기를 가장 많이 사용한다. 또한 운영 시스템에는 자체 문서 편집기 인 INed도 있다. 사용 가능한 문서 편집기가 여러 개 잇으므로, 사용하기 편한 편집기로 편집하면 된다.
파일을 작성하거나 수정한 후, 파일의 서로 다른 버전을 구분하거나 같은 파일에 서로 다른 이름을 지정하기 위해 파일을 한 디렉토리에서 다른 디렉토리로 복사하거나 이동해야 할 수 있다. 또한 다른 프로젝트에 대해 작업할 때는 새로운 디렉토리를 작성해야 할 수도 있다. 또한 특정 파일을 삭제해야 할 수도 있고, 디렉토리에 이전 또는 필요없는 정보를 포함한 파일이 있으면 혼란스러워지기 쉽기 때문에 필요없는 파일을 삭제하여 시스템에서 기억장치 영역의 빈 공간을 늘려주어야 한다.
6-2-1. 파일 삭제
더 이상 필요하지 않은 파일은 rm 명령으로 제거할 수 있다. rm 명령은 파일을 제거하기 전에 사용자 확인을 요청하지 않는다. rm을 사용하여 파일 그룹을 삭제하거나 리스트에서 삭제할 파일을 선택할 수 있다.
rm 명령은 디렉토리에서 지정된 파일의 항목을 제거한다. 제거하고자 하는 파일에 대한 읽기 또는 쓰기 사용권한은 필요하지 않는다. 그러나, 파일을 포함하는 디렉토리에 대한 쓰기 권한은 가지고 있어야 한다.
예를 들어, myfile 파일을 삭제하려면 다음과 같이 입력한다.
$rm myfile
또한 mydir 디렉토리에서 모든 파일을 하나씩 제거하려면 다음과 같이 입력한다.
$rm -i mydir/*
위의 명령을 실행 한 후, 각 파일 이름이 표시되고 삭제하기 위해서는 y를 입력한 후 Enter를 누르면 된다. 보존하기 위해서는 그냥 Enter를 누른다.
6-2-2. 파일 이동 및 재명명
mv 명령은 하나의 디렉토리에서 다른 디렉토리로 파일 및 디렉토리를 이동하거나 파일 또는 디렉토리를 재명명한다. 새로운 이름을 지정하지 않고 새로운 디렉토리로 파일 또는 디렉토리를 이동할 경우, 원래 이름을 유지한다.
note : mv 명령은 -i 플래그를 지정하지 않으면 기존 파일을 겹쳐 쓸 수 있다. -i 플래그는 파일에 겹쳐 쓰기하기 전에 확인할 것을 프롬프트 한다. -f 플래그는 프롬프트를 표시하지 않는다.. -f와 -i 플래그 그 둘을 함께 지정할 경우, 지정된 마지막 플래그가 유효한다. |
예를 들어, 다른 디렉토리로 파일을 이동한 후 새로운 이름을 지정하려면 다음과 같이 입력한다.
$mv intro manual/chap1
위와 같이 하면 intro가 manual/chap1로 이동한다. intro라는 이름은 현재 디렉토리에서 제거되고, 같은 파일이 manual 디렉토리에 chap1로 나타난다.
예를 들어, 같은 이름으로 파일을 다른 디렉토리로 이동하려면 다음과 같이 입력한다.
$mv chap3 manual
또한 파일의 이름을 재명명 할 수 있는데, 예를 들어 test1.a를 test로 바꾸려면 다음과 같이 실행한다.
$mv test1.a test
위에서 test라는 파일이 이미 있다면 이전 내용은 test1.a의 내용으로 대체된다.
6-2-3. 파일 복사
cp 또는 copy 명령은 SourceFile 또는 SourceDrectory 매개변수로 지정된 파일이나 디렉토리의 내용 사본을 TargetFile또는 TargetDirectory 매개변수로 지정된 파일이나 디렉토리에 작성한다. TargetFile로 지정된 파일이 존재할 경우, 경고없이 사본은 파일의 원래 내용 위에 겹쳐쓴다. 두 개 이상의 SourceFile을 복사하고 있을 경우 목표는 한 개의 디렉토리이어야 한다.
새로운 대상에 같은 이름을 갖는 파일이 존재할 경우 복사된 파일은 새로운 대상의 파일 위에 겹쳐쓴다. 그러므로, 같은 이름의 파일이 대상 디렉토리에 존재하지 않도록 파일의 사본에 새로운 이름을 지정하는 것이 바람직하다.
디렉토리에 SourceFile의 사본을 넣으려면, TargetDirectory 매개변수에 기존 디렉토리 경로를 지정한다. 경로 끝에 새로운 파일 이름을 지정하지 않는한, 파일은 디렉토리에 복사되어도 각자의 이름을 유지한다. 또한 -r 또는 -R 플래그를 지정한 경우 cp 명령은 전체 디렉토리를 다른 디렉토리로 복사한다. 특수 장치 파일도 복사할 수 있다. 이 복사에 선호되는 옵션은 -R 플래그이다. -R을 지정하면 특수 파일이 새로운 경로 이름 아래에 다시 생성된다. -r 플래그를 지정하여 cp 명령이 특수 파일을 정규 파일에 복사하도록 할 수도 있다.
예를 들어, prog.c를 prog.bak 으로 복사하려면 다음과 같이 입력한다. 이때, prog.bak 파일이 이미 존재할 경우 prog.bak 파일의 내용은 prog.c 파일의 사본으로 대체된다.
$cp prog.c prog.bak
또한 현재 디렉토리(/home/mydir)의 모든 파일을 다른 디렉토리(home/eibm/testdir)로 복사하려면 다음과 같이 입력한다.
$cp /home/mydir/* /home/eibm/testdir
디렉토리 내의 특정 파일(test1, test2, jones, lewis)을 다른 디렉토리(/home/eibm)로 복사 하려면 다음과 같이 입력한다.
$cp test1 test2 jones lewis /home/eibm
파일 복사에 패턴 대응 문자를 사용할 수도 있다.
$cp programs/*.c .
위의 예에서는 programs 디렉토리에서 .c로 끝나는 파일이 .(점)으로 표시되는 현재 디렉토리로 복사된다. c와 마지막 점 사이에 빈칸을 입력한다.
6-2-4. 파일 찾기
find 명령은 지정된 path가 있는지 디렉토리 트리를 반복적으로 탐색하고 다음 텍스트에서 지정된 항목을 조건을 사용하여 작성된 부울식과 일치하는 파일을 찾는다. find 명령의 출력은 Expression 매개변수에 의해 지정된 조건에 따라 결정된다.
예를 들어, 파일 시스템에서 .profile 이라는 이름을 가진 모든 파일을 나열하려면 다음과 같이 입력한다.
$find / -name .profile
전체 파일 시스템을 탐색하여 .profile에 언급된 모든 파일의 완전 경로 이름을 쓴다. /(슬래쉬)는 find 명령에 /(root) 디렉토리와 그 모든 서브 디렉토리를 탐색하도록 지시한다. 시간을 절약하려면, 파일이 있을 거라 생각되는 디렉토리를 지정하여 탐색을 제한 하는 것이 좋다.
예를 들어, 현재 디렉토리 트리에서 0600의 특정 사용권한 코드를 갖는 파일을 나열하려면 다음과 같이 입력한다.
$find . -perm 0600
그러면 오직 소유자의 읽기 및 소유자 쓰기 사용권한을 갖는 파일 이름이 나열된다. 점(.)은 find 명령에 현재 디렉토리 및 그 서브 디렉토리를 탐색하도록 지시한다. 사용권한 코드에 대한 설명은 chmod 명령을 참조한다.
예를 들어, 어떤 사용권한 코드를 갖는 파일이 있는지 디렉토리를 탐색하려면, 다음과 같이 입력한다.
$find manual clients proposals -perm -0600
그러면 소유자 읽기 및 소유자 쓰기 사용권한 및 가능한 기타 사용권한을 갖는 파일 이름이 나열된다. manual, clients 및 proposals 디렉토리와 서브 디렉토리가 탐색된다. 위의 예에서, -perm 0600은 0600에 정확히 일치하는 사용권한 코드를 갖는 파일만 탐색하였다. 그 다음 예에서의 -perm -0600은 0600에 의해 지정된 액세스 사용권한 코드를 갖는 파일 및 0600 이상의 레벨을 갖는 파일을 선택한다. 이는 또한 0622 과 2744 등도 탐색됨을 의미한다.
위의 예 이외에도 다음과 같은 형식으로 찾을 수 있다.
$find . -ctime 0
$find . -type f -links +1
위의 예중 -ctime 0 은 현재로부터 24시간전의 기간동안 변경되었던 모든 파일을 나열한다. 아래는 두 개 이상의 링크(-links +1)를 갖는 보통 파일 (-type f)의 이름을 나열한다.
note: 모든 디렉토리에 최소한 두 개의 링있다. 상위 디렉토리에 있는 입력항목과 자신의 . 입력 항목이 그것들이다. |
SCCS 디렉토리에서 이름이 SCCS인 디렉토리 또는 파일을 제외하고 현재 디렉토리 또는 그 아래에 있는 모든 파일의 경로 이름을 인쇄하려면 다음과 같이 입력한다.
$find . -name SCCS -prune
길이가 정확히 414 바이트인 모든 파일을 탐색하려면 다음과 같이 입력한다.
$find . -size 414c
6-2-5. 파일 유형 표시
file 명령은 File 또는 -f FileList 매개변수로 지정된 파일을 읽고, 각 파일에 대해 일련의 테스트를 수행하여 파일을 유형별로 분류한다. 그런다음, 명령은 표준 출력에 파일 유형을 쓴다.
파일이 ASCII로 나타날 경우, file 명령은 처음의 512 바이트를 검사하고 사용 언어를 결정한다. 파일이 ASCII가 아닐 경우, file 명령은 2진 데이터 파일 또는 확장 문자를 포함한 텍스트 파일인지 결정하기 위해 좀더 시도해야 한다.
File 매개변수가 실행 또는 오브젝트 모듈 파일을 지정하고 버전 번호가 0보다 클 경우, file 명령은 버전 스템프를 표시한다. file 명령이 /etc/magic 파일을 사용하여 파일종유 설명자(magic number)를 가진 파일인지 즉, 유형을 나타내는 수치 똔는 문자열 상수를 포함하는 파일인지 식별한다.
예를 들어, myfile 이라는 파일에 포함된 정보 유형을 표시하려면 다음과 같이 입력한다.
$file myfile
위와 같이 실행하면 myfile의 파일 유형(예:디렉토리, 데이터, ASCII 텍스트, C 프로그램 소스 및 아카이브)를 표시한다. 파일 이름 리스트가 있는 filename.lst 의 각 파일 유형을 표시하려면 다음과 같이 입력한다.
$file -f filenames.lst
현재 디렉토리의 모든 파일 이름이 포함되도록 filenames.lst 파일을 작성하여 편집을 원한다면 다음과 같이 입력한 후 편집하면 된다.
$ls ▒▒ filenames.lst
6-2-6. 파일 내용 표시
pg, more 및 page 명령을 사용하면 파일의 내용을 열람하고 파일이 표시되는 속도를 제어할 수 있다. 또한 cat 명령을 사용하여 화면에 한 개 이상의 파일 내용을 표시할 수도 있다. pg 명령과 cat 명령을 조합하여 한 번에 한 화면씩 파일 내용을 읽을 수 있다. 또한 입출력 방향 재지정을 사용하여 파일의 내용을 표시할 수 있다.
▒▒ pg 명령 ▒▒
pg 명령은 File 매개변수의 파일 이름을 읽어 한 번에 한 화면씩 표준 출력에 쓴다. 하이픈(-)을 File 매개변수로 지정하거나 옵션없이 pg 명령을 수행할 경우, pg 명령은 표준 입력을 읽는다. 각각 화면에는 프롬프트가 나온다. Enter키를 누르면, 다른 화면이 표시된다. pg 명령과 함께 부속 명령이 사용되면 이미 전달했던 것을 검토할 수 있다.
예를 들어, 한번에 한 페이지씩 myfile 파일 내용을 보려면 다음과 같이 입력한다.
$pg myfile
▒▒ more 또는 page 명령 ▒▒
more 또는 page 명령은 한 번에 한 화면씩 연속 텍스트를 표시한다. 한 화면 다음에 멈추고, 화면 하단의 파일 이름 및 완료 퍼센트(예: myfile(7%))를 인쇄한다. 그런다음 Enter를 누를 경우, more 명령은 추가 행을 표시한다. 스페이스 바를누를 경우, more 명령은 다른 텍스트 화면을 표시한다.
note : 일부 터미널 모델상에서는 다음 데이터 화면을 표시하기 전에 more 명령이 스크롤링 대신 화면을 지운다 |
예를들어, myfile 파일을 보려면 다음과 같이 입력한다.
$more myfile
▒▒ cat 명령 ▒▒
cat 명령은 순서대로 각 File 매개변수를 읽고 표준 출력에 쓴다.
예를 들어, notes 파일의 내용을 표시하려면 다음과 같이 입력한다.
$cat notes
파일이 24행 보다 길 경우, 파일의 일부는 화면에서 스크롤된다. 한 번에 한 페이지씩 파일을 나열하려면, pg 명령을 사용한다.
여러개의 파일 notes, notes2, notes3 등의 파일 내용을 표시하려고 할 때 다음과 같이 실행하면 된다.
$cat notes notes2 notes3
6-2-7. 텍스트 파일에서 문자열 찾기
grep 명령은 Pattern 매개변수에 의해 지정된 패턴을 찾고, 일치 행을 표준 출력에 쓴다.
예를 들어, pgm.s 파일에서 패턴 대응문자 *, ^ , ?, [, ], (, \), \{, \} 가 있는 패턴을 탐색하려면 다음과 같이 입력한다.
$grep "^[a-zA-Z]" pgm.s
위의 예에서는 한 개의 문자로 시작하는 pgm.s의 모든 행이 표시된다.
sort.c 파일에서 패턴에 대응되지 않는 모든 행을 표시하려면 다음과 같이 입력한다.
$grep -v bubble sort.c
ls 명령 출력에서 staff 문자열과 일치하는 행을 표시하려면 다음과 같이 입력한다.
$ls -l |grep staff
6-2-8. 텍스트 파일 분류
sort 명령은 File 매개변수에 의해 지정된 파일의 행을 알파벳 또는 순차적으로 분류하고 그 결과를 표준 출력에 쓴다. File 매개변수가 두 개 이상의 파일을 지정할 경우, sort 명령은 파일들을 한 개의 파일로 병합하고 알파벳순으로 만든다.
note : sort 명령은 대소문자를 구별하고 대문자가 소문자 앞에 오도록 한다. |
예를 들면 파일 names 의 내용이 다음과 같다고 하자.
marta
denise
joyce
endrica
melanie
또한 파일 states 의 내용이 다음과 같다고 할 때,
texas
colorado
ohio
위에서, names 파일의 내용을 분류하여 표시하려면 다음과 같이 입력한다.
$sort names
그러면 다음과 유사한 정보를 표시한다.
denise
endrica
joyce
marta
melanie
두 파일 names 와 states 의 내용을 분휴하여 표시하려면 다음과 같이 입력한다.
$sort names states
그러면 시스템은 다음과 유사한 정보를 표시한다.
colorado
denise
endrica
joyce
marta
melanie
ohio
texas
names 파일이ㅡ 원래 내용응ㄹ 분류된 내용으로 대체하려면 다음과 같이 입력한다.
$sort -o names names
6-2-9. 파일 비교
diff 명령은 텍스트 파일을 비교한다. 단일 파일 또는 디렉토리의 내용을 비교할 수 있다.
diff 명령을 정규 파일에서 수행하고 서로 다른 디렉토리의 텍스트 파일을 비교할 때, diff 명령은 그 파일을 일치시키려면 파일에서 어떤 행을 변경해야 하는지 알려준다.
예를 들어, 두 파일(chap1.bak 과 chap1)을 비교하려면 다음과 같이 입력한다. 이는 chap1.bak과 chap1 파일 사이의 차이점이 표시된다.
$diff chap1.bak chap1
예를 들어, 공백 문자 양의 차이를 무시하고 두 파일을 비교하려면 다음과 같이 입력한다.
$diff -w prog.c.bak prog.c
위의 예에서 두 행이 단어 사이의 빈칸 및 탭의 수에서만 다를 경우, diff -w 명령은 이 두 행을 동일하게 인식한다.
6-2-10. 파일에서 단어, 행 및 바이트 계수확인
디폴트에 의해, wc 명령은 File 매개변수에 의해 지정된 파일의 행, 단어 및 바이트 수를 계산한다. File 매개변수에 대해 파일이 지정되지 않은 경우, 표준 입력이 사용된다. 이 명령은 표준 출력에 결과를 쓰고 명명된 모든 파일의 총 수를 센다. 플래그가 지정될 경우, 플래그의 순서는 출력의 순서를 결정한다. word는 공백, 탭 또는 개행 문자로 분리된 한 문자열로 정의된다.
파일이 명령행에 지정되면, 파일의 이름이 계수와 함께 인쇄된다.
예를 들어, chap1 파일의 행, 단어 및 바이트 계수를 표시하려면 다음과 같이 입력한다.
$wc chap1
다시 바이트와 단어 계수만을 표시하려면 다음과 같이 입력한다.
$wc -cw chap*
이는 이름이 chap 로 시작되는 파일의 행 및 단어의 수를 표시하고 총 수를 표시한다.
6-2-11. 파일의 최초 행 표시
head 명령은 지정된 파일 또는 표준 입력의 처음 몇 행을 표준 출력에 쓴다. 플래그가 head 명령과 함게 지정되지 않을 경우, 처음 10행이 디폴트로 표시된다.
예를 들어, Test 파일의 첫 5행을 표시하려면 다음과 같이 입력한다.
$head -5 Test
6-2-12. 파일의 마지막 행 표시
tail 명령은 File 매개변수에 의해 지정된 파일을 지정된 지점부터 표준 출력에 쓴다.
예를 들어, notes 파일의 마지막 10행을 표시하려면 다음과 같이 입력한다.
$tail notes
notes 파일의 끝에서부터 읽기를 시작할 행의 수를 지정하려면 다음과 같이 입력한다.
$tail -20 notes
notes 파일을 200 번째 바이트에서 시작하여 한 번에 한 페이지씩 표시하려면 다음과 같이 입력한다.
$tail -c +200 notes |pg
accounts 파일의 크기가 늘어나는 것을 보려면 다음과 같이 입력한다.
$tail -f accounts
위와 같이 실행하면 accounts 파일의 마지막 10행이 표시된다. tail 명령은 accounts 파일에 행이 추가되면 계속해서 표시한다. 키(Ctrl-C)를 눌러 정지시킬 때까지 표시가 계속된다.
6-2-13. 텍스트 파일의 영역 자르기
cut 명령은 파일의 행에서부터 선택된 바이트, 문자 또는 필드를 표준 출력에 쓴다.
예를 들어, 파일의 각 행의 몇 개의 필드를 표시하려면, 다음과 같이 입력한다.
$cut -f1,5 -d: /etc/passwd
그러면 시스템 암호 파일에 대한 로그인 이름 및 전체 사용자 이름이 표시된다. 이는 콜론으로 분리된(-d) 최최 및 5번째 필드(-f1,5)이다.
예를 들어, /etc/passwd 파일이 다음과 같다.
su:*:0:0:User with special privileges:/:/usr/bin/sh
daemon:*:1:1::/etc:
bin:*:2:2::/usr/bin:
sys:*:3:3::/usr/src:
adm:*:4:4:System Administrator:/var/adm:/usr/bin/sh
pierre:*:200:200:Pierre Harper:/home/pierre:/usr/bin/sh
joan:*:202:200:Joan Brown:/home/joan:/usr/bin/sh
위의 예에서 cut 명령은 다음의 결과를 만든다.
su:User with special privileges
daemon:
bin:
sys:
adm:system Administrator
pierre:Pierre Harper
joan:Joan Brown
6-2-14. 텍스트 파일 영역 붙이기
paste 명령은 최대 12개 파일의 행을 한 파일로 병합한다.
예를 들어, 다음과 같은 텍스트를 포함하는 names라는 파일이 있다.
rache1
jerry
mark
linda
scott
places라는 파일은 다음과 같은 텍스트를 포함하고 있다.
New York
Austin
Chicago
Boca Raton
Seattle
그리고 dates 라는 파일은 다음과 같은 텍스트를 포함하고 있다.
February 5
March 13
June 21
July 16
November 4
names, places 및 dates 파일의 텍스트를 함께 붙이려면 다음과 같이 입력하면 된다.
$paste names places dates ▒▒ npd
위와 같이 실행 하게되면 한 열에는 names 파일의 데이터가, 다른 열에는 places 파일의 데이터가, 세 번째 열에는 dates 파일의 데이터가 들어가는 npd 파일이 작성된다. npd 파일에는 다음과 같은 데이터가 들어 있을 것이다.
reche1 New York February 5
jerry Austin March 13
mark Chicago June 21
linda Boca Raton July 16
scott Seattle November 4
탭 문자가 각 행이 이름, 장소 및 데이터를 분리한다. 탭 정지가 8열마다 한 번씩 설정되기 때문에 열이 항상 끝까지 가지는 않는다.
예를 들어, 탭 이외의 문자로 열을 분리하려면 다음과 같이 입력한다.
$paste -d"!@" names places dates ▒▒ npd
이것은 열 분리자를 ! 및 @로 대체한다. names, places 및 dates 파일이 위의 예에서와 같은 내용이라면 npd 파일의 내용은 다음과 같을 것이다.
rache1!New York@February 5
jerry!Austin@March 13
mark!Chicago@June 21
linda!Boca Raton@July 16
scott!Seattle@November 4
현재 디렉토리를 4개의 열로 나열하려면 다음과 같이 입력한다.
$ls |paste - - - -
각 하이픈(-)은 paste 명령에 표준 입력에서 읽은 데이터가 포함된 열을 작성하도록 지시한다. 첫 행은 첫 번째 열에, 두 번째 행은 두 번째 열에, 이런 식으로 들어간다.
6-2-15. 텍스트 파일에 행 번호 붙이기
nl 명령은 지정된 파일을 읽고(디폴트에 의해 표준 입력으로), 입력에서 행에 번호를 붙이고 표준 출력에 번호를 붙인 행을 쓴다.
예를 들어, 공백이 아닌 행에만 번호를 붙이려면 다음과 같이 입력한다.
$nl chap1
그러면 본문의 공백이 아닌 행에만 번호를 붙인 chap1의 번호 붙은 리스팅이 표시된다.
예를 들어, 모든 행에 번호를 붙이려면, 다음과 같이 입력한다.
$nl -ba chap1
그러면 chap1 파일의 공백 행을 포함한 모든 행에 번호가 붙는다.
6-2-16. 텍스트 파일에서 열 삭제
colrm 명령은 파일에서 지정한 열을 제거한다. 표준입력에 의한 입력이다. 출력은 표준 출력으로 보내진다.
하나의 매개변수와 함께 호출될 경우, 각 행에서 지정된 열에서부터 마지막 열까지가 제거된다. 두 개의 매개 변수와 함께 호출될 경우, 첫 번째 지정된 열에서부터 두 번째 지정된 열까지의 열이 제거된다.
note : 열에 번호는 1열부터 부여한다. |
예를 들어, text.fil 파일에서 열을 제거하려면 다음과 같이 입력한다.
$colrm 6 ▒▒ text.fil
이는 text.fil 이 123456789을 포함하고 있는 경우 화면에 12345를 표시할 것이다.
6-3. 파일 및 디렉토리 링크
링크는 파일 이름과 파일의 내부 표시인 색인 노드 참조 번호(i-node 번호) 사이의 연결이다. 디렉토리 항목에 i-node 번호와 쌍을 이루는 파일 이름이 있으므로, 모든 디렉토리 항목이 링크이다. i-node 번호는 사실 파일 이름을 식별하는 것이 아니라 파일을 식별한다. 링크를 사용하면 어떤 i-node 번호나 파일도 여러 이름으로 인식할 수 있다.
예를 들어, i-node 번호 798에는 Omaha 사무실의 6월 영업에 대한 메모가 있다. 현재, 이 메모에 대한 디렉토리 항목은 다음과 같다.
i-node 번호 파일 이름
798 memo
이 정보는 sales 및 omaha 디렉토리에 저장된 정보와 관련되므로, 필요할 경우 정보를 공유하기 위해 링크를 사용한다. ln 명령을 사용하여, 링크가 이들 디렉토리에 작성된다. 파일은 현재 세 개의 파일 이름을 갖고 있다.
i-node 번호 파일 이름
798 memo
798 sales/june
798 omaha/junesales
pg 또는 cat 명령을 사용하여 세 파일 이름 중에서 임ㅁ의의 파일 내용을 볼 경우, 동일한 정보가 표시된다. 세 파일 이름 중 읨의의 파일에서 i-node 번호의 내용을 편집하면, 모든 파일 이름으로 표시되는 데이터 내용을 변경사항을 반영한다.
6-3-1. 링크 유형
링크는 ln 명령으로 작성된다. 링크의 두 가지 유형은 다음과 같다.
하드 링크 |
파일 이름에서 파일 데이터로의 액세스를 허용한다. 하드 링크는 파일의 존재를 확인한다. 최종 하드 링크를 제거하면, i-node 번호와 그 데이터가 삭제된다. 하드링크는 동일한 파일 시스템안에있는 파일 사이에서만 작성될 수 있다. |
심볼 링크 |
새 파일 이름으로 다른 파일 시스템에 있는 데이터로의 액세스를 허용한다. 심볼 링크는 경로 이름을 포함하는 파일의 특별한 유형이다. 프로세스가 심볼 링크를 만나면, 프로세스는 그 경로를 탐색한다. 심볼 링크는 파일 시스템에서 파일이 삭제되는 것을 보호하지 않는다. |
note : 링크가 많이 작성되었더라도 파일을 작성한 사용자는 그 파일의 소유권을 보유한다. 파일의 소유자나 루트 사용자만이 그 파일의 액세스 모드를 설정할 수 있다. 그런, 링크된 파일 이름에서 해당 파일로 적절한 액세스 모드를 사용하여 파일을 변경할 수 있다. |
해당 파일의 i-node 번호에 대한 하드 링크가 하나 있을 경우, 파일이나 디렉토리가 있다. ls -l 명령에 의해 표시된 긴 리스트에서, 각각의 파일 및 하위 디렉토리와의 링크 수를 볼 수 있다. 어떤 링크가 먼저 작성되었는지에 상관 없이 모든 하드 링크는 운영 시스템이 동일하게 간주한다.
6-3-2. 파일 링크
ln 명령으로 파일을 링크하는 것은 여러 장소에서 동일한 데이터를 가지고 작업할 수 있는 편리한 방법이다. 링크는 원래 파일에 대체 이름을 제공함으로써 작성된다. 링크를 사용하면 메일 리스트나 데이터베이스와 같은 큰 파일을 복사하지 않고도 여러 사용자가 공유할 수 있다. 링크가 디스크 영역을 절약할 수 있을 뿐만 아니라, 하나의 파일에서 이루어진 변경이 링크된 모든 파일에 자동으로 반영된다.
ln 명령이 SourceFile 매개변수에 지정된 파일을 TargetFile 매개변수에 의해 지정된 파일이나 TartgetDirectory 매개변수에 의해 지정된 다른 디렉토리에서 동일한 파일 이름과 링크한다. 기본적으로, ln 명령은 하드 링크를 작성한다. ln 명령을 사용하여 심볼 링크를 작성하려면, -s 플래그를 지정하면 된다.
사용자가 파일을 새 이름에 링크하면 하나의 파일만 나열할 수 있다. 디렉토리에 링크하면, 하나 이상의 파일을 나열 할 수 있다.
TargetFile 매개변수는 선택적이다. 목표 파일을 지정하지 않으면, ln 명령은 사용자의 현재 디렉토리에 새 파일을 작성한다. 새 파일이 SourceFile 매개변수에 지정된 파일 이름을 상속한다.
note : -s 플래그를 사용하지 않고 파일 시스템에 걸쳐 파일을 링크할 수 없다. |
예를 들어, chap1 파일에 다른 링크를 작성하려면 다음과 같이 입력한다.
$ln -f chap1 intro
그러면 chap1이 새 이름 intro로 링크된다. -f 플래그를 사용할 경우, intor 파일이 아직 없으면 해당 파일이 작성된다. intro가 있으면, 파일은 chap1에 대한 링크로 대체된다. 그러면 chap1 및 intro 파일 이름이 모두 같은 파일을 참조한다. 하나의 파일에서 이루어진 임의의 변경이 다른 파일에도 나타난다.
예를 들어, index 파일을 manual 이라는 다른 디렉토리의 같은 이름에 링크하려면 다음과 같이 입력한다.
$ln index manual
그러면 index를 새 이름 manual/index에 링크한다.
예를 들어, 패턴 대응 문자와 함께 ln 명령을 사용하려면 다음과 같이 입력한다.
$ln manual/* .
그러면 manual 디렉토리의 모든 파일이 현재 디렉토리, . 으로 링크되고, manual 디렉토리에서와 같은 이름이 파일에 지정된다.
note : 별표와 마침표 사이에 공백을 입력해야 한다. |
예를 들어, 심볼 링크를 작성하려면 다음과 같이 입력한다.
$ln -s /tmp/toc toc
그러면 현재 디렉토리에 심볼 링크 toc가 작성된다. toc 파일은 /tmp/toc 파일을 가리킨다. /tmp/toc 파일이 있을 경우, cat toc명령이 그 내용을 나열한다.
TargetFile 매개변수를 지정하지 않고 동일한 결과를 얻으려면 다음과 같이 입력한다.
$ln -s /tmp/toc
6-3-3. 링크 파일 제거
rm 명령은 지시한 파일 이름에서 링크를 제거한다. 여러 개의 하드 링크된 파일 이름 중에서 하나가 삭제될 때, 다른 이름으로도 남아 있기 때문에 파일이 완전히 삭제되지는 않는다. i-node 번호에 대한 최종 링크가 제거되면 데이터도 제거된다. 이때 i-node 번호는 시스템에 의해 재사용 가능하다.
6-4. DOS 파일
AIX에서도 DOS 파일에 대해 작업할 수 있다. 작업하려는 DOS 파일을 디스켓에 복사하고, 올바른 명령을 사용하여 시스템의 기본 운영 시스템 디렉토리로 해당 파일을 올바른 형식으로 읽어 들이고 DOS 형식으로 디스켓에 되돌려 보낼 수도 있다.
note : 와일드 카드 문자 * 와 ? 는 기본 운영 시스템 쉘이라 해도 이런 명령에 대해 작용하지 않는 다. 파일 이름의 확장자를 기정하지 않을 경우, 파일 이름은 공백 확장자를 지정한 것과 같다. |
6-4-1. 기본 운영 시스템 파일로 DOS 파일 복사
dosread 명령으로 특정 기본 운영 시스템 파일로 지정된 DOS 파일을 복사할 수 있다.
note : DOS 파일 명명 규정에는 한 가지 예외가 있다. 기본 운영 시스템에서 백슬래쉬(\) 문자는 특별한 의미를 가질 수 있으므로, DOS 경로 이름에서 서브 디렉토리를 지정할 때 /(슬래쉬)를 분리 문자로 사용한다. |
예를 들어, DOS 디스켓에서 기본 운영 파일 시스템으로 chap1.doc라는 텍스트 파일을 복사하려면 다음과 같이 입력한다.
$dosread -a chap1.doc chap1
그러면 디폴트 장치 /dev/fd0 의 DOS 텍스트 파일 CHAP1.DOC이 현재 디렉토리의 기본 운영 시스템 파일 chap1로 복사된다.
예를들어, DOS 디스켓에서 기본 운영 파일 시스템으로 2진 파일을 복사하려면 다음과 같이 입력한다.
$dosread -D /dev/fd1 /survey/test.dta /home/fran/testdata
그러면 /dev/fd1의 DOS 데이터 파일 \survey\test.dta 가 기본 운영 시스템 파일 /home/fran/testdata에 복사된다.
6-4-2. DOS 파일로 기본 운영 파일 복사
doswrite 명령은 지정된 기본 운영 시스템 파일을 지정된 DOS 파일에 복사한다.
예를 들어, 기본 운영 파일 시스템에서 DOS 디스켓으로 chap1이라는 텍스트 파일을 복사하려면 다음과 같이 입력한다.
$doswrite -a chap1 chap1.doc
그러면 현재 디렉토리의 기본 운영 시스템 파일 chap1이 /dev/fd0의 DOS 텍스트 파일 chap1.doc 으로 복사된다.
예를 들어, 기본 운영 파일 시스템에서 DOS 디스켓으로 /survey/test.dta 라는 2진 파일을 복사하려면 다음과 같이 입력한다.
$doswrite -D/dev/fd1 /home/fran/testdata /survey/test.dta
그러면 기본 운영 시스템 데이터 파일 /home/fran/testdata 가 /dev/fd1의 DOS 파일 \survey\test.dta 에 복사된다.
6-4-3. DOS 파일 삭제
dosdel 명령은 지정된 DOS 파일을 삭제한다.
dosdel 명령은 디스크를 검사하기 전에 파일 또는 디렉토리 이름의 소문자를 대문자로 변환한다. 모든 파일 이름은 상대 경로가 아닌 전체 경로 이름일 것으로 간주되므로 처음에 /(슬래쉬)를 추가하지 않아도 된다.
예를 들어, 디폴트 장치(/dev/fd0)에 있는 file.ext라는 DOS 파일을 삭제하려면 다음과 같이 입력한다.
$dosdel file.ext
6-4-4. DOS 디렉토리의 내용 나열
dosdir 명령은 지정된 DOS 파일 또는 디렉토리에 관한 정보를 표시한다.
dosdir 명령은 디스크를 검사하기 전에 파일 또는 디렉토리 이름의 소문자를 대문자로 변환한다. 모든 파일 이름이 전체(상대적이 아님) 경로 이름일 것이라고 간주하기 때문에 처음에 /(슬래쉬)를 추가하지 않아도 된다.
예를 들어, /dev/fd0 에 있는 DOS의 디렉퇼를 읽으려면 다음과 같이 입력한다.
$dosdir
이 명령은 다음과 같이 파일 이름들과 디스크 공간 정보를 리턴한다.
TEST1.TXT
TEST2.TXT
EIBM_LEC.TXT
EIBM_LEC1.TXT
Free space : 216330 bytes
AIX는 콘쉘, 솔라리스 C쉘
/usr 디렉터리 : 유닉스에서 수행 가능한 시스템 명령이나 기타 서비스 프로글매이 설치되어 있는 디렉터(C:Windows)
/opt 디렉터리 : 유닉스 완전 설치 후 패키지 형태로 설치되는 프로그램들은 이 디렉터리에 설치(C:\program Files)
/etc 디렉터리 : 시스템에 관련된 다양한 설정 데이터가 주로 아스키 파일로 저장되어 있는 디렉터리(제어판)
/dev 디렉터리 : 시스템을 구성하는 모든 하드웨어 장비를 관리하기 위한 디바이스 드라이브 파일이 설치되는 디렉터리
/export/home 디렉터리 : 홈 디렉토리가 설치되는 디렉터리(C:\Documents and Settings)
비밀번호 변경
Passwd
로그아웃
Ct기+d, exit, logout
vi명령어
입력모드 전환 명령
i : 커서 앞에 글자 입력
I : 현재 커서가 위치한 라인의 맨 앞의 문자에 커서가 위치시키고 입력모드
a : 커서 뒤에 글자 입력
A : 현재 커서가 위치한 라인의 맨 끝에 입력모드
o : 커서 아래에 라인 삽입 후 입력모드
O : 커서 위에 라인 삽입 후 입력모드
커서이동 명령
h : 왼쪽으로 커서 이동
l : 오른쪽으로 커서 이동
h : 위로 커서 이동
j : 아래로 커서 이동
화면이동 명령
Ctrl+f : 다음 화면으로 이동
Ctrl+b : 이전 화면으로 이동
글자 및 라인 삭제 명령
x : 커서가 위치한 글자 삭제 후 이어지는 문자열을 앞으로 당김
X: 커서가 앞의 글자 삭제 후 이어지는 문자열을 앞으로 당김
dd : 커서가 위치한 라인을 삭제
복사/붙이기 명령
Y : 현재 라인을 메모리에 복사함
P : 메모리에 복사되어 있던 내용을 커서 바로 위에 삽입
라인 병합 명령
J : 커서가 위치한 현재 라인과 다음 라인을 하나로 병합
문자열검색 명령
/명령어 : 문자열을 검색하여 커서 이동
n : 다음 문자열을 검색하여 커서 이동
N : 이전 문자열을 검색하여 커서 이동
문자열대치 명령
:%s/검색문자열/대치문자열/g : 현재 파일 내에 존재하는 모든 검색문자열 대치문자열 바꿈
직접 라인 이동 명령
:숫자 : 주어진 라인으로 바로 이동
Vi 편집의 파일명은 14자 이내의 문자나 숫자의 조합, 특수문자와 ($, %, +, =, -) 불가능
복수개의 파일을 동시에 불리오기
$ vi echo.c echo2.c echo3.c
파일을 vi로 열 때 유용한 옵션들
-c : 지정한 명령어(검색, 배치등)를 실행한 후 vi편집상태로 돌안온다.
$ vi –c/key/ merge.c
-L : 시스템이나 에디터가 비정상적으로 종료했을 때 저장된 파일을 출력한다.
$ vi –L
-r file : 시스템 장애로 인해 손실된 파일을 복구한다.
$ vi –r echo.c
-R : 파일을 읽기 전용모드로 개방하는 명령어이다.(= view명령어)
$ vi –R echo.c
-w[n] : 화면으로 보이는 라인 수를 정의하는 옵션, 유닉스 보통화면에 23라인 정도 디스플레이
$ vi –w10 echo.c
vi종료
esc키를 누른후
ZZ : 화면에서 편집한 파일 내용을 디스크에 저장한 후 vi상태를 빠져나오기
:wq : 저장후 빠져나오기
:wq! : 저장후 빠져나오기(만약 읽기 전용 모드일 때 강제로 저장후 빠져나오기)
:w : vi종료하지 않고 현재 내용을 파일에 저장
:q : 저장않고 빠져나오기
:q! : 저장않고 강제로 빠져나오기
:w filename, :wq filename과 같이 저장할 파일 이름을 함께 입력하면 주어진 파일로 저장 후 종료
:e filename : vi를 종료하지 않고 새로운 파일을 편집하기 위한 명령
:e! filename
:e + echo.c : e명령 사용시 지정한 파일의 끝에서부터 편집을 원할경우
:f 파일명 : 현재 편집하고 있는 파일을 다은 이름으로 바꾸고자 할 때 사용하는 명령어
:sh : vi명령은 vi로 파일을 편집하는 도중 다른 작업을 수행하기 위하여 UNIX 쉘을 수행하기 위한 명령어
(vi에서 이전에 편집하던 내용으로 되돌아가려면 exit, ctrl+d)
Ctrl+g : 현재 편집 중인 파일에 대한 간단한 정보를 디스플레이
화면단위조정
Ctrl+f : 한 화면씩 파일의 앞으로 이동한다.
Ctrl+b : 한 화면씩 파일의 뒤로 이동한다.
Ctrl+d : 반 화면씩 파일의 앞으로 이동한다.
Ctrl+u : 반 화면씩 파일의 뒤로 이동한다.
Ctrl+e : 한 라인씩 파일의 앞으로 이동한다.
Ctrl+y : 한 라인씩 파일의 뒤로 이동한다.
커서 이동
한문자, 위아래별 이동 : 방향키
h : 한문자 왼쪽
j,엔터키,+ : 한 라인 아래쪽
k,- : 한 라인 위쪽
i : 한문자 오른쪽
현재 화면에서의 커서 이동
H : 현재 화면의 첫 라인 첫 칸으로 이동
M : 현재 화면의 중간 라인 첫 칸으로 이동
L : 현재 화면의 마지막 라인 첫 칸으로 이동
단어별 커서 이동
w : (word) 현재 커서 위치에서 오른쪽으로 한 단어씩 이동
b : (back) 현재 커서 위치에서 왼쪽으로 한 단어씩 이동
e : (end) 현재 커서 위치한 단어에서 그 단어의 끝 문자를 찾아서 커서를 이동
현재 커서가 속한 라인 내에서 커서 이동
숫자 0 : vi편집모드에서 숫자 0을 입력하면 현재 라인에서 첫 칸으로 이동
^ : vi편집모드에서 ^를 입력하면 현재 라인의 첫 번째 단어의 첫번째 글자 커서를 이동한다
$ : vi편집모드에서 $는 현재 커서가 위치한 라인의 마지막 문자로 커서를 이동
사용자가 지정한 라인으로 커서 이동
: 라인번호 또는 라인번호G : 원하는 라인으로 바로 이동함.
G : 편집 중인 파일의 끝으로 바로 이동하기 위한 명령어
파일에 라인 번호 매기기
: set number 또는 :se nu(해제는 :set nonumber 또는 :se nonu)
/문자열 또는 /문자열/ : 현재 커서가 위치한 곳으로부터 순방향(아래쪽)으로 지정한 문자열을 검색하여 첫 문자열에
커서가 위치
?문자열 또는 ?문자열? : /문자열 명령의 반대 (n:역방향으로 찾을 때, N: 순방향으로 검색하려면)
문자 삭제 명령
X : 커서가 위치해 있는 곳에 있는 하나의 문자를 삭제하고 삭제된 문자오른편의 위치하던 문자로 커서 이동
dw : (delete word) 커서가 위치하는 문자를 포함한 나머지 단어 삭제하고 그 다음 단어를 삭제되지 않은
현재 단어와 병 합하여 하나의 단어
db : 현재 커서 위치에서 왼쪽에 존재하는 첫번째 단어의 시작 문자부터 커서 왼쪽 문자까지 삭제하는 명령,
커서의 위치는 그대로
라인 삭제 명령
dd : 커서가 위치하고 있는 라인을 삭제하고 그 다음 라인의 첫 번째 칸에 커서를 위치하낟.
D : 현재 커서가 위치하고 있는 라인에서 커서 이후에 존재하는 나머지 문자를 모두 삭제
dG : 현재 커서가 위치한 라인에서부터 파일의 나머지를 모두 삭제
d1G : 파일의 처음부터 현재 커서가 위치한 라인까지 모든 내용을 삭제하는 명령어
:n,md : n번째 라인에서부터 m번째 라인까지 내용을 모두 삭제하는 역할
텍스트 덮어쓰기
r : 커서가 위치한 곳의 한 문자를 다른 한 문자로 바꾸는 명령
R : 현재 커서위치에서부터 ESC키를 입력할 때까지 계속해서 문자를 덮어쓰는 명령
s : 현재 커서위치에 있는 문자를 $문자로 변경하고 $문자로 표시된 부분에 입력하는 문자들을 삽입하는 명령어,
ESC키 입력할때까지 문자 삽입
단어 바꾸기
cw : (change word) 현재 커서가 있는 위치로부터 그 단어의 마지막까지를 수정하는 명령어
라인 바꾸기
cc : 현재 커서가 위치한 라인의 내용을 모두 바꾸기 위한 명령어, ESC키를 누르면 종료
C 또는 c$ : 현재 커서 위치에서 왼쪽 내용은 변화시키지 않고 오른쪽 내용을 모두 바꾸는 명령어, ESC키를 누르면 종료
소문자를 대문자로, 대문자를 소문자로 바꾸기
~ : 바꾸고자 하는 커서를 먼저 이동시킨후 사용하면 자동으로 소문자->대문자, 대문자->소문자
원하는 문자열을 찾은 후 바꾸기
:%s/검색문자열/대체문자열/g 또는 :g/검색문자열/s//대체문자열/g : 문서 전체에 걸쳐서 무조건 교체
:%s/검색문자열/대체문자열/gc 또는 :g/검색문자열/s//대체문자열/gc : 문서 전체에 걸쳐 교체, 변경할건지 확인 요청함.(종료는 ctrl+c)
명령 취소하기
u : 삽입, 치환, 변경, 삭제 등 편집버퍼를 변경했던 마지막 명령을 그 이전 상태 되돌림
U : 현재 라인으로 옮겨 온 이후로 현재의 라인에 가한 모든 변경사항을 취소한다.
명령어 반복하기
.(점) : 바로 이전에 수행되었던 명령을 한 번 더 반복한다.
복사하기 붙이기
yw : 현재 커서가 위치한 단어를 버퍼에 복사하는 명령어
yy 또는 Y : 현재 커서가 위치한 라인을 버퍼에 복사하는 명령어
ny : 현재 커서가 위치한 라인에서부터 사용자가 지정하는 n개의 라인을 버퍼에 복사하는 명령어
붙이기
p(소문자) : 커서가 위치한 오른쪽 또는 라인의 아래 라인에 버퍼에 복사되어 있던 문자열을 붙이기
P(대문자) : 커서가 위치한 왼쪽 또는 위 라인에 버퍼에 복사되어 있던 문자열을 붙이기
라인 병합과 라인 분리
J : 현재 커서가 위치한 라인과 그 아래쪽 라인을 현재 커서가 위치한 라인에 단일 라인으로 연결
라인분리 : i명령과 엔터키를 활용, 편집모드로 전환하기 위해서 ESC키
여러 라인의 복사와 이동
:시작라인번호[,끝라인번호]co복사할라인번호 : 예) 1~3라인까지 복사하여 7번 라인 다음에 넣기 :1,3co7
:시작라인번호[,끝라인번호]m이동할라인번호 : 예) 1~3라인까지 이동하여 7번 라인 다음에 넣기 :1,3m7
파일 편집을 위한 기타 기능
:r파일명 : 현재 커서 위치 다음라인에 지정하는 파일을 읽어서 삽입할 때 유용한 명령어
:! : vi상태를 종료하지 않고 UNIX명령 실행(예 :!date), vi상태로 복귀하기 위해 엔터키 입력
AIX 점검 명령어
CPU - 수량 및 사용 가능상태 확인
lsdev -Cc processor Processor 수량 및 Available 한 가용상태 확인
CPU - CPU의 병목 여부 파악
sar Processor 별로 사용률 점검
vmstat processor 의 used, idle, wait 등을 파악
topas processor load average 를 검토
bindprocessor processor bind 의 존재여부 확인 및 필요 시 binding
Memory - 수량 및 사용 가능상태 확인
lsdev -Cc Memory memory(Card)수량 및 Available 한 가용상태 확인
lsattr -El mem(n) 메모리 타입 및 Size 확인
Disk - 수량 및 사용 가능상태 확인
lsdev -Cc disk disk 수량 및 Available 한 가용상태 확인
lspv 디스크 할당 상태 확인
lspv hdisk(n) 디스크 할당 상태 및 가용 Size 확인
Adapter - 구성된 종류 및 수량, 가용상태 확인
lsdev-Cc adapter adapter 별 Available 한 가용상태 확인
diag 구성 장치들의 문제점 진단
Log 점검 - 오류에 대한 로그 및 시스템에 설정된 로그파일 확인
errpt System 에서 발생된 기본적인 로그를 확인하고 Class:H (Hardware)와 type:P(PEND, PERF, PERM) 부분의 발생여부 중점으로 점검
vi /var/spool/mail/root root 메일을 점검하여 관리자에게 통지된 에러 확인
find / -name core core 파일 생성 여부 확인
Memory - Memory의 과부하 여부 파악
vmstat 충분한 Free memory가 있는지 확인하고 paging in, out 여부를 파악하여 Memory의 병목 여부 판단.
lsps Paging 공간의 사용률을 파악하여 메모리 병목 판단에 활용
topas Memory의 caching 사용여부와 사용률을 파악
ps aux 프로세스 별로 메모리 사용률 파악
svmon 프로세스 사용률 순 또는 Memory 사용률에 따른 순서로 상세한 사용에 대한 세부 내역파악.
- 회사명 = lsattr -El sys0
- 모델명 = prtconf (하드웨어config)
- 버전 = oslevel -r
- Arch = prtconf
- Hz = lsattr -El proc0 (단위 Hz)
- 개수 = lsdev -Cc processor|wc -l
4. Memory
- 용량 = lsattr -El sys0, prtconf
- 용량 = lsps -a
- size = bootinfo -s hdisk(숫자) (Mb단위)
- 개수 = lsdev -Cc disk
- size = bootinfo -s hdisk(숫자) (Mb단위)
- 개수 = lsdev -Cc pdisk , lsdev -Ct hdisk
- mirror = lsvg rootvg (ACTIVE PVs = 2)
- 속도, 개수 = lsparent -Ck ent
prtconf = list system configuration
lscfg [-v] = devices (-v = verbose for microcode levels, etc)
lscfg -v = devices verbose (microcode level, firmware, etc)
lsdev -Cc adapter = adapter cards
lsdev -Cc disk = disks
lsdev -Cc processor = CPU s
lsattr -El sys0 = serial number, model number, memory
oslevel = AIX OS level
instfix -i |grep ML = AIX maintenance level
lslpp -l = installed SW and levels
lsvg -o = active volume groups
lsvg -p vgname = disk drives in VG
lsvg -l vgname = LV s in VG
lslv lvname = LV detail
lslv -l lvname = LV disk location
lspv = disks
lspv -l hdisk# = LV s residing on a disk
* Network 관련 정보
lsdev -Cc if = List network interfaces
netstat -rn = List network gateways
출처 : http://ssyangcal.tistory.com/414