1. FTP 실행

~]ftp 접속할서버ip [port]

ex) ftp 123.123.213.0 21

접속할 서버의 IP가 아니라 만약 리눅스의 hosts에 host명이 등록되어있다면 그걸 써도 된다.
접속되면 id,와 pw를 물어보는데 계정을 치고 들어가면

fip> 이렇게 나온다.
여기서부터는 ftp 명령어를 사용하면 된다.

2. 명령어
 명령어 설명 
 !  Shell을 실행한다. Unix 로그인 유저의 디폴트 쉘을 실행하게 된다. 이 쉘을 종료하려면 exit를 치면 ftp로 돌아오게 된다.
 ! 명령어  Shell명령어를 실행한다. Unix프롬프트 상에서의 명령어를 실행하게 된다.
내부적으로 Shell을 구동시켜 실행하게 된다
 ascii  화일 전송모드를 ASCII화일로 변경한다. 디폴트로 설정되어 있다.
 binary  화일 전송모드를 Binary화일로 변경한다.
 bye, quit  ftp를 종료한다
 cd  리모트 디렉토리를 변경한다
 lcd  로컬 디렉토리를 변경한다
 chmod  리모트 시스템의 화일의 모드를 변경한다.
 close  ftp 세션을 종료한다. ftp는 종료하지 않는다.
 dir  리모드 시스템의 화일의 리스트를 얻는다.
 open  리모트 IP와 포트를 주고 ftp세션을 연다.
 prompt  Interactive mode를 토글시킨다.
화일 하나 하나를 물어보고 전송할지 물어보지 않고 전송할 지를 결정한다.
 put  로컬의 화일을 리모트로 전송한다.
 mput  로컬의 여러 화일을 리모트로 전송한다.
 get  리모트의 화일을 로컬로 가져온다.
 mget  리모트의 여러 화일들을 로컬로 가져온다.
 user  다른 사용자로 세션을 연다.
 pwd  현재의 리모트 디렉토리 Path를 보여준다.
 mdir  리모트 디렉토리내의 조건에 맞는 화일을 보여준다.
mdir *.c
 delete  리모트 시스템의 화일을 삭제한다.

'서버 이야기 > Linux 이야기' 카테고리의 다른 글

VI에서 인코딩 변환해서 보기  (0) 2010.12.02
Linux screen 사용하기  (0) 2010.11.30
vmstat 항목 설정 보기  (0) 2010.02.02
Crontab 설정 하기  (0) 2010.02.02
리눅스 명령어 모음  (0) 2009.08.05
Posted by 서오석
,

레퍼런스 : 복사 http://blog.naver.com/ares2011/50023242845

사실 다른 사람이 쓴 것 퍼오는 이유 중 하나는 즐겨찾기를 했는데 나중에 해당 페이지가 삭제되서 못찾을 때의 난감함 때문이다.--;
이 아래부터 퍼온 것.



vmstat를 이용하여 cpu와 i/o 활동을 모니터링을 할 수가 있다.
첫번째 줄은 무시한다.(첫줄은 부팅 이후의 각 통계치에 대한 평균값을 보여준다.)

vmstat에서 중요한 것은 procs 영역의 b 필드이다. b의 수치가 높은 경우 i/o 작업을 위해 cpu가 계속 대기 상태로 있는 경우다.
이런 경우에는 디스크i/o 문제를 확인함.

스왑아웃(so)이 지속적으로 발생한다면 메모리가 부족한 것이다. 하지만 일정간격으로 스왑아웃이 발생되는 것은 정상적이다.
스왑아웃(so)필드는 항상 0에 가까워야 한다.

 # vmstat 1
 procs     memory                       page                disk              faults           cpu
 r b w   swap     free      re  mf    pi po fr de sr s6 s1 s1 s1   in    sy     cs  us  sy  id
 0 0 0 20719952 5846888 1235 9503 0  0   0  0   0  0   0   0   0  462 11337  1085 14  12  75
 0 0 0 20719864 5846792 1228 9315 0  0   0  0   0  0   0   0   0  250 10729  1029 13  13  74
 0 0 0 20720224 5847424 1261 9514 0  0   0  0   0  0   0   0   0  262 10909  1023 15  11  74

 

각 항목 설명
procs :  세가지 상태에 있는 프로세스들의 수

Solaris에서는 멀티 쓰레드 기능을 제공하며, 커널의 스케쥴링도 쓰레드 단위로 한다. 멀티 쓰레딩 방식으로 프로그래밍되어 있지 않은 프로세스는 하나의 쓰레드가 프로세스에 있다. 각 프로세스에 몇 개의 쓰레드가 있는지는 psinfo 명령어의 결과에서 NLWP 항목에 있는 값으로 확인할 수 있다.

# /opt/JSparm/bin/psinfo -f
Date.time 0507.23:09:34 proc 70 zombie 0 runnable 0 lwp 144 cpu 6.11%
avgload  0.07  0.02  0.02 hp+stk 52.75M
  PID  USERNAME HP+STK S NLWP   WCPU%   CPU%  ELAPSED        TIME CMD
  499  root     0.117M O    1   0.29%  0.29%      0d0       00.06 psinfo
  170  root     0.188M S    8   0.25%  0.25%  0d11147       00.63 syslogd
  463  guest    9.383M S    1   0.15%  0.15%   0d8594    01:03.88 netscape
  287  root     0.148M S   12   0.02%  0.02%  0d10724       02.81 mibiisa
  495  guest    0.031M S    1   0.01%  0.01%   0d5498       00.16 vi

쓰레드의 상태는 크기 세가지로 나눌 수 있다.

  • CPU를 사용하고 있는 쓰레드
  • CPU를 사용하기 위해 Run Queue에서 대기하고 있는 쓰레드
  • IO나 이벤트가 완료되기를 기다리며 sleep하는 쓰레드
  •  
    r : In run queue - CPU를 사용하기 위해 Run Queue에서 대기하고 있는 쓰레드의 수 (2 이상이면 CPU busy)

    b : Blocked for resources(I/O, paging, etc.) - IO나 이벤트가 완료되기를 기다리며 sleep하는 쓰레드의 수

        CPU 성능과 관계가 없는 필드이다. Disk의 I/O가 느리기 때문에 b 필드의 수치가 발생한다.

       w : threads swapped out - swap out된 실행가능한 쓰레드의 수 (0 이상이면 메모리가 부족하여 메모리 증설을 고려 한다.)

        시스템의 메모리가 부족할 때 paging이 일어나는데, 페이징으로도 부족한 메모리를 보충하지 못하면 swapping이 일어난다. 이때 메모리로 부터 빠져나기 swap 디바이스에 보관된 쓰레드의 갯수를 w에 보여준다. 한번 swapout된 쓰레드는 그 쓰레드가 다시 실행될 때 물리적 메모리로 들어온다 

        paging이란... 즉 물리적인 메모리의 크기는 한정되어 있기 때문에 실제 메모리의 크기보다 더 큰 메모리가 있는 것처럼 속여서 메모리를 사용하는데 이러한 방법을 가상 메모리 기법이라고 한다. 물론 메모리상에 항상 올라가 있는 프로세스도 있지만 (즉, 커널과 같은 시스템 프로세스) 대부분의 사용자 프로세스들은 실행시에만 메모리에 올라가기 때문에 자주 사용되지 않는 프로세스들은 굳이 메모리상에 있을 필요가 없다. 그래서 이런 놈들은 스왑이라는 영역에 잠시 내려 놓았다가(스왑아웃) 필요할때 다시 메모리로 불러들인다.
        이렇게 메모리에서 스왑으로 왔다 갔다하는 것을 스왑핑(swaping)이라고 한다. 근데 왜 paging을 설명하면 swaping을 얘기했냐?  왜냐면 이 두놈은 같은 개념이다. page가 뭐냐면 앞에서 얘기한 가상 메모리 기법을 사용하기 위해서 메모리를 일정 크기로 나누어 놓거든. 이렇게 나눈 것을 page라고 부르지. 예를 들어 13K의 메모리를 차지하고 있는 프로세스를 스왑아웃하려 할때 실제 스왑아웃된 영역의 크기는 얼마를 차지하느냐? 페이지 단위로 스와핑이 일어나기 때문에 만약 시스템의 페이지 사이즈가 4k면 16k의 영역을 차지한다는 거지...  근데 이게 맞나 모르겠다.

     memory : virtual and real memory의 사용에 관한 정보(?)
    swap : amount of swap space currently available (Kbytes)

    사용 가능한 가상 메모리(physical memory + swap device)의 크기를 나타낸다.

     free : size of the free list(말안해도 뭔지 알겠지?) - size of the free list (Kbytes)

    사용 가능한 physical memory 의 크기를 나타낸다.

     disk - f0, s0,s1, s4

     최대 4개의 디스크에 대하여 초당 read/write 횟수를 나타낸다.

     

    page : page에 관한 정보(썰렁)
    re : page reclaims

    프리 메모리가 부족할 경우, paging이 발생하여 최근에 사용되지 않은 페이지를 찾아서 프리시켜 부족한 메모리를 보충하게 되는데,
    이렇게 프리되는 페이지의 내용은 훼손되지 않고 프리 메모리 영역에서 관리된다. re값은 이렇게 프리된 페이지가 프로세스의 요청에 따라 다시 사용되는 페이지의 수를 나타낸다.

     

    at : 주소 변환에 실패한 페이지?

    pi : page in 되는 페이지 수
    디스크로 paged out한 페이지를 다시 메모리에서 읽을 때, 읽은 페이지를 KB로 환산한 값이다.

    po : page out 되는 페이지 수
    프리 시킬 페이지의 내용이 파일 시스템의 캐쉬일 때 해당 디스크 파티션에 저장을 하는데, 이때 디스크에 저장된 페이지를 KB로 환산
    한 값이다.

    fr : pages freed per second

    sr 필드 값(스캔한 페이지의 개수)을 KB 단위로 환산한 값이다.

    de : Anticipated short term memory shortfail (어렵다, 어려워...)

    sr : Pages scanned by clock algorithm. per second

    free physical memory가 전체 physical memory 양의 1/64보다 크게 만들기 위해서 시스템에 있는 페이지를 스캔하여 최근에 사용되지
    않는 페이지를 찾아 프리 시킨다. 이때 스캔한 페이지의 개수

     

    faults 시간 간격 동안 페이지 폴트의 수
    in : Device interrupts per second - 초당 인터럽드 횟수(clock interrupt 제외)

    인터럽트는 주변 장치가 데이타의 입출력이 발생할 때, CPU에게 알려주는 방법으로 사용된다. 예를 들어, 사용자가 키보드의 키를 누르면 키보드를 관장하는 하드웨어가 인터럽트를 발생하여 키보드로 부터 입력이 있다는 것을 CPU에게 알리게 된다. 그러면, CPU는 이미 정의되어 있는 키보드 처리 루틴(인터럽트 핸들러)을 호출하여 입력을 처리한다. 이처럼 주변장치들은 대부분 인터럽트를 발생하는 기능을 가지고 있다. 시스템에는 클럭이라는 장치가 있는데 이것은 1초에 100번씩 일정하게 인터럽트를 발생한다. 그러나 in에는 일정하게 발생하는 클럭 인터럽트는 제외한다.
    sy : System calls per second - 초당 시스템 콜 회수

    시스템 콜은 커널이 제공하는 기본적인 서비스 루틴이다. 프로세스의 실행부터 종료될 때까지 시스템 콜의 연속적인 호출이라고 할 수 있다. Solaris에는 200가지가 넘는 시스템 콜이 있으며, 가장 흔히 사용하는 시스템 콜에는 read(), write()가 있다.
    cs : CPU context switch rate - 초당 컨텍스트 스위칭 횟수

    Solaris에서 스케줄링은 커널 쓰레드 단위로 한다. 하나의 쓰레드가 실행되다가 쓰레드에게 주어진 시간을 다 사용하거나, 자발적인 sleep하거나, 자원이 준비되기를 기다리거나, 우선순위가 높은 쓰레드가 CPU를 사용하기 위해 대기하고 있으면, 다른 쓰레드로 전환이 발생한다. 이것을 컨텍스트 스위칭이라고 한다.

     

    여기서 잠깐 페이지 폴트란? 일단 실제 메모리 보다 큰 가상의 메모리 주소를 사용한다고 앞에서 얘기했다. 이 가상메모리 주소는 실제 사

    용될시에는 실제 물리적 메모리 주소와 Mapping이 되야한다. 바로 이때 Mapping이 안되서 CPU가 trap요청하는데 이것이 바로 페이지 폴트다. 이렇게 페이지 폴트가 일어나면 아까 얘기한 것처럼 오래된 놈 하나를 스왑영역으로 page out시켜버려 가상메모리 주소가 물리적
    메모리 주소에 Mapping할 수 있도록 공간을 만들어 준다. 그리고 나서야 트랩된 명령어의 실행을 다시 시작한다.

     

    cpu

    Solaris 운영체제는 1초에 100번씩 CPU가 어떤 일을 하는지 조사한다. 이때 CPU가 user mode에서 작업을 실행하면 user_tick에 1을 증가 시키고, system mode에서 작업을 실행하면 system_tick에 1을 증가시킨다.
    CPU가 실행할 작업이 없어서 쉬고 있는 경우, I/O(block device: hard disk)를 기다리는 작업이 있으면 wait_tick에 1을 증가시키고, 그렇지 않으면 idle_tick에 1을 증가시킨다.
    vmstat나 sar 명령어는 이러한 값을 시스템으로 부터 얻어서 주어진 시간간격(interval) 의 차이 값을 구하여 각각을 백분율(%)로 나타낸 것이 CPU 사용량이다.

              sar     vmstat              CPU
    ---------------------------------------------------
             %usr  =  us            run on user mode
             %sys  =  sy            run on system mode
    %wait + %idle  =  id            idle
    


    us : 사용자 프로세스가 사용하는 총 CPU시간의 비율
         (이건 시스템 프로세스보다 우선순위가 낮은 사용자 프로세스가 사용하는 CPU시간이고...)
    sy : 시스템 부하로 사용하는 총 CPU시간의 비율
        (시스템이 사용하는 CPU시간을 말하는 거겠지.)
    id : 놀고 있는 CPU시간의 비율

    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    Linux screen 사용하기  (0) 2010.11.30
    리눅스에서 FTP로 사용하기  (0) 2010.02.18
    Crontab 설정 하기  (0) 2010.02.02
    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    Posted by 서오석
    ,

    1. Crontab 실행 및 종료
       실행 : /etc/rc.d/init.d/crond start
       종료 : /etc/rc.d/init.d/crond stop

    2. 설정
    크론 설정 : /etc/crontab ( ~]$crontab 해도 됨.)

    option
      -e : 설정된 파일을 새롭게 편집
      -d : 등록된 내용을 삭제
      -l  : 현재 등록된 내용 보기

    3. 시간 등록
    ex) 01 03 * * * /disk/script/tomcatctl start

     필드 의미  내용
     필드 1 (01)  분  0-59
     필드 2 (03)  시  0-23
     필드 3 (*)  일  0-31
     필드 4 (*)  월  1-12
     필드 5 (*)  요일   0-7 (0 또는 7=일, 1=월, 2=화, ...)
     필드 6 (/disk/script/tomcatctl start)  명령어 실행할 명령어 

    연속으로 수행하는 법 : 콤마로 구분

    ex 1 00,01,08,13,17,20 * * * /disk/start.sh

    00시, 01시, 08시 .. 1분에 start.sh를 수행하게 됨.

    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    리눅스에서 FTP로 사용하기  (0) 2010.02.18
    vmstat 항목 설정 보기  (0) 2010.02.02
    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    리눅스 파일 내용 검색  (1) 2009.07.28
    Posted by 서오석
    ,

    가끔 서버에 파일을 업로드하거나 다운로드 할 때 해당 파일의 용량이 얼마나 되는지 알아야 할 때가 있다. 이런 때 아파치 로그로 I/O가 된 Byte를 표기해야 하는데 아래와 같은 설정을 하면된다.
    ( 새로 Apache를 설치하는게 아니라 동작하고 있는 녀석에 모듈을 추가하는 것이다. )

    우선 내가 작업한 환경은 apache-2.0.63 이다.

    우선 http://httpd.apache.org/download.cgi 여기서 아파치를 다운 받는다.
    다운로드 (http://mirror.apache-kr.org/httpd/httpd-2.0.63.tar.gz)

    서버에서 작업 중이라면

    /]wget http://mirror.apache-kr.org/httpd/httpd-2.0.63.tar.gz 

    이렇게 명령어를 하면 파일이 다운받아진다.

    그리고 다운받은 녀석의 압축을 푼다.

    /]tar xvf httpd-2.0.63tar.gz

    하면 압축이 줄줄 풀린다. 

    그리고 logio.c가 있는지 확인하기 위해 디렉토리 이동을 한다.
    /]cd /httpd-2.0.63/modules/loggers

    그 안에 mod_logio.c가 있는지 확인이 되었으면 다시 /]로 돌아가서 configure 파일을 만든다.

    /]./configure --enable-mods-shared=logio --prefix=/apache

    이러면 checking 하면서 설정할 파일들이 제대로 있는지 확인하고나서 configure 파일을 만들게 된다.

    그리고 예전에 make 파일을 지우기위해 다음과 같은 명령어를 쓴다.

    /]make clean

    그럼 예전에 make 파일 만든게 몽땅 삭제된다.

    그리고 나서 logio만 make하기 위해 modules/loggers 밑으로 이동한다.

    /]cd modules/loggers

    그다음 make 명령어로 make 파일을 만든다.
    modules/loggers] make
    /httpd-2.0.63/srclib/apr/libtool --silent --mode=compile gcc  -g -O2 -pthread    -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -DAP_HAVE_DESIGNATED_INITIALIZER   -I/httpd-2.0.63/srclib/apr/include -I/httpd-2.0.63/srclib/apr-util/include -I. -I/httpd-2.0.63/os/unix -I/httpd-2.0.63/server/mpm/prefork -I/httpd-2.0.63/modules/http -I/httpd-2.0.63/modules/filters -I/httpd-2.0.63/modules/proxy -I/httpd-2.0.63/include -I/httpd-2.0.63/modules/generators -I/httpd-2.0.63/modules/dav/main -prefer-non-pic -static -c mod_log_config.c && touch mod_log_config.lo
    /httpd-2.0.63/srclib/apr/libtool --silent --mode=link gcc  -g -O2 -pthread    -DLINUX=2 -D_REENTRANT -D_GNU_SOURCE -DAP_HAVE_DESIGNATED_INITIALIZER   -I/httpd-2.0.63/srclib/apr/include -I/httpd-2.0.63/srclib/apr-util/include -I. -I/httpd-2.0.63/os/unix -I/httpd-2.0.63/server/mpm/prefork -I/httpd-2.0.63/modules/http -I/httpd-2.0.63/modules/filters -I/httpd-2.0.63/modules/proxy -I/httpd-2.0.63/include -I/httpd-2.0.63/modules/generators -I/httpd-2.0.63/modules/dav/main -module -export-dynamic    -o mod_log_config.la mod_log_config.lo
    make[1]: Leaving directory `/httpd-2.0.63/modules/loggers'

    이러면 apache의 modules아래 mod_logio.so 라는 파일이 만들어졌을 것이다.

    그럼 이제 apache/conf 에 가서 로그 설정만 해주면 된다.

    apache/conf]vi httpd.conf

    맨 아래에 LoadModule logio_module modules/mod_logio.so 요걸 추가해준다.

    이거 추가하면 아파치가 이 모듈을 로딩한다는 것이다. 그리고 로그 포멧 중 맨 마지막 combined 라고 된 녀석에 뒤에

    %I %O를 추가해주면 된다.

    LogFormat "%h %D %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combined

    그리고 저장하구 나와서

    apache/bin]./httpd -t

    해서 문법이 맞는지 확인 한다.
    Syntax OK 이렇게 나오면 잘 한 것이다.

    이제 아파치 설정을 적용한다.

    apache/bin] ./apachectl graceful

    끝~ 이제 access 로그 뒷 쪽에 보면 해당 I/O 값들이 붙어서 날아 올 것 이다.





    Posted by 서오석
    ,


    출처 : http://blog.daum.net/warmfeel/72

     

    addbib  -  도서목록 형식의 데이터베이스를 만들거나, 확장
    apropos  - 사용설명서의 키워드 검색
    ar       -  라이브러리 만들기, 관리
    at, batch - 원하는 시간에 원하는 명령을 실해하게 하는 명령
    awk     - 패턴 검색과 언어 처리
    banner   - 큰 글자(배너) 만들기
    basename - 경로 이름에서 마지막에 있는 이름만 출력
    biff     - 자신에게 편지가 배달되면 알려주는 명령
    bin-mail, binmail - 예전에 사용한 전자우편 프로그램
    cal     - 달력보기
    calendar - 간단한 일정표
    cat    - 파일 병합과 내용 보기
    cb     - 간단한 C 프로그램 beautifier(?)
    cc     - C 컴파일러
    cd    - 작업 디렉토리 바꾸기
    checknr - nroff 또는 troff 입력 파일 검사; 오류를 보여준다
    chgrp  - 파일의 사용자 그룹 바꾸기
    chmod - 파일의 접근 권한 바꾸기
    clear  - 터미날 화면 깨끗이 하기
    cmp   - 두 파일을 바이트 단위로 비교
    colcrt  - troff 파일의 밑줄 속성 문자 처리
    comm  - 지정 두파일의 줄 단위 비교와 그 처리
    compress, uncompress, zcat - 파일 압축관련 유틸리티들
    cp     - 파일 복사
    cpio   - copy file archives in and out
    cpp    - C 언어 전처리기
    csh    - C 문법과 비슷한 쉘 스크립트 문법과 기타 여러 기능이 내장된 쉘
    ctags  - ex 나 vi 편집기에서 사용될 tag 파일을 만드는 명령
    date    - 시스템 시간 보기나 지정하기
    dbx    - 소스 수준의 디버거
    deroff  - nroff, troff, tbl, eqn 관련 내용 지움
    df     - disk free: 디스크의 남은 용량 보기
    diff    - 두 파일의 차이점 비교
    du     - disk used : 디스크 사용량 보기
    echo   - 인자를 표준 출력으로 출력
    ed, red - 기본 줄 편집기
    eqn, neqn, checkeq - 수식 표현 포멧 도구
    error   - 컴파일러 오류 메시지 목록
    ex, edit, e - 줄 편집기
    expand, unexpand - TAB 문자를 공백문자로 바꿈, 또는 그 반대로
    expr    - 인자를 수식으로 처리
    file     - 파일 형식 알아보기
    find    - 파일 찾기
    finger   - 사용자 정보 알아보기
    fmt, fmt_mail - 간단한 문서나, 편지 포멧 도구
    fold    - 긴 줄 출력 방법 지정
    ftp     - 파일 전송 프로그램
    gcore   - 실행 중인 프로세스의 core 이미지를 구한다.
    gprof   - call-graph profile data(?)를 보여줌
    grep   - 문자열 찾기
    groups - 사용자의 그룹을 보여줌
    history - 이전 명령 보기
    hostname - 현재 시스템 이름을 보여줌
    imake   - makefile 만드는 프로그램
    indent  - C 프로그램 소스 파일을 들여쓰기 하는 포멧 도구
    install  - 파일 설치
    join    - 관계형 데이터베이스 연산자
    kill     - 프로세스  stop :-)
    last     - 사용자가 마지막 접속 상태를 보여줌
    ld, ld.so - 링크 편집기, 동적 링크 편집기
    leave    - 자신의 접속 종료 시간을 알려줌
    less     - more 명령의 확장
    lex     - 어휘 분석 프로그램 생성기
    lint     - C 프로그램 verifier
    ln      - 파일의 하드, 심벌릭 링크 명령
    login   - 시스템 접속 명령
    look    - 시스템 디렉토리나, 정열된 목록에서 단어 찾기
    lookbib - 도서목록형 데이타베이스에서 찾기
    lorder  - 오브젝트 라이브러리의 관계 찾기
    lp, cancel - 인쇄 시작, 취소
    lpq     - 인쇄 작업 상황 보기
    lpr     - 인쇄
    lprm   - 인쇄 작업 지우기
    ls      - 디렉토리 내용 보기
    mail, Mail - 전자 우편 프로그램
    make   - 실행 파일을 만들거나, 특정 작업 파일을 만들 때 사용하는 도구
    man    - 온라인 사용자 설명서를 보는 명령
    mesg   - 메시지 수신 상태를 보거나 지정
    mkdir   - 디렉토리 만들기
    mkstr   - C 소스 파일을 참조로 오류 메시지 파일을 만듬.
    more, page - 텍스트 파일 보기 명령
    mv     - 파일 이동이나, 이름 바꾸기
    nawk   - 패턴 검색과 언어 처리
    nice    - 낮은 우선권에서 명령 실행
    nm     -  심블 이름 목록 보기
    nroff   - 문서 포멧 도구
    od     - 8진수, 10진수, 16진수, ascii 덤프
    passwd, chfn, chsh - 비밀번호, 핑거정보, 쉘 바꾸기
    paste   - 여러파일의 서로 관련 있는 줄 연결시키기
    pr      - 문서 파일 양식화 도구
    printenv - 현재 환경 변수들의 내용과 그 값 알아보기
    prof     - profile 자료 보기
    ps      - 현재 프로세스 정보 보기
    ptx     - permuted(순열화된?, 교환된?) 색인 만들기
    pwd     - 현재 작업 디렉토리 보기
    quota   - 한 사용자에게 지정된 디스크 할당량보기
    ranlib   - archive를 random 라이브러리로 변화
    rcp     - 리모트 카피
    rcs     - RCS 파일 속성 바꾸기
    rcsdiff  - RCS revisions 비교
    rev     - 한 줄의 문자열 꺼꾸로
    rlogin   - 리모트 로그인
    rm, rmdir - 파일, 디렉토리 지우기
    roffbib   - 도서목록형 데이터베이스 보기 또는 양식화
    rsh     - 리모트 쉘
    rup     - 로칼 머쉰의 호스트 상태 보기(RPC version)
    ruptime - 로칼 머쉰의 호스트 상태 보기
    rusers   - 현재 접속자 보기 (RPC version)
    rwall   - 모든 사용자에게 알림(RPC)
    rwho    - 현재 접속자 보기
    sccs    - Source Code Control System (SCCS)
    sccs-admin, admin   - SCCS 사용 내역 파일을 만들고, 관리
    sccs-cdc, cdc        - SCCS 델타의 델파 주석을 바꿈
    sccs-comb, comb    - SCCS 델타 조합
    sccs-delta, delta     - SCCS 파일에 데해 델타를 만듬
    sccs-get, get        - SCCS 파일 버전확인
    sccs-help, help      - SCCS 오류나 경고 메시지 검색
    sccs-prs, prs       - SCCS 사용내역의 선택된 부분 보기
    sccs-prt, prt        - SCCS 파일에서 델타 테이블 정보를 봄
    sccs-rmdel, rmdel   - SCCS 파일에서 델타를 지움
    sccs-sact, sact      - SCCS 파일의 편집 상태를 봄
    sccs-sccsdiff, sccsdiff - SCCS 파일들의 버전 비교
    sccs-unget, unget   - SCCS 파일의 미리 얻은 것(?)을 취소한다.
    sccs-val, val       - SCCS 파일 유요화
    script     - 화면 갈무리
    sed       - stream editor
    sh        - 유닉스 표준 쉘
    size       - 오브젝트 파일의 크기들을 보여줌
    sleep     - 지정한 시간 만큼 실행 보류
    sort      - 줄 정열과 검색
    sortbib    - 도서목록형 데이터베이스 정열
    spell, hashmake, spellin, hashcheck - 맞춤범 검사(물론 영어겠지요)
    split      - 파일 나누기
    strings   - 오브젝트 파일이나, 실행 파일에서 문자열 찾기
    strip     - 오브젝트 파일에서 심벌 테이블과 중복된 비트 삭제
    stty     - 터미날 설정
    su      - super-user, 임시적으로 새 ID로 바꿈
    symorder - 심벌 순서 바꿈
    tabs    - 터미날 tab 크기 지정
    tail     - 파일의 끝 부분 보기
    talk    - 다른 사용자와 이야기하기
    tar     - 여러 파일 묶기 또는 묶긴 파일 풀기
    tbl     - nroff 또는 troff의 도표 작성 도구
    tee      - 표준 출력으로 방향 전환
    telnet   - TELNET 프로토콜을 이용한 원격 리모트 호스트 접속
    test     - 주워진 환경이 참인지, 거짓인지를 돌려줌
    tftp     - 간단한 ftp.
    time     - 명령 실행 시간 계산
    touch    - 파일 날짜 관련 부분을 바꿈
    troff     - 문서 양식화 도구
    true, false - 쉘 스크립트에서 사용되는 참/거짓을 리턴하는 명령
    tsort    - topological sort
    tty     - 현재 터미날 이름 보기
    ue      - MICROemacs
    ul      - 밑줄 속성 문자 표현
    unifdef - cpp 입력 줄에서 ifdef 부분 바꾸거나 지움
    uniq   - 중복되는 빈줄 지우기
    units   - 프로그램 변환도구
    uptime  - 시스템 부팅 기간 보기
    users   - 현재 접속 사용자 보기
    uucp, uulog, uuname - 시스템 간의 복사
    uuencode, uudecode - 이진 파일을 아스키파일로 인코딩, 반대로 디코딩
    uusend   - 리모트 호스트에 파일 보내기
    uux     - 리모트 시스템 명령 실행
    vacation  - 자동으로 편지 답장하기
    vgrind   - grind nice program listings
    vi, view, vedit - ex 바탕의 편집기
    vtroff    - 문서 양식화 도구
    w       - 현재 누가 접속해 있으며, 무엇을 하고있는지
    wait     - 프로세스가 마치기를 기다림
    wall      - 모든 사용자에게 알림
    wc       - 단어, 줄, 바이트 계산
    what    - 파일에서 SCCS 버전 정보 알아냄
    whatis   - 명령의 간단한 설명 보여줌
    whereis   - 찾는 명령의 실행파일, 소스, 맨페이지가 어디 있는지 경로를 보여 줌
    which    - 명령만 찾음.
    who     - 시스템에 접속되어 있는 사람만 보여줌
    whoami - 현재 사용하고 있는 자신이 누군지 보여줌
    write   - 다른 사용자의 화면에 특정 내용을 알림
    xargs   - 명령행 인자 처리 명령
    xstr    - extract strings from C programs to implement shared strings
    yacc    - yet another compiler-compiler: 파싱(형태소분석) 프로그램 생성기
    yes     - 항상 yes만 응답하는 명령
    zcat     - 압축 파일 내용보기




    [2]명령어 상세


    adduser
    루트로 로그인해서 이용자를 추가
    $ adduser [ID]


    admin
    SCCS(Source code control system) 파일을 작성 또는 관리를 위한 명령어
    $ admin [-nirtfdaemyhz] files
    -n  : 신규 SCCS 화일을 작성
    -i[name] : 신규 SCCS 화일에 등록된 화일명(name)
    -f  : flag SCCS 화일에 등록하는 플래그들의 값을 지정
    -r  : 번호 초기 델타의 릴리즈 번호 지정은 -i와 함께 사용
    -t[name] : SCCS 화일의 주석문으로 등록되는 화일명(name)
    -e  : login 델타 작성 가능한 사용자 리스트로 부터 삭제되는 로그인명
    -h  : 신규 check sum을 계산하고 기존 check sum과 비교
    -z  : check sum을 계산하여 SCCS 화일에 기록


    alias
    자주 쓰이는 명령어를 쓰기 편하게 바꾸는 명령
    $ alias [새로만들 명령어]='[기존 명령어] [옵션]'


    $ alias cp='cp -i'
    $ alias la='ls $LS_OPTIONS -a'
    $ alias less='less -rf'
    $ alias lf='ls $LS_OPTIONS -F'
    $ alias ll='ls $LS_OPTIONS -l'
    $ alias ls='ls $LS_OPTIONS'
    $ alias mv='mv -i'
    $ alias rm='rm -i'
    $ alias dir='ls -al


    ar
    아카이브 화일에 있는 화일의 그룹들을 유지 관리하는 명령어
    $ ar [-X32_64] [-]{dmpqrstx}[abcfilNoPsSuvV] [member-name] [count] archive-file file...
    $ ar -M [<mri-script]


    d  : delete file(s) from the archive
    m[ab] : move file(s) in the archive
    p  : print file(s) found in the archive
    q[f]  : quick append file(s) to the archive
    r[ab][f][u] : replace existing or insert new file(s) into the archive
    t  : display contents of archive
    x[o]  : extract file(s) from the archive
    command specific modifiers:
    [a]  : put file(s) after [member-name]
    [b]  : put file(s) before [member-name] (same as [i])
    [N]  : use instance [count] of name
    [f]  : truncate inserted file names
    [P]  : use full path names when matching
    [o]  : preserve original dates
    [u]  : only replace files that are newer than current archive contents
    generic modifiers:
    [c]  : do not warn if the library had to be created
    [s]  : create an archive index (cf. ranlib)
    [S]  : do not build a symbol table
    [v]  : be verbose
    [V]  : display the version number
    [-X32_64] : (ignored)


    at
    프로그램을 지금이 아닌 나중에 실행하도록 예약한다.
    $ at [option]
    -q 큐  : 대소문자 알파벳으로 큐를 지정한다. 순서적으로 빠른 알파벳이 지정된 큐 일수록 CPU 시간 점유 우선권이 낮다.
    -r 작업번호 : 큐에서 작업 번호가 지시하는 작업을 지운다. 슈퍼유저가 아니라면 자신의 작업만을 지울 수 있다.
    -l  : 현재 계획된 작업들의 목록을 보여준다. 슈퍼 유저라면 모든 작업들의 계획목록을 보여준다.
    -m  : 작업이 완결되면 사용자에게 메일을 보낸다.
    -f filename : 표준 입력이 아닌 지시된 파일에서 작업을 읽어온다.
      ps- 수행 시간 지정 명령어 -->at 11:30 pm


    awk
    program file에서 기술된 pattern들 중 일치되는 line 을 찾기 위해 입력 화일을 검색하는 명령어
    $ awk [-Fc] [profile] [file] ...
    $ awk [-Fc] [-f profile] [file] ...
    -Fc  : 입력필드의 구분기호로서 c를 이용
    -f  : progam file로서 다음 인수 사용


    background : 하나의 명령을 수행시킨후 그 수행의 종료 이전에 다른 명령을 수행 하는 것
         명령어 끝에 &로 표시 (cc -o test1 test1.c &)


    banner
    인수로 주어진 문자열을 큰 글씨로 만들어서 출력
    $ banner [ -w [숫자] ] 문자열
    -w  : 옵션 지정만 하면 80 칼럼으로 폭을 바꾼다. 지정하지 않으면 132 칼럼으로 내정되어 있다. -w 옵션 뒤에 숫자를 지정하면 원하는 폭으로 조정할 수 있다.


    bang
    '!' 문자를 부르는 말로, C shell에서 '!!'를 명령어 라인에 입력하면, 마지막 명령을 반복하며, Bang!Bang!(뱅뱅)이라고 부른다.


    bash
    bash 셸이 아닌 사용자가 셸을 변경하고자 할 때 사용하는 명령입니다.
    bash셸은 일반적으로 Linux의 기본 셸로 지정되어 있습니다.
    만약 다른 셸을 사용하고 있으면서 bash 셸로 바꾸기 위한 명령은 다음과 같습니다.
    # bash     (enter)'


    bc
    C Language와 유사한 대화식 번역기이며 무제한 정도의 연산을 제공하는 명령어
    $ bc [-cl] [file ... ]
    -c  : compile만 한다
    -l  : 임의 정밀도의 수학 library명을 의미


    bg %1( " ) : 포그라운드로 " " 백그라운드로 전환

    biff
    전자우편의 수신을 즉시 알려주는 동작을 가능하게 할 것인지 그렇지 않은 지의 여부를 보여주거나 결정
    $ biff [ y 혹은 n]

    닉스 셸은 사용중이라도 주기적으로 전자우편의 수신 여부를 점검한다. 만일 사용자가 전자우편이 도착하는 즉시 알고자 한다면
    biff를 사용하여 그것을 지시할 수 있다. 또는 언제라도 그 기능을 해제할 수도 있다. biff는 인수없이 사용되면 현재 어떤
    상태로 되어 있는지 보여준다. 기능 설정과 해제 여부는 y 혹은 n 인수를 주어서 결정한다.


    bzip2
    자료를 압축하기 위한 새로운 알고리즘이다. 보통은 gzip으로 한 것의 60-70%의 크기로 압축한다.
    bzip2는 압축률과 복원률에서 탁월한 성능을 자랑하고 있다. 또한 UNIX 및 WIN32에서 모두 사용할 수 있으며 프로그램은 GNU을 따르므로 누구든지 사용할 수 있다.


    cal
    서기 원년부터 9999년까지의 달력을 볼 수 있다 .
    $ cal [-jy] [ [ 달 ] 연도 ]
    -j  : 1월 1일부터 날짜수를 계산하는 julian 날짜를 표시한다.
    -y  : 올해의 달력을 표시한다.
          cal 9 1995 : unix 시스템에 내장되어있는 달력을 화면에 출력


    cancel [print name] ; 프린터 취소

    cat
    파일의 내용을 표준 출력으로 내보내어, 파일내용을 알아보거나, 여러 파일을 하나의 파일로 출력하여 연결합니다. 또는 표준 입력으로부터 파일을 만들 수도 있습니다.
    $ cat [option] file_name(s)
    -b  : 공백 외의 글자가 있는 모든 행의 개수를 센다.
    -e  : 제어 문자를 ^ 형태로 출력하면서, 각 행의 끝에 $를 추가한다. -vE와 같다.
    -n  : 각 행을 출력하면서 행 번호를 함께 첨부한다.
    -s  : 중복되고 겹치는 빈 행은 하나의 빈 행으로 처리한다.
    -r  : 행바꿈 문자를 제외한 제어 문자를 ^ 형태로 출력한다. -vT와 같다.
    -u  : 유닉스 호환성을 위해 추가된 옵션으로서 무시된다.
    -v  : tab과 행바꿈 문자를 제외한 제어 문자를 ^ 형태로 출력한다.
    -E  : 각 행마다 끝에 $ 문자를 출력한다.
    -T  : 시로서 탭(tab) 문자를 출력한다.
    -A  : -vET 옵션을 사용한 것과 같은 효과를 가진다.


    cat address.list : 파일의 내용을 화면에 출력한다

    cat : 파일을 작성하거나 파일의 내용을 간단하게 출력
      # cat test1.c
      # cat > test1.c


    cc
    C Language를 compile 하는 compiler
    $ cc [option] file
    -c  : compile의 linkage editor 단계를 억제한다
    -E  : 지정된 C program에 대해 cpp만을 실행하고 결과는 표준출력하지 않는다
    -f  : C program에서 부동소수점을 포함하는 코드를 linkage editor시킨다
    -o  : outfile outfile이라는 화일명으로 목적프로그램을 저장하며 생략시는 a.out에 저장
    -s  : C program을 compile 하지만 assemble하지 않으며 어셈블리 언어 출력은 .S가 붙은 화일에 저장
    cc test.c
      -옵션 -r: 이전에 지정된 작업 취소, -l : 지정된 작업 번호 출력
      (sleep 20; cc -o sample sample.c)& -->백그라운드 실행, 20초 뒤 프로그램 컴파일
      (sleep 10; ps -el) --> 10초후 모든 프로세서 상태 출력
      time cc -o test test.c --수행 시간 출력 명령어


    cd
    디렉토리를 변경
    $ cd [directory]
    $ cd cgi-bin : 하부 디렉토리인 cgi-bin으로 들어감.
    $ cd .. : 상위디렉토리로 이동
    $ cd or cd ~ : 어느곳에서든지 자기 홈디렉토리로 바로 이동
    $ cd /webker : 현재 작업중인 디렉토리의 하위나 상위 디렉토리가 아닌 다른 디렉토리(webker)로 이동하려면 /로 시작해서 경로이름을 입력하면 된다.


    chfn
    사용자의 finger 정보를 바꾸는 명령어입니다.

    chgrp
    파일의 그룹 소유권을 바꾼다.
    $ chgrp [option] 그룹_파일들
    -c  : 실제로 소유자가 바뀐 파일에 대해서 자세히 기술한다.
    -f  : 파일의 그룹 소유권을 바꿀 수 없더라도 에러 메시지를 출력하지 않는다.
    -v  : 소유권의 바뀜에 대해서 자세히 기술한다.
    -R  : 디렉토리와 그 내용 파일들의 소유권을 재귀적으로 모두 바꾼다.


    chmod
    화일 permission 제어
    $ chmod [option] [file]
    $ chmod [option] 레벨 동작 권한 파일이름(들)
    -c  : 실제로 파일의 권한이 바뀐 파일만 자세히 기술한다.
    -f  : 파일의 권한이 바뀔 수 없어도 에러 메시지를 출력하지 않는다.
    -v  : 변경된 권한에 대해서 자세히 기술한다.
    -R  : 디렉토리와 파일들의 권한을 재귀적으로 모두 바꾼다.
    참고
    예) -rwxr-xr-x guestbookt.html
    rwx : 처음 3개 문자 = 사용자 자신의 사용 권한
    r-x : 그다음 3개 문자 = 그룹 사용자의 사용 권한
    r-x : 마지막 3개 문자 = 전체 사용자의 사용 권한


    읽기(read)---------- 화일 읽기 권한
    쓰기(write)---------- 화일 쓰기 권한
    실행(execution)------ 화일 실행 권한
    없음(-)------------ 사용권한 없음
    chmod --- 파일 및 디렉토리에 이미 정해진 접근 허가 모드를 변경
      - 사용 형식: %chmod [ugoa] [+-=] [rwx] [file name]
      u: 파일 소유자, g: 그룹, o: 기타 사용자, a: 모든 사용자
      +: 사용허가부여, -: 사용허가박탈, =: 허가 취소
      r: 읽기 허가, w:쓰기 허가, x: 실행 허가
      특정 사용자를 지정하지 않으면 모든 사용자를 의미한다
      chmod go+r test.c ; 소유자 그룹과 기타 사용자에게 읽기 허가
      chmod ugo-w test.c ; 소유자,그룹,기타 사용자에게 읽기 허가 박탈
      chmod +x test.c
      chmod o -rwx test.c
      r = 4, w = 2, x =1
      chmod 744 test.c
      -rwxr--r-- 1 edul user 235 Oct 15 13:23 test.c
      chmod 724 test.c
      -rwx-w-r-- 1 edul user 235 Oct 15 13:23 test.c


    chown
    파일의 소유권을 다른 사람에게로 변경시킨다.
    $ chown [option] [user file]
    -c  : 실제로 파일의 소유권이 바뀐 파일만 자세히 기술한다.
    -f  : 파일의 소유권이 바뀔 수 없어도 에러 메시지를 출력하지 않는다.
    -v  : 변경된 소유권에 대해서 자세히 기술한다.
    -R  : 디렉토리와 파일들의 소유권을 재귀적으로 모두 바꾼다.
    파일의 소유권을 다른 사람에게로 바꾸는 것은 슈퍼 유저만이 할 수 있다.


    chsh
    사용자의 shell을 바꾸는 명령어입니다.


    clear
    화면 지우기


    cmp
    두 개의 파일 내용을 비교
    $ Cmp [option] [file1] [file2]
    -l  : 두 파일 내용을 비교하여 틀린 곳마다 byte수(10진수)와 틀린 byte수(8진수) 출력
    -s  : 비교하여 틀린 내용을 출력하지 않고 return code 만 반환


    comm              
    두 개의 정렬(sort)된 화일에서 공통된 line을 선택하거나 삭제
    $ comm [option] file1 file2
    -1  : file1에만 있는 line을 출력하지 않는다
    -2  : file2에만 있는 line을 출력하지 않는다
    -3  : file1, file2 양쪽 화일에 있는 line을 출력하지 않는다


    compress
    확장자 .Z 형태의 압축파일 생성
    $ compress [file]  : 압축시
    $ uncompress [file]  : 해제시
    compress test.c (파일 압축) --->uncompress test.c.Z (압축 풀기)


    cp
    화일 복사(copy)
    $ cp [option] [file1] [file2]
    $ cp [option] [file1] [directory]
    -a  : 가능한한 원 파일의 구조와 속성을 그대로 복사한다.
    -b  : 복사할 때 덮어쓰게 되는 파일은 백업을 만든다.
    -d  : 심볼릭 링크는 심볼릭 링크로 복사한다. 그리고 원본 파일과의 하드 링크 관계를 유지한다.
    -f  : 복사 위치에 존재하는 파일을 제거하고 복사한다.
    -i  : 복사시 같은 이름의 파일이 존재한다면 덮어쓸 것인가 확인한다.
    -I  : 하드 링크를 만든다.
    -P  : 원본 파일의 소유자, 그룹, 권한, 시간 기록을 그대로 복사한다.
    -r  : 파일과 하위 디렉토리에 포함된 파일 모두를 재귀적으로 복사한다.
    -s  : 디렉토리가 아닌 파일의 심볼릭 링크를 만든다. 소스 파일의 이름은 전체 경로 이름으로 한다. 목적지 파일 이름은 전체 경로를 주지 않아도 현재 디렉토리로 간주되므로 상관없다.
    -u  : 파일의 정보를 갱신한다.
    -x  : 다른 파일 시스템인 하위 디렉토리는 무시한다.
    -R  : 디렉토리를 재귀적(recursive)으로 복사한다.
    cp :시스템내에 있는 특정 파일을 복사
      # mkdir temp --temp라는 디렉토리 생성
      # cp sample test temp --temp라는 디렉토리 밑에 sample 과 test 라는 파일을 복사
      # mkdir example
      # cp -r temp example --temp라는 디렉토리 아래에있는 모든 내용을 example디렉토리에 복사


    cpio
    아카이브 파일을 복사하여 입출력
    $ cpio -o [abcv]
    $ cpio -i [Bdmtuvsb] [patterns]
    $ cpio -p [adlmv] directory
    -o 복사 출력 : 화일을 path명과 정보 상태를 함께 출력
    -i  복사 입력 : 표준 입력 화일로 부터 pattern에 일치하는 화일을 추출
    -p  : *directory 내에 file 을 조건부로 작성하고 복사
    command:
    a  : *file 복사후 입력 화일의 최종 접근 시간을 reset한다
    B  : 입출력을 5,120 byte의 레코드로 블럭화한다
    c  : ASCII 문자로 헤드 정보를 쓴다
    d  : 필요에 따라 directory를 생성
    m  : 존재하는 최종 화일 수정 시각을 보존
    r  : 대화 문법으로 화일명을 변경
    t  : 입력 화일명 목록을 출력하여 화일은 작성되지 않는다
    u  : 무조건 복사
    v  : 화일명 목록을 출력


    crontab
    지정한 화일을 입력으로 받아 user의 크론탭 화일을 관리 및 directory로 복사하는 명령어
    $ crontab [file]
    $ crontab [-u user] file
    $ crontab [-u user] { -e | -l | -r }
    -l  : crontab 파일 목록을 보여준다.
    -e  : 에디터를 사용하여 crontab 파일을 수정한다.
    -d  : 사용자의 crontab 파일을 지운다.
    -u user : 특정 사용자의 crontab 파일을 다루도록 지정한다.
       이 명령을 사용하려면 슈퍼 유저로 로그인해야만 한다.
    crontab 파일 내의 빈 핵과 # 문자로 시작되는 행은 무시된다.
    파일의 각 행은 M H D m d cmd 형태로 되어 있다. 필드의 에스테리스크(*)표시는 어떠한 값이든 일치하는 조건으로 가정한다는 의미이다.


    csh
    유닉스 C 셸이다. 하지만 리눅스에서는 tcsh에 링크되어 있는 파일에 불과하다.


    cu
    다른 system을 호출
    $ cu [options] [system or phone-number]
    -h  : 반이중 모드만을 지원하는 시스템을 호출
    -t  : 자동응답 모드에 설정된 ASCII단말기 호출
    -d  : message 출력
    -o  : 홀수 parity 생성을 지시
    -n  : 전화번호 입력을 요구
    -l  : line 통일 회선 장치명을 지정
    -s  : speed 전송 속도(1200,2400,4800,7200,9600 bps)를 지정


    cut
    파일에서 필드를 뽑아낸다. 필드는 필드 구분자나 문자 위치로 지정된다.
    $ cut -c문자위치 [file1 file2]
    $ cut -f필드 -d필드구분자 [-s] [file1 file2 ...]
    -c문자위치  : 잘라낼 곳의 글자 위치를 지정한다. 콤마를 사용하거나 하이픈을 사용하여 범위를 정할 수도 있으며, 이런 표현들을 혼합하여 사용할 수도 있다.
    -f필드 : 잘라낼 필드를 정한다. 지정하는 방법은 -c 옵션과 같다.
    -d필드 구분자: 필드를 구분하는 문자를 지정한다. 디폴트는 탭 문자다.
    -s  : 필드 구분자를 포함할 수 없다면 그 행은 하지 않는다.


    date: 현재의 날짜와 시간을 화면에 표시
      date;who;cat > sample.c : 한 줄에 두 개 이상의 명령어를 동시에 입력하고자 할 경우 명령어와 명령어 사이를 ; 으로      구분한다
      date > date.out : 이전 내용이 지워지고 새로운 내용이 저장
      * date >> date.out : 이전 내용과 함께 새로운 내용 첨가


    dc
    system을 이용한 탁상계산기
    $ dc [file]
    file  : 읽어들일 화일 지정, 생략시 표준 입력으로 간주


    dd
    다양한 데이타 형식을 가진 화일을 복사, 변환
    $ dd [option = value] ...
    bs=n  : 입출력 블럭의 크기를 n byte로 쓴다
    cbs=n : buffer 크기변환
    conv=ascii : EBCDIC 코드를 ASCII 코드로 변환
    conv=ebcdic : ASCII 코드를 EBCDIC 코드로 변환
    conv=lcase : 알파벳을 소문자로 변환
    conv=ibn : 약간은 다르지만 ASCII 코드를 EBCDIC 코드로 변환
    conv=noerror : 에러처리를 중지하지 않는다
    conv=swab : 두개의 byte를 서로 교환
    conv=sync : 각 입력 레코드를 ibs로 패딩
    conv=ucase : 알파벳을 대문자로 변환
    ...,...  : 컴마로 구분된 여러개의 변환
    count=n : 입력코드를 n개만 복사
    files=n : 복사 시작전에 n개의 화일을 건너뛴다
    seek=n : 복사 시작전에 출력화일의 처음으로 n 레코드를 탐색
    ibs=n  : 입력블럭크기를 n byte로 한다 (디폴트는 512)
    if=file  : 입력화일명(디폴트는 표준입력)
    obs=n : 출력블럭크기를 n byte로 한다 (디폴트는 512)
    of=file : 출력화일명(디폴트는 표준출력)
    skip=n : 복사전에 입력레코드를 건너뛴다 


    df
    이용 가능한 디스크 블록 수 출력
    $ df [-f] [-t] [file sysytem]
    -f  : 디스크내의 자유리스트내의 정확한 블럭수를 출력
    -t  : 사용가능 블럭 및 i-node와 할당된 전체블럭과 i-node가 출력
    -m  : 파일 크기를 Mbyte단위로 출력


    diff
    두 개의 파일 중에서 다른 라인을 출력
    $ diff [option] file1 file2
    -b  : 비교할 때 라인의 마지막에 있는 탭(tab)과 공백을 무시
    -e  : file1으로부터 file2를 재생성. ed 편집을 위한 a,c 그리고 d 명령어의 script를 만든다
    -f  : 비슷한 script를 만들지만 역순이기 때문에 ed 편집에서는 사용할 수 없다
    -h  : 정밀도가 없어도 빠른 속도를 처리하고자 할 때 사용하며 -e와 -f와 함께 사용할수 없다
    -i  : 대소문자를 구분하지 않는다.
    -w  : 탭(tab) 문자를 포함한 모든 공백 문자를 무시하고 비교 작업을 수행한다.


    diff3
    세 개의 파일 중에서 다른 라인을 출력
    $ diff3 [option] file1 file2 file3
    -e  : file1에 file2와 file3의 차이 비교를 기록
    -x  : file1에 3개 화일 모두의 차이 비교를 기록
    -3  : file1에 file3과 차이 비교되는 부분만 기록
    disable -c [print name] ; 지정한 프린터에서 현제 출력중인 작업 취소
      * disable -w laser-3 ; 모두 인쇄한 다음 프린터를 disable 상태로 만든다
      * disable -c -r "out of paper" laser-1 ; 주석을 달아 놓는다


    dmesg
    부팅 메시지를 보여주는 명령어
    Done : 백그라운드 프로세서의 수행이 완전히 종료된 상태


    du
    하드 사용량 체크(chkdsk)
    $ du [option][dirctory, file]
    -s  : 총 합계만을 따진다. 하위 디렉토리의 숫자 등은 나오지 않는다.
    -a  : 크기가 계산된 각 파일의 크기를 보인다.
    -b  : 바이트 크기로 출력한다.
    -x  : 현재 디렉토리에 마운트된 파일 시스템만 검사된다.
    -L  : 심볼릭 링크 자신의 공간 대신 연결된 파일의 크기를 다룬다.


    echo
    외부 프로그램과 내부 쉘명령어 사이에 있으며 echo의 인수는 공백에 의해 구분되어지며 new line으로 종료하는 각 인수를 화면에 표준출력하는 명령어
    $ echo [option] [string]
    -n  : 새로 개행하지 않고 출력하게 한다.
    -e  : 문자열 중에서 백슬래쉬와 조합되는 특수 문자를 인식하게 한다.
                    그러한 특수 문자들은 다음과 같은 것들이 있다.
    \a 밸소리    \b 백스페이스
    \f 용지바꿈(form feed)  \n 행바꿈
    \r 0 칼럼으로(carriage return)  \f 탭(tab)
    \v  수직 탭    \\ 백슬래쉬 문자
    \nnn 8진법으로 표기되는 ASCII 문자 \c 출력 후 행바꿈 금지


    ed
    풀 스크린 에디터를 사용할 수 없는 열악한 환경의 터미널을 위한 라인 에디터
    $ ed [-] [-s] [-p문자열] [file]
    -  : e, r, w, q, ! 명령에 의해 발생하는 메시지를 금지한다.
    -s  : 검사 작업을 금지한다.
    -p문자열 : 프로프트를 원하는 문자열로 바꾼다.


    edquota
    사용자의 하드디스크 용량 및 파일의 개수를 제한한다.
    $ edquota [option] [ID]
    -n  : 쿼터 할당을 림트 서버에 할 수 있다.
    -u  : 사용자를 정희한다. (기본값)
    -p  : 사용자 그룹에 제한을 주기위한 옵션
    -t  : 파일시스템의 soft time의 제한 값을 정한다. 디폴트 값은 /linux/quota.h를 따른다.


    env
    현재의 환경에 영향을 주지 않고 원하는 환경을 만들어 명령을 실행, 또는 현재의 환경 보고
    $ env [-][-i ][-u 이름][name=value][command arg]
    -  : 뒤에 오는 이름=값 목록으로 환경을 제한한다.
    -i  : 현재의 환경을 무시하고 빈 환경 상태로 시작한다.
    -u 이름 : 현재의 환경에 그 이름의 변수가 있다면 제거한다.
    -name=value : 명령 수행 전의 원래 환경을 지정
    -command arg: 수행하고자 하는 명령어 지정


    ex
    ed 기능을 강화한 텍스트 편집기
    $ ex [-] [-trRV] [+command] name ...
    -  : 대화형 사용자를 위해 feed-back을 억제
    -t  : tag tag를 갖는 화일을 편집후 편집기를 그 화일의 위치에 지정
    -r  : file file을 복구
    R  : 읽기 허가만 된 모드로 한다
    + command : 지정한 명령어를 수행하고 편집


    exit
    현재의 프로세스를 종료하고 빠져나감
    Exit : 백그라운드 프로세서가 수행도중 오류 때문에 빠져 나온 상태


    fdformat
    플로피 디스켓을 포멧한다
    $ fdformat [device]


    fg
    후면 작업을 전면 작업으로 전환
    $ fg [%작업번호]
    fg %1(작업 번호) : 백그라운드로 수행중인 작업을 포그라운드로 전환


    fgrep
    문자열에 따라 파일 검색
    $ fgrep [option] string [file]
    -b  : 각 행의 선두에 그 행이 발견된 블럭번호를 넣어줌.
    -c  : 일치하는 패턴을 갖고 있는 행의 수 만을 출력함.
    -l  : 일치하는 행이 있는 화일의 화일명만을 복귀개행으로 구별시켜 출력하는데, 화일내에 패턴이 몇 개나 포함되어 있어도 화일명은 한 개밖에 출력하지 않음.
    -n  : 각 행의 선두에 화일내의 행번호를 넣음.(1 라인은 1임)
    -i  : 비교시 소문자와 대문자의 차이를 무시
    -v  : 일치하는 행을 제외한 모든행을 출력.


    file
    파일이 어떤 형태의 파일인지 알아낸다.
    $ file [option1][option2] file
    -c  : 매직 파일의 파생된 형태를 보여준다
    -z  : 압축되어 있는 파일의 형태를 검사
    -l  : 뒤따르는 심볼릭 링크를 야기 시킴
    -f 파일명 : 검사한 파일에 대해 리포트를 만들 파일의 이름을 지정
    -m 파일명 : 파일의 형태를 결정하는 데에 사용되는 매직 파일을 정함
    file < test > test.out : test 파일을 입력으로 받아서 file 명령을 실행하고 test.out에 출력
      file test.c : test.c라는 파일의 형태를 출력


    find
    원하는 특정 파일이나 디렉토리를 탐색하여 찾는다.
    $ find path_list expression!


    Expression!s
    -name 파일명 : 찾고자 하는 파일의 이름을 정한다. 와일드 카드도 가능하다.
    -perm 모드 : 파일권한(permission)이 일치되는 것을 찾는다. 원하는 권한은 ls로 볼 수있는 형태와 같이 지정한다.
    -type ? : 형태가 같은 파일을 찾는다. 물음표(?) 부분에 디렉토리는 d, 파이프는 p, 심볼릭 링크는 l, 소켓은 s, 블록 파일은 b, 일반 파일은 f 등의 기호를 사용한다.
    -links ? : 특정 개수의 링크를 가진 파일을 찾는다. 물음표 부분에 링크의 숫자를 표기한다.
    -size ? : 파일의 크기가 일치하는 것을 탐색한다. 파일 크기는 블록단위로 물음표 부분에 지정한다. 한 블록은 512바이트로 내정되어 있지만 블록 숫자 뒤에 단위로 k자를 붙이면 1키로바이트 크기의 블록 숫자로 간주된다.
    -user 사용자 : 파일 사용자의 ID에 따라서 검색한다. 로그인 이름이나 번호 모두가 가능하다.
    -atime ? : 최근 며칠내에 엑세스한 파일을 검색한다. 날짜수는 ?에 명시한다.
    -exec 명령 : 원하는 검색 조건에 맞는 파일을 찾으면 명시된 명령을 실행한다. 명령의 끝은 \;을 사용하여 끝낸다. find가 검색해낸 파일의 이름을 인수로 사용하고 싶다면 그 위치에 {}를 사용한다.
    -newer 파일 : 어떤 파일보다 최근에 갱신된 모든 파일을 검색한다.
    -cpio device : 현재의 화일은 cpio(1)의 문법(5120byte 레코드)으로 장치에 써넣는다
    -ctime n : 화일이 n 날짜내에 변경되면 참
    -group gname: 화일에 gname에 포함되어 있으면 참
    -mtime n : 화일이 n 날짜 이내에 수정되면 참
    -ok cmd : 명령어 라인을 의문부호를 선두에 부과하여 화면에 출력하며 만약 사용자가 y를 칠 경우에만 실행 가능
    find: 사용자가 지정한 특정 범위에 해당하는 모든 파일을 검색
      # find / -name test1.c -print ; 최상위 루트 디렉토리부터 검색하여 검색된 파일을 한 행에 하나씩 표준 출력
      # find . -name test1.c -print ; 현제의 작업 디렉토리에서 검색
      # find / -size +1000 -print ; 최상위 루트에서 크기가 1000블록 이상인 파일 검색
      # find . -size -1000 -print ; 현 디렉토리에서 크기가 1000블록 이하인 파일 검색
      # find . -mtime +10 -print ; 10일 이전에 수정된 파일 검색
      # find . -mtime -10 exec rm {} \: ; 10일 이내에 수정한 파일을 검색하여 모두 지운다


    finger
    시스템 상의 사용자들에 대한 정보를 보여준다.
    특정 사용자에 대한 정보를 알려면 finger username(또는 사용자가 다른 컴퓨터에 있으면 finger
    username@domain)을 입력한다.
    $ finger [option] [user]
    -s  : 사용자의 로그온 이름, 실제이름, 터미널 이름, 로그온 시간 등등을 보인다.
    -l  : -s 옵션 정보에 몇 가지를 추가하여, 여러 줄에 걸쳐서 보여준다.
    -p  : -l 옵션 정보에서 .plan과 .project 파일을 보이지 않는다.


    foreground : 하나의 명령이 실행되어 결과를 출력할때까지 다른 명령을 수행 할 수 없다

    free
    메모리의 사용상태와 남은 상태, 버퍼의 상태등을 보여줌


    fsck
    파일 시스템의 완전한 상태를 유지하고 있는가를 검사하고, 잘못된 것은 수정한다.
    $ fsck [option] [file system]
    -f  : 빠른 속도로 블록과 크기 및 자유리스트를 점검
    -n  : fsck 명령 수행중에 모든 질문에 대해 no라 응답한다.
    -y  : fsck 명령 수행중에 모든 질문에 대해 yes라 응답한다.


    -a  : 검사도중 발견된 에러를 자동적으로 복구한다.
    -r  : 검사도중 에러가 발견되면 복구할 것인가를 물어온다. 이것은 하위 호환성을 위한 것으로서 사실상은 사용되지 않는다.
    -s  : 병렬적인 방법이 아니라 순차적인 방법으로 검색한다.
    -V  : 검색중 각종 정보를 자세하게 보여준다.
    -N  : 실제로 검사 작업을 하지는 않도록 한다.


    grep
    파일 중에서 어떠한 패턴을 검색합니다.
    $ grep [option] expression! [file]
    -A  : [숫자] 라인에서 패턴과 매치되는 문자열을 찾아서 그 이상의 라인을 전부 보여줍니다.
    -B  : [숫자] 라인에서 패턴과 매치되는 문장열을 찾아서 그 이하의 라인을 전부 보여줍니다.
    -b  : 매치되는 라인과 그 크기(bite)를 출력합니다.
    -c  : 매치되는 개수를 출력합니다.
    -f  : 파일로부터 패턴을 입력받아 들입니다.
    -n  : 매치되는 라인과 그 라인수를 출력합니다.
    -v  : 매치되지 않는 라인을 출력합니다.
    -w  : 주어진 단어와 완전히 매치되는 라인을 출력합니다.
    -l  : 매치되는 내용이 있는 파일의 이름만을 표시한다.
    -h  : 매치되는 내용을 찾은 파일의 이름을 표시하지 않는다.
    -i  : 대소문자 구분을 하지 않는다.
    -e expression! : 표현이 하이픈 문자로 시작될 때 사용한다.
    -f file  : 규칙적인 식(grep) 또는 리스트열(fgrep)이 화일로부터 취한다
    -s  : 읽지못하는 화일이거나 존재하지 않는 화일에 대한 에러 메세지 출력을 억제
    grep [option] 형태 [화일명] -- 정규식을 이용 패턴 지정
      # grep -i tom sample.c -- sample.c 라는 파일에서 tom 이라는 문자열을 대소문자 구분 없이 검색
      # grep -n tom sample -- 행 번호와 함께 출력
      # grep -i "tom is" sample -- 공백은 " "로 표기
      # grep -v tom sample --tom이라는 형태를 포함하지 않는 행을 출력
      # cat sample
      computer science
      computer graphics
      # cut -c10-17 sample -- sample 파일에서 칼럼 단위10-17을 절단 --> science/graphics
      # cmp test1 test2 -- 서로 다른 두 파일을 비교
      # dircmp test test -- 서로 다른 두 디렉토리 비교


    groupadd
    그룹 이용자를 추가하는 명령어.


    gpasswd
    group의 사용자나 관리자를 추가, 또는 삭제할 때 쓴다.
    root또는 관리자만이 group member를 추가, 삭제할 수 있다.
    $ gpasswd [-r|-R] group
    $ gpasswd [-a user] group
    $ gpasswd [-d user] group
    $ gpasswd [-A user,...] [-M user,...] group


    gzip
    파일 압축(확장자 .gz, .z 형태의 압축파일 생성)
    $ gzip [파일명] : 압축시
    $ gzip -d [파일명] : 해제시
    gzip은 tar파일을 압축하는데 사용하는 명령어로 1단계에서 9단계로 압축률을 조정할 수 있다. 6단계를 사용하면 적절한 압축률로 압축할 수 있고 압축하는데 시간을 줄일 수도 있다.


    halt
    신속하게 system을 정지시키는 명령어


    hd
    16진수로 파일을 덤퍼하는 명령어(od참조)
    $ hd [-bcdox] [file] [[+[x]] offset [.] [b]]


    head
    파일의 처음 n개의 내용을 보고자 할때 사용하는 명령


    help
    system 명령어에 대한 설명과 메시지에 대한 정보를 On-line 으로 제공
    $ help [args]


    history
    작업 내역을 보여줌


    hostname
    현재 설정되어 있는 호스트의 이름을 표시하거나 변경한다.
    $ hostname [name of host]

    -i : 서버의 ip를 알려준다.

    id
    시스템에 등록된 ID를 확인한다.
    $ id [option]
    -g  : 그룹 ID만을 출력한다.
    -G  : 추가 그룹들만을 출력한다.
    -n  : ID 번호대신 이름으로 출력한다.
    -r  : 실제 사용자나 그룹 ID를 출력한다. 다른 옵션과 함께 사용한다.
    -u  : 사용자의 ID만을 출력한다.


    ifconfig
    네트워크 정보 표시
    $ ifconfig [네트워크명]


    ipcs
    process 상호간의 통신에 대한 상태를 출력하는 명령어
    $ ipcs [option]
    -c  : 사용자의 로그인 명과 그룹명을 출력
    -o  : 사용 상황 상태에 대한 정보를 출력
    -p  : 프로세서 번호에 대한 정보를 출력
    -q  : 수행중인 메세지 큐(Queue)에 대한 정보를 출력
    -t  : 시간에 대한 정보를 출력


    ispell
    영어 단어의 철자를 확인
    $ ispell [option] [file(s)]
    파일 이름을 써주면 해당 파일의 단어를 검사하며, 파일 이름없이 실행시키면 표준 입력의 단어를 체크합니다. 해당하는 단어가 없을 때는 비슷한 단어들의 리스트를 보여줍니다.


    install
    파일을 갱신하고 이진 파일로써 인스톨하기 위해 makefile에서 종종 사용되는 유틸리티


    jobs
    현 터미널에서 수행된 작업들을 간략하게 나열해 준다.
    $ jobs [-lnprs] [jobspec ...] or jobs -x command [args]
    -l  : 프로세서 번호를 추가해서 보여준다.
    jobs : 백그라운드로 수행중인 모든 프로세서의 상태 출력


    join
    두 개의 정렬된 파일을 하나로 수평 병합한다.
    $ jobs [option] [file1] [file2]
    -an  : 첫 번째나 두 번째 파일로부터 일치하지 않는 것도 처리, n은 1이나 2
    -e 문자열 : 비어 있는 필드는 문자열로 대체
    -j n m : 파일 n의 m번째 필드를 두 파일에 병합
    -o file : 명시된 파일의 형태에 따라서 출력을 만듬
    -t 문자 : 필드 구분 as자를 정한다. 기본적으로 공백, 탭, 개행 문자
    -v file : file1이나 file2의 짝이 연결되지 않는 행을 지정된 파일로 출력


    joe
    emacs에 기초한 텍스트 에디터
    kernel; 생성되는 프로세스마다 PCB 부여하고 관리


    kill
    프로세스를 강제 종료하는 명령어
    $ kill [-signal number] process id
    $ kill -l : 시그널 종류를 나열한다. 시그널의 종류는 시그널 번호 순서대로 이름으로 나열한다.
    1 hang up     2 인터럽터   3 정지
    4 정확하지 않는 명령    5 trace trap   6 IOT
    7 EMT    8 부도소수점 expression! 발생  9 강제 종료
    10 버스 에러     11 세그먼트 위배  12 bad system 콜
    13 읽는 사람없이 파이프에 써 넣음  14 경보 신호    15 Software 종료
    kill [번호] -- 프러세서 강제 종료 명령어
      * 강제 종료가 안될 경우 -9옵션을 사용 %kill -9 1239


    killall
    system내에 활동중인 모든 프로세서를 강제로 종료하는 명령어


    last
    시스템에 마지막으로 접근한 사용자를 표시
    $ last [option]
    -f  : 파일명을 참조하여 출력합니다.
    -t  : tty로 로그인한 터미널을 추적합니다.
    -v  : 로그인한 연도를 추가해서 출력합니다.


    less
    more와 유사하게 페이지 단위로 문서를 보여준다. 문서의 앞으로 이동하는 것이 가능
    $ less [option] file
    -?  : less에서 사용할 수 있는 명령들에 대한 도움말을 제공한다. 이 옵션이 사용되면 다른 인수는 무시되고, 도움말 화면을 보여준다.
    -a  : 마지막 라인이 화면에 출력되고 나서 탐색을 시작한다.
    -c  : 필요할 때 전체 화면은 다시 갱신한다.
    -C  : -c 옵션과 같지만 갱신할 때 화면 전체를 지우고 시작한다.
    -e  : 두 번째로  파일의 끝에 도달하면 자동적으로 종료한다.
    -E  : 파일의 끝에 도달하기만 하면 자동적으로 종료한다.
    -i  : 대소문자를 구분하여 탐색한다.
    -n   : 행번호를 추가한다.
    -q  : 특정 에러가 발생하지 않으면 아무 소리도 내지 않고 조용히 동작한다.
    -Q  : 결코 아무 소리도 내지 않는다.
    -s  : 연속되는 공백 라인은 하나의 행으로 처리한다.
    -x 숫자 : 수치를 지정해서 탭 간격을 조정한다. 기본값은 8이다.


    link / unlink
    file 및 directory 링크 / 링크해제  명령
    $ (un)link file1 file2


    ln
    실제 file을 file name에 연결시키는 명령
    $ ln [-s] file_name1 file_name2
    $ ln file_name(s) directory
    -s  : 하드 링크 대신 심볼릭 링크를 만듬
    ln test1 test2 --- test1과 test2라는 2개의 파일을 연결 (unlink ; 연결 해제)


    locate
    저장 위치를 찾아줌


    login / logout
    자신을 식별하고 시스템에 대한 액서스를 얻기 위해 사용하는 명령
    $ logiin [option] ID
    -f  : 뒤의 사용자명으로 로그인
    -g  : 뒤의 그룹사용자명으로 로그인


    longname
    현재 시스템에서 자신이 사용하는 로그온 이름을 보여줌


    lp
    특정 file / 정보를 프린터로 출력하는 명령어
    $ lp [options] files
    -c  : 프린터가 끝나기전에 화일 변경이 가능하도록 프린트할 화일을 복사
    -d dest : 프린터 또는 프린터 클라스를 dest로 지정
    -m  : 프린트 후 전자우편을 보낸다
    -n number : 프린트 할 매수를 지정
    -s  : 메세지 출력을 억제
    -w  : 프린트 후 사용자의 단말장치에 메세지를 보낸다


    lpadmin
    스풀 프린터 시스템 구축 명령어
    $ lpadmin [options]
    -d dest : 기존 dest를 신규 시스템의 생략시 수신자로 한다


    lpstat
    출력되는 라인 프린터의 상태에 대한 정보를 화면에 나타내는 명령어
    $ lpstat [option]
    -a list  : 프린터나 클라스의 처리 상태 출력
    -c list  : 클라스명과 멤버 출력 이때 list는 프린터명 또는 클라스명의 리스트
    -d  : lp에 대한 system을 생략시 주소를 출력
    -o list : 출력 request의 상태 출력 이때는 프린터명,클라스명,request id 리스트
    -p list : 프린터 상태 출력 이때 리스트는 프린터명
    -r  : 라인 프린터 scheduler 상태 출력
    -t  : 프린터의 모든 상태 출력
    lpstate : 프린터의 현제 상태 (활성화: enable, 비활성화: disable)
      * lp -c temp.c ; 내용이 변경되어도 문제가 지속되지 않도록미리 출력될 파일을 복사
      * lp -n7 /etc/lp/temp ; 7장 프린트
      * lp -m temp.c ; 출력이 끝난후 사용자에게 전자우편을 보냄
      * lp -t"chon bing hee" test.out ; chon bong hee라는 표제를 달아 줌


    ls
    directory의 내용을 화면에 출력하는 명령어
    $ ls [option] file..
    -a  : .file을 포함한 전 entry를 출력
    -A  : -a option과 유사하지만 .또는 ..을 포함하는 화일은 출력 억제
    -c  : 마지막 변경된 i-node의 시간을 출력
    -C  : 멀티칼럼으로 출력하며 디폴트로는 CRT에 출력
    -d  : directory명만 출력하며 내용은 출력하지 않는다
    -D  : directory만 출력
    -f  : 인수를 directory로 해석하며 각각의 슬롯에 있는 directory 및 file명을 출력
    -F  : system에 있는 화일이 directory면 /를 실행가능한 화일이면 *를 붙인다
    -g  : 옵션 -l과 같으나 소유자명이 출력되지 않는다
    -i  : 첫 칼럼에 i-number를 출력
    -l  : 화일 및 directory 상태 정보를 long 문법으로 출력
    -m  : 스트림 문법의 출력
    -n  : 소유자명과 그룹명 대신에 UID 번호와 GID 번호가 출력되는 것을 제하고는 옵션 -l과 같다
    -g  : 비도형문자를 ?문자로 출력
    -r  : 화일명이나 수정시간을 알파벳 또는 오래된 역순으로 출력
    -R  : 발견되는 sub-directory의 내용을 순환적으로 출력
    -s  : 간접블럭을 내포하는 블럭수를 출력
    -t  : 화일명 대신에 수정된 시간으로 분류
    -u  : -t 또는 -l option으로 분류하는 중에서 최종접근 시간을 사용
    ls: 현재 위치한 디렉토리 아래에 있는 파일 및 서브디렉토리의 정보를 나열
      - 옵션: -l: 파일의 모든 정보 출력
      -c: 최근 변경한 시간 순서데로 출력
      -d: 디렉토리 명만 출력
      -F: 파일의 특성을 출력( /디렉토리 *실행화일)
      -a: dot(.)으로 시작하는 파일의 이름을 포함한 모든 내용을 출력


    mail
    사용자들간에 전자우편을 주고 받는 명령어
    $ mail
    ID@domain_address
    $ mail [-f file] [-par]
    -f file  : 지정한 화일을 전자우편 화일로 한다
    -p  : 조치를 위한 prompt를 나타내지 읺고 전자우편을 출력
    -g  : 인터럽터를 건후에 종료
    -r  : 메세지를 FiFo(선입선출)방식으로 한다


    mailx
    대화형 메시지 처리를 하는 명령어
    $ mailx [option] [name ...]
    -e  : 전자우편이 있는가 없는가를 조사
    -f[file name] : mailbox 대신에 화일명에서 메세지를 읽는다
    -F  : 메세지를 최종 수신자명이 붙어 있는 화일에 기록
    -S  : subject 종속 헤드필드를 subject로 한다
    -U  : user 사용자의 mailbox를 읽어낸다


    man
    원하는 명령어의 사용방법을 검색하여 보여주는 명령어
    $ mailx [option] [chapter] title ...
    -k  : 인수로 주어진 단어를 키워드로 사용하여, 해당 키워드가 발견되는 모든 매뉴얼의 내용을 검색
    man date : 예약어나 명령어에 대한 온라인 매뉴얼


    mcd
    MSDOS 시스템으로 현재 사용하는 디렉토리 장소로 이동
    $ mcd [dos directory]


    mcopy
    MSDOS file system으로 or DOS file system의 file을 복사
    $ mcopy [option] file_name1 file_name2
    -t  : 텍스트 파일 복사시 CR/LF 문자를 \n 하나로 바꾼다.
    -n  : 파일을 덮어쓰게 되는 경우에도 경고하지 않는다.
    -v  : 자세히 안내문을 보여준다.
    -m  : 파일 갱신 시간을 보존한다.


    mdel
    MSDOS file system에서 file을 제거
    $ mdel [-v] file
    -v  : 진행되는 상황을 자세히 보여줌


    mdir
    MSDOS directory의 목록을 보여준다.
    $ mdir [-w] file
    -w  : 파일 크기나 생성 날짜는 제외하고 넓은 형식으로 보여줌


    mesg
    teminal에 들어오는 메시지를 허가 또는 거부하는 명령어
    $ mesg [n] [y]
    n  : 메세지 거부
    y  : 메세지 허가


    newgrp
    현재 그룹 ID를 변경한다.


    mfs
    모든 file system을 mount 하는 명령어


    mkdir
    directory 생성
    $ mkdir [-m mode] [-p] directory
    -m  : 디렉토리를 만들 때 같이 사용하여 사용자 권한을 줄수 있다.
    -p  : 만들 디렉토리의 상위 elfprxhflRK지 한꺼번에 만든다.
    mkdir : 디렉토리 생성 명령어 (%mkdir [option] [directory name]


    mknod
    특수화일을 위해 directory와 이에 i-node를 만드는 명령어
    $ mknod file [b] [c] major minor
    b  : 특수화일이 블럭형
    c  : 특수화일이 문자형
    major  : 주장치 번호
    minor  : 부장치 번호


    mkswap
    swap 공간 생성


    more
    한 화면씩 출력을 보여주는 유틸리티
    $ more [ -ncdflspu ][ +줄번호 ][ 파일이름(들) ]
    -n  : 여기서 n은 숫자를 의미하여, 숫자는 출력 윈도우의 행수를 지정한다.
    -c  : 위에서부터 한 행씩 지운 후 한 행씩 출력한다. 보통은 화면 전체를 지운 후 각 행을 출력하기 시작한다. 특정한 터미널을 위해 사용한다.
    -d  : 스페이스나 q 키를 누르라는 프롬프트를 출력한다.
    -f  : 화면의 행이 아닌 논리적인 행 수를 계산한다. 보통은 긴 칼럼의 행은 화면에서 행바꿈을 하여 새로운 행으로 계산된다. -f 옵션을 사용하면 이러한 행은 계산하지 않는다.
    -s  : 여러 개의 빈 공백행은 하나로 취급한다.
    -p  : 스크롤하지 않는다. 대신 화면을 지우고 출력한다.
    -u  : 밑줄 차기를 금지한다.


    설명
    more 명령은 몇 가지 명령을 인식할 수 있다. 스페이스 바를 누르는 것을 포함해서 다음과 같은 조작을 하는 것이 가능하다.
    ■ <return> : 한 줄만 스크롤된다.
    ■ D        : 반 페이지만 뒤로 이동한다.
    ■ <space> : 한 페이지만 뒤로 이동한다.
    ■ B  : 한 페이지 앞으로 이동한다.
    ■ H  : 도움말을 제공한다.
    ■ V  : vi 에디터를 부른다. 에디터를 종료하면 원 위치로 돌아간다.
    ■ Q  : more 를 종료한다.


    more [file name] : 한 번에 한 화면씩 파일의 내용을 표준 출력
      -내용을 보지 않고 종료시 q 나 Q 키를 누른다


    mount
    다른 파티션의 디스크나 물리적으로 다른 rldr 장치를 파일 시스템으로 연결
    $ mount [option] 장치명 디렉토리
    -v  : 마운트 작업을 수행하면서 자세한 정보를 출력한다.
    -w  : 마운트되는 파일 시스템을 읽기와 쓰기가 가능하도록 한다.
    -r  : 마운트되는 파일 시스템이 읽기 동작만 가능하도록 한다.
    -n  : 마운트 정보가 기록되는 /etc/rntab 파일에 정보를 기록하지 않는다.
    -a  : /etc/fstab 파일에 있는 모든 파일 시스템을 마운트하도록 한다.
    -t 형태 : 마운트되는 파일 시스템의 형태를 지정한다.


    mountall
    여러개의 file system을 mount하는 명령어
    $ mountall [-] file system
    $ mountall [-k]
    -  : 입력되는 데이타가 표준입력
    -k  : 화일을 open시키고 프로세서를 찾은 다음 SIGKILL 시그널을 보낸다


    Multitask

    mv
    파일의 위치를 이동하거나 파일의 이름을 바꾸어 준다.
    $ mv [ -fi ] 파일명1 파일명2
    $ mv [ -fi ] 파일명(들) 디렉토리명
    -f  : 같은 이름의 파일이 존재하고 쓰기 권한이 금지되어 있더라도 물어 보지 않고 덮어쓰기를 해버린다. 이런 경우 이 옵션을 사용하지 않으면 사용자에게 다시 확인을 할 것이다.
    -i  : 파일을 덮어쓰기 전에 사용자에게 확인한다.
    mv [file name1] [file name2] --file name1을 file name2로 이름 변경
    mv [file1] [file2] [directory1] --file1, file2를 directory1으로 이동
    mv [directory1] [directory2] --directory1의 모든 내용을 directory2로 이동
      **명령어 cp, mv, rm에서 option -i는 사용자에게 여부를 묻는 옵션입니다


    mvdir
    file system 내에서 directory 변경을 하는 명령어
    $ mvdir [oldname] [newname]


    nice
    프로세스의 순위를 변경하는 명령어
    $ nice command -n XX
    nice
    값은 -20에서 19까지 있는데, 값이 작을수록 우선 순위가 높습니다. -n옵션을 쓰기 않으면 디폴트로 10이 쓰입니다. 일반
    유저는 nice값을 증가시킬 수밖에 없지만 root는 nice값을 감소시켜 우선 순위를 높을 수도
    있습니다.               
    nice [-정수값:1~39 , 20으로 설정] 명령어 -->우선 순위 변경 명령어
      정수값이 높을수록 우선 순위가 낮다 (nice -10 cc -o test test1.c)


    nl [file name] : 지정한 파일의 내용을 츨력할 때 맨 앞에 행 번호를 이어서 출력

    nohup cc -o sample1 sample1.c & 1132[PID번호]
        백그라운드로 실행, 로그 아웃이나 중지 신호후에도 프로세서의 수행 계속

    nslookup
    네임 서버를 조회한다.
    $ nslookup [option] [host or IP Address] [name server]
    -q=A  : IP Address
    -q=MX : 메일서버 확인
    -q=NS : 네임서버 확인
    -q=CNAME : 호스트의 앨리어스
    -q=PTR : 호스트 또는 포인터명
    -q=SOA : Statt of Authority 정보


    od
    8, 10, 16진 또는 파일의 ASCII 덤프를 만들기 위한 명령어
    $ od [option] file
    -b  : 바이트를 8진수로 출력
    -c  : 바이트를 아스키 문자로 출력
    -x  : 바이트를 16진수 워드 단위로 출력


    pack test.c (파일 압축) ---> unpack test.c.z


    page [option] [file name] : 한 번에 한 화면씩 파일의 내용을 표준출력(=== %pg)

    passwd
    자신의 패스워드를 관리하는 명령어
    $ passwd [user]
    암호화 되어 /etc/passwd 파일에 놓여집니다.
    암호는 최소한 6자 이상이어야 합니다(8자 이상 권장).
    암호는 구두점 기호와 숫자뿐만 아니라 대소문자를 모두 포함해도 됩니다.


    paste
    하나 혹은 그 이상의 파일로부터 칼럼 형태의 출력을 만든다. cut과 함께 사용
    $ paste [-s] [-d 구분문자] file_name(s)
    -s  : 각 file을 순회하면서 paste를 수행한다.
    -d 구분문자 : 어떠한 문자로 칼럼을 구분하는지 지정. 기본값은 탭 문자


    pico
    UNIX용 에디터


    pine
    PINE 4.10   MAIN MENU                            Folder: INBOX  19 Messages


              ?     HELP        -  Get help using Pine
              C     COMPOSE MESSAGE  -  Compose and send a message
              I     MESSAGE INDEX -  View messages in current folder
              L     FOLDER LIST         -  Select a folder to view
              A     ADDRESS BOOK       -  Update address book
              S     SETUP               -  Configure Pine Options
              Q     QUIT                -  Leave the Pine program
        Copyright 1989-1999.  PINE is a trademark of the University of Washington.
                       [Folder "INBOX" opened with 19 messages]
    ? Help                     P PrevCmd                 R RelNotes
    O OTHER CMDS > [ListFldrs] N NextCmd                 K KBLock
    메일을 주고 받을 수 있는 명령


    ping
    자신의 네트워크나 다른 네트워크가 통신이 잘되고 있는지 점검함
    $ ping hostname


    ps
    프로세서들의 상태를 점검하는 명령어
    $ ps [options]
    -l  : 자세한 형태의 정보를 출력한다.
    -u  : 각 프로세서의 사용자 이름과 시작 시간을 보여준다.
    -j  : 작업 중심 형태로 출력한다.
    -s  : 시그널 중심 형태로 출력한다.
    -v  : 가상 메모리 중심 형태로 출력한다.
    -m  : 메모리 정보를 출력한다.
    -a  : 다른 사용자들의 프로세서도 보여준다.
    -x  :
    로그인 상태에 있는 동안 아직 완료되지 않은 프로세서들을 보여준다. 유닉스 시스템은 사용자가 로그아웃하고 난 후에도 임의의
    프로세서가 계속 동작하게 할 수 있다. 그러면 그 프로세서는 자신을 실행시킨 셸이 없이도 계속 자신의 일을 수행한다. 이러한
    프로세서는 일반적인 ps 명령으로 확인할 수 없다. 이때 -x 옵션을 사용하면 자신의 터미널이 없는 프로세서들을 확인할 수 있다.
    -S  : 차일드(child) CPU 시간과 메모리 페이지 결함(fault) 정보를 추가 한다.
    -c  : 커널 task_structure로 부터 명령 이름을 보여준다.
    -e  : 환경을 보여준다.
    -w  : 긴(wide) 형태로 출력한다. 한 행 안에 출력이 잘리지 않는다.
    -h  : 헤더를 출력하지 않는다.
    -r  : 현재 실행중인 프로세서를 보여준다.
    -n  : USER 와 WCHAN 을 위해 수치 출력을 지원한다.


    설명
    기본적으로 ps는 현재 명령이 내려지는 셸에서 만들어진 프로세서들의
    목록만을 보여준다. ps는 자신이 실행되는 당시, 현재의 셸에 의해서 수행된 프로세서들을 검사하고 보고한다는 점을 생각하자.
    그러면 ps의 출력결과 리스트에 ps 자신이 있는 이유를 쉽게 이해할 수 있을 것이다. 각 필드의 의미는 다음과 같다.


      COMMAND : 명령어의 이름
      PID  : 프로세서 ID, 각 프로세서를 구분하기 위한 고유의 ID
      RSS  : 프로세서에 의해 사용되는 실제 메모리의 용량(K byte 단위)
      USER : 프로세서를 실행시킨 소유자의 계정을 보여준다.
      SZ  : 프로세서의 자료와 스텍 크기의 (K byte 단위)
      TIME : 현재까지 사용된 CPU의 시간(분,초)
      TT  : 프로세서의 제어 터미널(t3=/dev/tty3)
      %CPU : 마지막 분동안 프로세서가 사용한 CPU시간의 백분율
      START : 프로세서가 시작된 시간
      STAT : 프로세서의 상태


    이중 STAT 필드는 몇 가지의 부호를 사용해서 프로세서의 상태를 표시하고 있다. 그것들을 정리해 보면 다음과 같다.

      P  : 수행 가능/수행중
      T  : 일시 정지
      D  : 디스크 입출력 대기 같은 인터럽트할 수 없는 대기상태
      S  : 20초 미만의 짧게 잠듦(sleep)
      I  : 20초 이상의 길게 잠듦
      Z  : 좀비(zombi) 프로세서


    좀비(zomb) 상태라는 것은 프로세서가 사라질 때 시그널 처리의 문제로 완전히 소멸되지 못한 상태를 말한다.
    ps -l --프로세스에 관한 모든 상태 정보 출력
      ps -e --현제 실행중인 모든 프로세스에 관한 정보 출력
      ps ps -t 00 --지정된 터미널에서 실행중인 프로세스에 관한 정보 출력


    pstree
    프로세서의 트리구조를 출력한다.


    pwd
    현재 작업하는 디렉토리를 알기 위해서 pwd 명령을 사용한다.
    print working directory, 현재 작업 Directory를 출력한다.
    pwd : 현제 작업 디렉토리 출력 명령어


    quota
    계정에 할당된 사용량을 확인한다.
    $ quota [-vq] [[-ug] | -u[ user] | -g[ group]]


    quit
    대화식 모드에서 떠남


    reboot
    system을 재부팅
    $ reboot [-q]
    -q  : 현재의 프로세서들을 종료시키지 않고, 부팅 동작만을 수행한다. 이 옵션을 사용하면 더 빠르게 리부팅할 수 있다. 다시 부팅한 기록은 로그 파일인 /var/adm/wtmp에 기록된다.


    rcp
    컴퓨터 사이에서 file을 복사할 때 사용된다.
    $ rcp [option] file_name1 file_name2
    $ rcp [option] file(s) directory
    -q  : 현재의 프로세서들을 종료시키지 않고, 부팅 동작만을 수행한다. 이 옵션을 사용하면 더 빠르게 리부팅할 수 있다. 다시 부팅한 기록은 로그 파일인 /var/adm/wtmp에 기록된다.
    -r  : 하위 디렉토리까지 재귀적으로 모두 복사한다.
    -p  : 파일의 시간과 모드를 보존한다.
    -k  : kerberos ticktets을 요구한다.
    -x  : 복사되는 모든 데이터에 암호화 과정을 거친다.


    rfd:디스켓, rct:카트리지테이프, rmt: 테이프) 백업 및 복사에 관한 명령어 하드 ----> 디스켓
      Non-preemptive(비선점) ; 커널 모드
      # tar -cvf /dev/rfd0c test1
      (c: 저장되는 파일들이 디스크의 처음부터 기록, v:기록되는 화일명 화면 출력)
      # tar -tvf /dev/rfd0c --- 디스켓의 파일 목록 확인
      디스켓 ----> 하드
      #  tar -xvf /dev/rfd0c test1 --- 지정한 파일 복원 
      동일한 하드 ---> %tar -cvf test1.tar test1
      test.c.Z (파일 생성) --- >zcat test.c.Z (파일 보기)
      touch : 내용이 없는 빈 파일을 생성, 이미 생성된 파일의 수정 시간 갱신
      # touch [option] [시간] [파일명]


    rm
    file을 지우는 명령
    $ rm [option] file_name
    -f  : 보통 지울 수 있는 권한이 없으면 안되지만, 이 옵션을 사용하면 성가신 작업을 하지 않고서도 강제로 파일을 지울 수 있다.
    -i  : 파일을 지울 것인가 다시 물어본다. 지우기를 원한다면 y를 누른다.
    -r  : 서브 디렉토리의 파일도 모두 재귀적으로 지운다.
    -v  : 파일을 지우기 전에 파일의 이름을 나타내준다.


    rmdir
    원하는 directory를 제거한다.
    $ rmdir [-p] directory
    -p  : mkdir의 -p 옵션의 반대 동작으로 하위 디렉토리와 그 상위 디렉토리 모두를 제거할 수 있다. 이때 모든 디렉토리는 비워져 있어야 한다. 수행 후 결과가 어떻게 되었는지를 보여준다.
    rmdir : 디렉토리 삭제 명령어
      - 옵션: rm -r test ; test의 하위디렉토리와 파일을 전부 삭제
      - 옵션: rm -i test ; 삭제 여부를 사용자에게 물어 본다


    rm test1 test2 test3 --- test1,test2,test3 파일을 삭제
      rm -r quit --- quit 디렉토리 및 모든 내용을 삭제


    route
    현재 라우터에 상태 확인 및 라우터 정보를 수정할 수 있다.
    $ route add -net network address netmask device
    route를 이용해서 라우터의 정보를 변경 또는 추가할 수 있다. 특히 가상 IP 설정을 할 수 있다. 즉, 한 대의 서버에 여러개의 IP를 사용할 수 있다.


    rpm
    레드헷 패키지 관리자
    $ route add -net network address netmask device
    rpm
    명령어는 바이너리 소프트웨어를 설치해주는 역할을 하므로써 일반사용자에게 설치의 편리성을 제공해주는 편리한 명령어이다. 설치뿐만
    아니라 소프트웨어의 삭제도 간단한 명령어로 간단하게 해결해 주기 떄문에 설치된 소프트웨어의 파일을 일일이 찾아 삭제하는 수고를
    덜어준다.


    Running : 현제 백그라운드 수행중인 상태

    sh
    원래의 nunix 명령인 본 셀을 불러내는 명령어


    shutdown
    시스템을 종료할 때 일반적으로 사용하는 명령어
    $ shutdown [ -thnrfck ] 시간 [ 메시지 ]
    $ shutdown now
    -t n  : t 옵션 뒤에 n초를 명시해서, 경고 메시지를 보낸 후 n초 후에 kill 시그널을 보낸다.
    -h  : shutdown시 halt를 실행하게 한다.
    -n  : 디스크 동기화 동작의 수행을 금지한다. 이런 옵션은 보통 사용할 일이 없을 것이다.
    -r  : 시스템 종료를 완료하고 나서 다시 부팅 과정을 수행한다.
    -f  : 빠른 리부팅을 한다. 리부팅시 파일 시스템 검사를 하지 않는다.
    -c  : 이미 예약되어 있는 shutdown을 취소한다. 이 옵션을 준다면 시간 인수는 줄 수 없다. 하지만 메시지는 사용자들에게 줄 수 있다.
    -k  : 모든 동작을 제대로 수행하지만 시스템을 종료할 시간이 되면 아무 것도 하지 않는다. 보는 사람으로 하여금 '절로 누구 놀리나?'하는 말이 나오게 한다. k는 'just kidding'의 의미라고 한다.


    sleep
    이름 그래로 잠자는 일 외에는 하는 일이 없다.
    $ sleep 시간

    간은 초 단위의 정수 숫자이다. 전면(foreground)에서 수행된다면 사용자의 터미널은 정해진 시간만큼 잠을 잘 것이다.
    물론 정해진 시간에 즉각 일어나니 안심해라. 원한다면 ^C로 흔들어 깨울 수도 있다. sleep을 사용하는 가장 좋은 예는
    3장에서 본 것과 같이 다중 작업을 시행할 때이다.


    다음과 같은 확인자를 사용한다면 다른 시간 단위를 사용할 수 있다.

    S 초   m 분
    h 시간   d 날짜


    sort
    파일 내의 단어 순서를 행 단위로 정렬하는 명령어
    $ sort [option] file_name(s)
    -c  : 파일이 정렬되었는지 검사한다. 그렇다면 아무런 출력도 하지 않는다.
    -m  : 특정한 파일을 병합한다. 파일은 이미 정렬되었다고 가정한다.
    -u  : 고유한 행만이 출력된다.
    -o 파일명 : 출력 파일 이름을 지정한다. 이름은 입력 파일 이름과 같을 수 있다.
    -d  : 사전(dictionary)과 같은 순서대로 정렬한다. 단어 정렬 순서에는 문자, 숫자, 공백 문자만이 사용된다.
    -f  : 대문자와 소문자를 구별하지 않는다.
    -i  : 정렬에 사용되는 문자 중 프린트될 수 없는 문자는 사용하지 않는다.
    -M  : 단어를 정렬할 때 달을 의미하는 문자를 취급한다. FEB는 JAN보다 뒤에 정렬된다.
    -n  : 숫자를 같은 문자가 아닌 정말로 숫자로 취급해서 수의 크기대로 정렬한다.
    -r  : 역순으로 정렬한다.
    -t 문자 : 단어 등 필드를 구분하는 문자를 지정한다. 탭(tab)이나 공백 문자 이외의 문자를 구분 문자로 취급하도록 한다.
    -b  : 단어의 뒤에 오는 공백 문자는 정렬 키(key) 값으로 무시하도록 한다.


    split
    텍스트 file을 작은 조각으로 나눈다. 너무 커서 다루기 불편한 텍스트 문서를 나눌 때 사용
    $ split -행 수 file_name [tag_name]
    -행 수 : 몇 개의 행 단위로 조각을 나누는지 정한다.


    Stopped : fg로 수행되다가 ^D로 잠시 중단된 상태

    su
    다른 사용자 계정으로 서브 셸을 생성한다. 잠시만 다른 사용자 계정으로 작업할 필요가 있을 때 사용한다.
    $ su [-] [userID] [인수]
    -  : 하이픈 (-)을 사용하면 새로운 셸로 로그인할 때 자신의 로그인 과정을 수행한다. 옵션이 주어지지 않으면 새로운 셸은 단지 셸 역할을 수행할 뿐이다.
    아무런 인수없이 su를 사용하면, 이것은 root 계정으로 로그인하기를 원하는 것으로 간주된다. 그래서 많은 사람들이 su가 'super user'를 의미하는 말로 생각하지만, 사실은 'substitute user'를 의미하는 말이다. 물론 수퍼 유저의
    패스워드를 알고 있어야만 한다.


    swapon
    스왑 공간 사용하기


    sync
    현재 시스템 디스크의 IO 버퍼에 있는 디스크 이미지를 하드 디스크로 기록한다.
    $ sync

    스템을 다운시키기 전에 버퍼에 있는 이미지를 반드시 디스크로 기록해야 한다. 그렇지 않으면 디스크는 기록된 정보의 이미지와 일치하지 않는 이미지를 가지게 될지도 모른다. 사실, 이것을 사용할 경우는 극히 드물다. 왜냐하면 shutdown등의 동작을 수행하면 그들이 자동적으로 sync를 호출하기 때문이다.


    tail
    문서의 끝 부분을 화면에 출력한다.
    $ tail [-행수] file_name(s)
    -행 수 : 출력될 행수를 지정한다.


    tar
    file들을 묶는 명령어
    $ su [-] [userID] [인수]
    주요 동작 모드 :
    -t, --list   : 아카이브의 내용물을 출력합니다
    -x, --extract, --get  : 아카이브에서 파일을 추출합니다
    -c, --create   : 새로운 아카이브를 만듭니다
    -d, --diff, --compare : 아카이브와 파일 시스템간의 차이점을 비교합니다
    -r, --append  : 아카이브 끝에 파일을 추가합니다
    -u, --update  : 아카이브 안의 것보다 새로운 파일만 추가합니다
    -A, --catenate  : 아카이브에 tar 파일을 추가합니다
        --concatenate  : -A와 같음
        --delete   : 아카이브로부터 제거합니다 (자기 테이프에선 안됨!)

    동작 변경자:
    -W, --verify   : 아카이브를 기록한 다음 검증하도록 합니다
        --remove-files  : 아카이브에 파일을 추가한 다음 지웁니다
    -k, --keep-old-files  : 추출할 때 이미 존재하는 파일을 덮어쓰지 않습니다
    -U, --unlink-first  : 추출하기에 앞서 대상 파일을 지웁니다
        --recursive-unlink : 디렉토리를 추출하기에 앞서 그 체계를 비웁니다
    -S, --sparse   : 스파스 파일을 효율적으로 처리합니다
    -O, --to-stdout  : 표준 출력으로 파일을 추출합니다
    -G, --incremental  : 오래된 GNU 형식의 점진적 백업 파일을 처리합니다
    -g, --listed-incremental : 새로운 GNU 형식의 점진적 백업 파일을 처리합니다
        --ignore-failed-read : 읽을 수 없는 파일에 대해 영 아닌 값으로 종료하지 않습니다


    장치 선택과 전환:
    -f, --file=ARCHIVE  : 아카이브 파일 또는 ARCHIVE 장치를 사용합니다
        --force-local  : 이름에 콜론이 있는 아카이브 파일도 지역 파일로 인식합니다
        --rsh-command=COMMAND: rsh 대신 원격 COMMAND를 사용합니다
    -[0-7][lmh]   : 드라이브와 기록 밀도를 지정합니다
    -M, --multi-volume  : 다중 볼륨 아카이브를 생성/출력/추출합니다
    -L, --tape-length=NUM : NUM x 1024 바이트를 쓴 뒤에 테이프를 바꿉니다
    -F, --info-script=FILE : 각 테이프의 끝에서 스크립트를 실행합니다 (-M을 포함함)
        --new-volume-script=FILE: -F FILE과 같음
        --volno-file=FILE  : FILE 안에 있는 볼륨 번호를 사용/갱신합니다


    장치 블럭 설정:
    -b, --blocking-factor=BLOCK: 레코드당 BLOCK x 512 바이트
        --record-size=SIZE : 레코드당 SIZE 바이트, 512의 배수
    -i, --ignore-zeros  : 아카이브에서 영으로 된 블럭을 무시합니다 (EOF를 의미함)
    -B, --read-full-records : 읽은 것을 재블럭화합니다 (4.2BSD 파이프용으로)
    정보 출력에 관한 옵션:
        --help   : 이 도움말을 인쇄하고 끝냅니다
        --version  : tar 프로그램의 버전 번호를 인쇄하고 끝냅니다
    -v, --verbose  : 처리되는 파일을 순서대로 출력합니다
        --checkpoint  : 아카이브를 읽을 동안 디렉토리 이름을 인쇄합니다
        --totals   : 아카이브를 만들 동안 쓰여진 총 바이트 수를 인쇄합니다
    -R, --block-number  : 각 메시지마다 아카이브내의 블럭 번호를 표시합니다
    -w, --interactive  : 모든 행동에 대해 확인을 요구합니다
         --confirm!ation  : -w와 같음
    -s, --same-order  : sort names to extract to match archive
        --preserve-order  : same as -s
        --preserve  : same as both -p and -s
    -z, --gzip, --ungzip  : filter the archive through gzip
    -Z, --compress, --uncompress: filter the archive through compress
        --use-compress-program=PROG: filter through PROG (must accept -d)


    tcsh
    c 셸 명령 번역기. c 셸의 확장판
    $ tcsh [option] file
    -T  : tenex라고 하는 특수한 기능을 수행하도록 한다.
    -V  : -v 옵션과 같지만 초기화 스크립트의 수행에도 영향을 미친다.
    -X  : -x 옵션과 같지만 초기화 스크립트의 수행에도 영향을 미친다.
    나머지 옵션들은 bash셸과 같다.


    tee
    파이프 연결 출력을 양방향으로 나눈다.
    $ tee [option] file_name(s)
    -i  : 인터럽트를 무시하도록 한다.
    -a  : 지정된 파일들로 출력이 덮어쓰지 않고, 뒤에 추가되도록 한다.
    Terminated : Kill 명령을 사용해 강제로 종료된 상태


    test
    file의 각종 상태를 검사하여 결과를 알려준다. 셀 스크립트 상에서 if 문이나 while 문등과 함께 사용되는게 보통이다.
    $ test [expression!]


    Expression!s
    -r 파일명 : 파일이 읽기 권한이 있으면 참
    -w 파일명 : 파일이 쓰기 권한이 있으면 참
    -x 파일명 : 파일이 실행하기 권한이 있으면 참
    -f 파일명 : 파일이 일반(regular) 파일이면 참
    -d 파일명 : 파일이 디렉토리이면 참
    -b 파일명 : 파일이 존재하고 블록 장치 파일이면 참
    -c 파일명 : 파일이 문자 전용 파일(character special file)이면 참
    -u 파일명 : 파일이 set-user-ID 플래그가 세트되어 있으면 참
    -g 파일명 : 파일이 set-group-ID 플래그가 세트되어 있으면 참
    -k 파일명 : 파일이 sticky 비트가 세트되어 있으면 참
    -s 파일명 : 파일의 크기가 0보다 크면 참
    -t 파일 디스크립터 : 파일 디스크립터에 해당하는 파일이 열려 있고, 터미널 장치로부터 사용되고 있으면 참, 기본 디스크립터 값은 1이다.
    -z 문자열 : 문자열의 길이가 0이면 참
    -n 문자열 : 문자열의 길이가 t 이상이면 참
    -문자열 1 = 문자열2 : 문자열1과 문자열2가 같으면 참
    -문자열 1 != 문자열2 : 문자열1과 문자열2가 다르면 참
    -문자열 : 문자열이 널(null)이 아니면 참, 널 문자열이면 거짓
    -정수1-eq정수2 : 두 개의 정수1과 정수2가 같으면 참
    -정수1-ne정수2 : 두 정수가 다르면 참
    -정수1-gt정수2 : 정수1이 정수2 보다 크면 참
    -정수1-ge정수2 : 정수1이 정수2 보다 크거나 같으면 참


    이외에도 -lt(작으면) -le(작거나 같으면), !(논리부정), -a(AND), -o(OR) 등과 같은 표현을 사용할 수 있으며, 괄호를 사용할 수도 있다.

    time
    프로그램이 수행되는 시간을 측정한다.


    설명
    time의 인수로 측정하고자 하는 명령을 준다. time은 세 가지 다른 형태의 시간 측정 결과를 보고한다. 실제로 얼마만큼의 시간이 걸렸는가 하는 real 커널이 사용한 시간을 제외하고 CPU에서 소비된 시간을 나타내는 user그리고 실제로 얼마만큼의 커널 시간을 할애했는가 하는 sys시간이 있다. sys+user 시간이 실제로 작업에 할애된 시간이며, real 값에서 sys+user 값을 뺀 결과값은 다른 프로세서 처리에 할당된 시간이다.


    top
    프로세서의 상태를 실시간으로 확인한다.


    설명
    top명령어는 현재 시스템의 메모리의 상태를 실시간으로 점검할 수 있는 장점이 있다. 현재 사용중인 프로세서와 사용중인 메모리 및 스왑의 양이 출력된다. 시스템을 주의 관찰해야 되는 경우에 사용하면 상당히 도움이 된다.


    touch
    파일의 엑세스 시간이나 갱신 시간을 수정한다.
    $ touch [option] file
    $ [-acm] MMDDhhmm[YY] file (obsolescent)
    -a   : change only the access time
    -c   : do not create any files
    -d, --date=STRING : parse STRING and use it instead of current time
    -f    : (ignored)
    -m   : change only the modification time
    -r, --reference=FILE : use this file's times instead of current time
    -t STAMP  : use [[CC]YY]MMDDhhmm[.ss] instead of current time
       --time=WORD : access -a, atime -a, mtime -m, modify -m, use -a
       --help  : display this help and exit
       --version  : output version information and exit


    tr
    특정한 문자들을 다른 문자로 변경한다. redirection과 함께 사용
    $ tr [option] 변경할문자 변경문자
    -c  : 파일의 모든 내용을 보이지 않고 바꾸는 작업만 보여준다.
    -d  : 파일에서 변경할 문자를 제거한다.


    설명
    문자 표현시 백슬래쉬 문자 뒤에 8진법 숫자를 써서 문자 코드를 표현할 수 있다. 또한  [c1-c2]와 같은 하이픈 표현으로 문자의 범위를 지정할 수 있으며 [c*n]과 같은 방법으로 n 만큼의 문자 반복을 표현할 수도 있다. 변경할 문자의 변경 문자의 개수는 같아야 한다.


    traceroute
    네트웍크의 구간에 접속한 시간을 측정한다.
    $ traceroute [IP Address 또는 Host]


    true
    셸 상에서 참의 의미를 가지는 0을 반환한다.


    tty
    현재 로그온 되어 있는 터미널의 장치 이름을 알려준다.
    $ tty [-s]
    -s  : 표준 입력이 터미널 장치인지 아닌지를 시험한다. 터미널이 표준이라면 0을 반환하며 아니면 1을 반환한다.
    tty : 현재 사용하고 있는 단말 장치의 이름을 경로와 함께 표준 출력


    umask
    파일을 생성할 때 현재 사용되고 있는 권한(permission)값의 마스크가 무엇인지 알려주거나 그것을 새로 지정할 때 사용된다.
    $ umask [마스크]
    마스크 값은 세 자리의 8진법 숫자로 구성된다. 이것을 마스크라고 부르는 이유는 마스크 값의 각 비트가 들어오는 값을 걸러내는
    역할을 하기 때문이다. 즉 마스크 값이 0이면 권한 지정에 제한을 두지 않는다는 것이고 6이라면 읽기와 쓰기에 제한을 가한다는
    의미가 되기 때문이다.


    umount
    설정된 마운트 정보를 해제한다.
    $ umount 장치면 or mount_piont
    $ umount -a
    $ umount -t file_system_type
    -a  : 모든 파일 시스템의 마운트 정보를 해제한다.
    -t  : 특정 형태의 파일 시스템만을 선택하여 해제된다. 옵션 뒤에는 어떤 파일 시스템을 해제할 것인지 지정한다.


    uname
    시스템 이름과 다른 정보를 보여준다.
    $ uname [option]
    -s  : 시스템 이름을 알려준다. (기본값으로 내장)
    -n  : 시스템의 노드(node) 이름을 알려준다.
    -r  : 오퍼레이팅 시스템의 증명번호를 알려준다.
    -v  : 오퍼레이팅 시스템의 버전(version) 번호를 알려준다.
    -m  : 하드웨어의 이름을 알려준다.
    -a  : 모든 정보를 알려준다. -snrvm 과 같다.


    uncompress
    compress로 압축되어 있는 file의 압축을 푼다.
    $ uncompress file_name(s)

    실상, compress의 -d 옵션을 사용하면 압축을 풀 수 있기 때문에 이 명령은 불필요하다. 하지만 옵션을 사용하는 것보다
    의미있는 단어를 사용함으로 좀더 친숙하게 사용할 수 있다. uncompress는 자신이 압축 풀기 동작을 수행하는 것이 아니라
    -d 옵션을 주어 compress를 호출한다. uncompress 자신의 파일 크기는 아주 적다.


    users
    간단히 사용자들의 ID 이름만을 알고자 할때 사용한다.


    uptime
    서버 부팅시간과 현재 시간이 출력된다.


    uundecode / uuencode
    uuencode는 USENET과 같이 ASC2 코드만을 다루는 미디어를 위해 바이너리 코드를 변환한다.
    uudecode는 그 반대의 동작을 수행한다.
    $ uudecode file..
    $ uuencode file.. 이름


    사용예
    $ uuencode canexe.Z canexe.Z > exemail.uu
    canexe.Z 라는 파일을 인코딩 작업을 거친 후 exemail.uu라는 파일로 저장한다. 이 파일을 디코딩하면 canexe.Z라는 이름으로 파일이 만들어진다.


    vi
    vi 에디터. 유닉스 계열의 운영체제에서 가장 널리 쓰이는 에디터


    vi 명령어 요약
    1. 시작
    vi file   : vi를 시작하여 지정한 파일 편집
    vi -R file  : 읽기 전용(read- only) 편집기로서 vi를 시작하여 지정한 파일 편집
    view file  : 읽기 전용(read- only) 편집기로서 vi를 시작하여 지정한 파일 편집

    2. 종료
    :wq   : 데이터를 저장하고 종료
    :q!   : 데이터를 저장하지 않고 종료


    3. 시스템이 다운된 후에 되살리기
    vi -r   : 되살릴 수 있는 모든 파일 이름 보여주기
    vi -r file   : vi를 시작하여 지정한 파일 되살리기

    4. 디스플레이 제어하기
    ^L   : 현재 화면을 다시 디스플레이하기
    :set number  : 내부 줄 번호 디스플레이
    :set nonumber  : 배부 줄 번호 디스플레이 않기
    5. 마지막으로 지운 것 복사하기
    p   : 마지막으로 지워진 것을 커서의 뒤/아래에 삽입
    P   : 마지막으로 지워진 것을 커서의 앞/위에 삽입
    xp   : 두 문자를 바꿈
    deep   : 두 단어를 바꿈
    ddp   : 두 줄을 바꿈

    6. 패턴 검색
    /rexp   : 지정된 정규 표현식에 대해 앞으로 이동
    /   : 이전의 패턴에 대해 앞으로 검색을 반복
    ?rexp   : 지정된 정규 표현식에 대해 뒤로 이동
    ?   : 이전의 패턴에 대해 뒤로 검색을 반복
    n   : /나 ?명령에 대해 같은 방향으로 반복
    N   : /나 ?명령에 대해 반대 방향으로 반복


    7. 약어의 사용
    :ab short long  : short를 long에 대한 약어로 변경
    :ab   : 현재 약어 목록을 표시
    :una short   : 약어 short를 표시

    8. 줄 길이의 조정
    r<Return>  : 문자를 뉴라인으로 변경
    J   : 줄의 결합
    :set wm=n  : 오른쪽으로 n문자 위치에서 자동적으로 줄 나눔

    9. 커서 이동
    h<Left>  : 커서를 한 칸 왼쪽으로 이동
    j<Down>  : 커서를 한 줄 아래로 이동
    k<Up>   : 커서를 한 줄 위로 이동
    l<Right>  : 커서를 한 칸 오른쪽으로 이동


    <Backspace>  : 커서를 한 칸 왼쪽으로 이동
    <Space>  : 커서를 한 칸 오른쪽으로 이동
    -   : 커서를 이전 줄의 처음으로 이동
    +   : 커서를 다음 줄의 처음으로 이동
    <Return>   : 커서를 다음 줄의 처음으로 이동
    0   : 커서를 현재 줄의 맨 앞으로 이동
    $   : 커서를 현재 줄의 맨 끝으로 이동
    ^   : 커서를 현재 줄의 첫글자(공백이나 탭이 아닌)로 이동
    w   : 커서를 다음 단어의 첫 글자로 이동
    e   : 커서를 다음 단어의 끝 글자로 이동
    b   : 커서를 이전 단어의 첫 글자로 이동
    W   : w와 같음(문장 부호 무시)
    E   : e와 같음(문장 부호 무시)
    B   : b와 같음(문장 부호 무시)
    (   : 다음 문장의 처음으로 이동
    )   : 이전 문장의 처음으로 이동
    {   : 다음 문단의 처음으로 이동
    }   : 이전 문단의 처음으로 이동
    H   : 커서를 화면 맨 위로 이동
    M   : 커서를 중간으로 이동
    L   : 커서를 맨 아래로 이동

    10. 편집 버퍼를 통한 이동
    ^F   : 한 화면 아래로 이동
    ^B    : 한 화면 위로 이동
    n^F    : n화면 아래로 이동
    n^B   : n화면 위로 이동
    ^D   : 반 화면 아래로 이동
    ^U   : 반 화면 위로 이동
    n^D   : n줄만큼 아래로 이동
    n^U   : n줄만큼 위로 이동
    11. 셸 명령 실행
    :!command  : vi를 중단하고 지정한 셸 명령을 실행
    :!!   : vi를 중단하고 이전의 셸 명령을 실행
    :sh   : vi를 중단하고 셸을 실행
    :!csh    : vi를 중단하고 새로운 C-셸을 실행

    12. 패턴에 의한 치환
    :s/pattern/replace/ : 현재 줄의 치환
    :lines/pattern/replace/ : 지정한 줄의 치환
    :line,lines/pattern/replace/: 지정한 범위의 치환
    :%s/pattern/replace/ : 모든 줄의 치환

    13. 데이터 읽기
    :liner file  : file의 내용을 지정한 줄 다음에 삽입
    :r file   : file의 내용을 현재의 줄 다음에 삽입
    :liner !command  : command의 결과를 지정한 줄 다음에 삽입
    :r !command  : command의 결과를 현재의 줄 다음에 삽입
    :r !look pattern   : 지정한 pattern으로 시작된 단어 삽입

    14. 정규 표현식을 사용하기 위한 특수 기호
    .   : 뉴라인을 제외한 모든 단일 문자와 대응
    *   : 영 또는 그 이상의 선행 문자와 대응
    ^   : 줄의 시작과 대응
    $   : 줄의 끝과 대응
    \<   : 단어의 시작과 대응
    \>   : 단어의 끝과 대응
    [ ]   : 묶여진 문자중의 하나와 대응
    [^ ]   : 묶여진 문자를 제외한 아무것하고나 대응
    \   : 이어지는 기호를 문자 그대로 해석


    15. 줄 번호
    nG   : 줄번호 n으로 건너뛰기
    1G   : 편집 버퍼의 첫 줄로 건너뛰기
    G   : 편집 버퍼의 마지막 줄로 건너뛰기
    :map g lG  : g가 lG와 같도록 매크로 정의

    16. 삽입
    i   : 입력 모드로 전환, 커서 위치 앞에서 삽입
    a   : 입력 모드로 전환, 커서 위치 뒤에서 삽입
    I   : 입력 모드로 전환, 현재 줄의 앞에 삽입
    A   : 입력 모드로 전환, 현재 줄의 끝에 삽입
    o   : 입력 모드로 전환, 현재 줄의 아래에 전개
    O   : 입력 모드로 전환, 현재 줄의 위에 전개

    17. 편집하고 있는 파일을 바꾸기
    :e file   : 지정한 파일의 편집
    :e! file   : 지정한 파일의 편집, 자동 점검의 생략

    18. 내용 고치기
    r   : 단지 한 글자만 변경(입력 모드로 바뀌지 않음)
    R   : 입력하는 대로 겹쳐 써서 변경
    s   : 삽입에 의해 한 단어의 변경
    C   : 커서의 위치로부터 줄 끝까지 삽입에 의한 변경
    cc   : 전체 줄을 삽입에 의한 변경
    S   : 전체 줄을 삽입에 의한 변경
    cmove   : 커서부터 move까지 삽입에 의해 변경
    ~   : 대,소문자 바꾸기
    19. 고치기의 취소 또는 반복
    u   : 편집 버퍼를 수정했던 마지막 명령을 취소
    U   : 현재 줄을 저장
    .   : 편집 버퍼를 수정했던 마지막 명령 반복

    20. 문자 삭제
    x   : 커서가 있는 문자 삭제
    X   : 커서의 왼쪽 문자 삭제
    D   : 커서부터 줄의 끝까지 삭제
    dd   : 현재 줄의 전체 삭제
    dmove   : 커서부터 move까지 삭제
    dG   : 커서부터 편집 버퍼의 끝까지 삭제
    d1G   : 커서부터 편집 버퍼의 맨 앞까지 삭제
    :lined   : 지정한 줄의 삭제
    :line, lined  : 지정한 범위의 삭제

    21. 여러 줄의 복사와 이동
    :linecotarget  : 지정한 줄을 복사하여 target 줄 밑에 삽입
    :line, linecotarget : 지정한 범위를 복사하여 target 줄 밑에 삽입
    :linemtarget  : 지정한 줄로 이동하여 target 줄 밑에 삽입
    :line, linemtarget  : 지정한 범위로 이동하여target 줄 밑에 삽입

    22. 데이터를 처리하기 위한 셸 명령의 사용
    n!!command  : n번 줄에서 command의 실행
    !move command  : 커서부터 move까지 command 실행
    !move fmt  : 커서부터 move까지 줄들을 형식 맞추기

    23. 데이터 저장하기
    :w   : 원래의 파일로 데이터를 저장
    :w file   : 지정한 파일로 데이터를 저장
    :w>> file   : 지정한 파일에 데이터를 추가


    w
    현재 시스템에 접속한 사용자들의 정보를 출력한다.
    $ w [user]


    wait [작업번호] --백그라운드 실행 종료

    wall
    현재 시스템에 로그온되어 있는 모든 사용자들에게 메시지를 보낸다.
    $ wall [message]
    메시지는 각 사용자의터미널에 나타나게 된다. 인수로 파일 이름이 주어지지 않으면 표준 입력으로부터 데이터를 받아들이며, ^D로
    입력을 종결하고 메시지를 발송한다. 이것을 사용하려면 슈퍼 유저로 로그인되어야 한다. 사용자가 자신의 터미널을 메시지 수신 거부
    상태로 만들어 놓더라도 슈퍼 유저는 그것을 무시할 수 있다.


    wc
    file 내의 단어 수 등의 정보를 출력한다.
    $ wc [option] file(s)
    -c  : 문자(character)의 개수만을 알고 싶을 때 사용한다.
    -w  : 단어(word)의 개수만을 알고 싶을 대 사용한다.
    -l  : 행(line)의 숫자를 알고 싶을 때 사용한다. 혹은 개행 문자의 개수를 알고자 할 때 사용될 수도 있다.


    whereis
    문자열 또는 file을 검색한다.


    which
    등록된 path를 통해서 특정 프로그램을 찾는다.


    who
    현재의 시스템에 접속한 사용자의 이름이나 로그온 정보를 보여준다.
    $ who [ -uTHqs ] [로그온 정보파일 ]
    -u  : 현재 시스템에 누가 로그온되어 있는지 보여준다.
    -T  : 사용자의 터미널이 메시지를 보낼 수 있는지를 알려준다. +기호는 메시지를 쓸 수 있고, -는 그렇지 않음을 보여준다.
    -H  : 헤더 라인을 프린트한다.
    -q  : 사용자 이름과 카운트가 구분된 목록을 보여줌, 다른 옵션은 무시된다.
    -s  : 호환을 위해 포함된 옵션으로 무시된다.
    who : 유닉스 시스템에 로그인 되어 있는 사용자들에 대한 정보를 화면에 표시


    whoami
    현재 접속한 계정명 확인 및 접속자의 정보를 출력한다.
    $ whoami


    write
    사용자의 터미널 사이에 메시지를 전달한다.
    $ write [user] [tty]

    시지를 전달하고자 하는 사용자의 이름을 지정한다. 만일 한 사용자의 이름으로 두 명 이상이 사용중이면 특정 터미널을
    지정하여(tty) 메시지를 전달할 수 있다. write는 표준 입력 장치로 전달할 메시지를 입력받는다. 각행에서 리턴 키를 누를
    때마다 메시지가 전달되며, ^D를 누르면 그만둔다.


    메시지가 수신되면 'Message from 보낸사람 터미널'등의 정보를 보여주어서
    누가 어느 터미널에서 메시지를 보내는지를 알 수 있도록 한다. 보내고자 하는 사람이 로그인되어 있지 않다면 'user is
    not logged on이라고' 알려주며 만일 그 사람의 터미널이 메시지 수신을 거부하고 있는 상태라면 'permission
    denied 라는' 말을 보여준다. 그는 아마도 mesg n 명령을 사용했을 것이다.


    xdm
    X-Widows상에서 login screen을 보여준다.
    어떤 system은 특정 level로 가도록 지정하면 xdm을 시동시킨다(/etc/inittab를 보도록).
    리눅스 부팅 스크립트에 넣어두면 리눅스를 처음 부팅할 때부터 엑스윈도우로 부팅할 수 있다.


    zcat
    데이터를 다른 명령에 파이프 하려는 경우 사용하는 명령어


    cat 명령과 똑같이 작업하지만 입력으로 압축된 파일이 필요하다.
    zcat은 파일을 압축 해제한 후 표준 출력 디바이스에 프린트한다.
    zcat namelist | program1 | program2 ...


    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    vmstat 항목 설정 보기  (0) 2010.02.02
    Crontab 설정 하기  (0) 2010.02.02
    apache 재시작 문제  (0) 2009.07.31
    리눅스 파일 내용 검색  (1) 2009.07.28
    chown 사용하기  (0) 2008.10.27
    Posted by 서오석
    ,
    내가 top 명령어로 서버 부하를 모니터링하고 있는 것을 본 창국님이 jconsol이란 녀석으로 모니터링 하라고 해서 하는 방법을 알려주셨다.

    jconsol은 Tomcat의 메모리나 cpu 사용량 같은 것들을 모니터링하기 위한 툴이다.

    실행법은 다음과 같다.

    환경은 java jdk1.5나 jdk1.6 버전이어야 한다. (사실 그 이하 버전에 있는지는 잘 모르겠다. 1.5 버전과 1.6버전에 있는 건 확인했다.

    그리고 모니터링 할 tomcat에 설정 상에 -Dcom.sun.management.jmxremote.port=8999
    라는 녀석이 있어야 한다. 저건 8999번 포트에 jconsole로 모니터링 할 수 있도록 지원하겠다는 의미다. (Tomcat 기본 설정에 들어가 있지 않기 때문에 추가해주어야 한다. )
    없다면 톰켓 환경 설정에서 argment에 추가해주고 톰켓을 실행시키자.


    위에 이미지처럼 자신이 Java를 깐 폴더 및에 bin 폴더로 가서 jconsole 라는 녀석을 실행시키자.

    그럼 프로그램이 실행되는데 java1.6버전 안에 들어있는 녀석은 다음과 같다.

    원래 뒤에 있는건 이미 내가 지정한 녀석이라 모니터링이 되고 있는 것이다.

    저기 Remote Process에다가 Tomcat이 올라간 서버명과 아까 인수로 지정한 포트를 써준다.

    ex) 192.168.19.231이란 서버에 Tomcat이 올라갔을 경우 저기에 192.168.19.231:8999 이라고 써준다.
    만약에 서버에 접근 할 때 PW가 있다면 아래다가 로그인 할 username하고 password를 적어준다. 없으면 안써도 된다.

    그리고 Connect를 누르면 해당 톰켓을 모니터링 할 수 있게 된다.

    완소 프로그램이다..ㅋ

    좀더 자세한 내용을 알고 싶으면

    여기로 한번 가보는 것도 좋다.




    좀더 자세하게 설정을 해보자.

    1) java가 있는 디렉토리 밑에가서 아래 커맨드를 날리자
    > cd jre/lib/management
    2) password 파일 복사
    > cp jmxremote.password.template jmxremote.password
    3) 파일 하단에 이거 주석 제거  #monitorRole  QED #controlRole 
    > vi jmxremote.password
    > 주석 제거 후 w! (읽기전용파일이라 저렇게 하고 나서 q!로 나간다.)
    4) 권한 변경  
    > chmod 444 jmxremote.password
    5) 톰켓 start는 부분에 java_Option으로 -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"
    이부분 추가 하면 세팅 끝~!




    이거 하려다 에러가 난다면?
    Posted by 서오석
    ,

    아파치를 재시작하려고 할 때 아래와 같은 문제로 아파치가 재시작이 안되는 경우가 있다.

    (98)Address already in use: make_sock: could not bind to address 0.0.0.0:80

    이경우는 다른 프로세서가 80번 포트를 사용하고 있다는 것이다.

    netstat -nlp

    이거로 어떤 프로세스가 80번 포트를 사용하는지 확인한다.

    나같은 경우는 특이하게

    httpd (아파치)가 사용하고 있었다.

    ps -ef | grep httpd

    로 해당 httpd 의 상태를 보니 특이하게 부모 pid 가 1 이었다.

    어떠한 이유로 해서 부모 프로세스가 죽어버린 것이다. 이땐 아파치를 stop이나 restart 를 하려해도 안된다.

    그냥 떠 있는 모든 httpd 관련한 프로세스를 몽땅 죽인 후 다시 재시작을 해야 한다.

    killall httpd

    를 하게되면 httpd라는 이름으로 되어있는 애들은 모두 죽는다. (조심해서 사용하자.)

    그다음 다시 apachectl start 하면 제대로 될 것이다.

    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    Crontab 설정 하기  (0) 2010.02.02
    리눅스 명령어 모음  (0) 2009.08.05
    리눅스 파일 내용 검색  (1) 2009.07.28
    chown 사용하기  (0) 2008.10.27
    리눅스 IP, Path 설정  (0) 2008.09.25
    Posted by 서오석
    ,

    리눅스에서 eclipse처럼 파일 안에 있는 내용을 검색할라면 다음과 같이 해야한다.

    예제) 
    "5dolstory" 라는 글자가 포함된 파일을 /home/ 아래 하위 디렉토리 전체 검색해서 찾고 싶은 경우

     grep -e  5dolstory /home/ -R

    그냥 /home/에서만 찾고 싶은 경우 -R을 뺀다.

    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    chown 사용하기  (0) 2008.10.27
    리눅스 IP, Path 설정  (0) 2008.09.25
    회사에서 배운 리눅스 명령어들.  (1) 2008.09.19
    Posted by 서오석
    ,
    이거 배포를 root로 했다가 사용자 바꾸는 거 몰라서 뻘짓한 후 철원님이 알려준 거..--;;

     chown -R hanadmin:hanmail request_old/
                       그룹        사용자     변경할 폴더

    모르면 개고생이여..--;


    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    리눅스 파일 내용 검색  (1) 2009.07.28
    리눅스 IP, Path 설정  (0) 2008.09.25
    회사에서 배운 리눅스 명령어들.  (1) 2008.09.19
    Posted by 서오석
    ,

    아파치 2.0에선 Trace를 막는 건 쉬운데 사실 HEAD나 OPTIONS를 막는게 어떻게 하는지 몰라서

    개삽질을 하다가 찾아냈다.

    뭐 대략 서버에 다 막아버리는 방법은 다음과 같다.

    DocumentRoot "/data2/htdocs"

    이게 내 서버의 루트 디렉토리다. 루트디렉토리 다 때려막기는 다음과 같다.

    <Directory "/data2/htdocs">
       Options FollowSymLinks
       AllowOverride None
      <Limit GET POST>
            Order allow,deny
            Allow from all
      </Limit>
      <LimitExcept GET POST>
            Require valid-user
      </LimitExcept>
    </Directory>


    설명을 하자면 디렉토리를 설정한 후

    대략 GET POST를 제외한 모든 녀석은 막아버리고
    만약 그 외 OPTIONS나 HEAD 등을 사용하려면 Valid-user만 가능하다는 뜻인데..
    가디언 TFT 최세환님이 말해주셨는데... 젝일 까먹었다..T.T
    Posted by 서오석
    ,

    아파치웹서버를 동작시킨 후에 관리자는 서버의 부하를 어느정도 받고 있는지 모니터링을 해야한다. 부하가 많고 응답속도가 현저하게 떨어졌을 때에는 적절한 조치를 취해야하며, 데몬은 떠있지만 제대로 응답하지 않는 경우도 있기 때문에 항상 모니터링을 해야한다. 아파치웹서버의 모니터링은 유닉스의 쉘상태에서도 할 수 있으며, 웹으로도 할 수 있다.

    일단 이런 모니터링을 가능하게 하려면 httpd.conf파일에 다음과 같이 설정을 해야한다.

     

    [아파치 모니터링을 위하여 httpd.conf의 설정] : 특정 IP주소자만 허용

    <Location /server-status>
        SetHandler server-status
        Order deny,allow
        Deny from all
        Allow from 192.168.0.203
    </Location>

    위의 예와 같이 아파치 모니터링을 위해서는 httpd.conf 파일내에 server-status 설정이 되어 있어야 한다. 위의 설정에서 Order deny, allow 와 Deny from all 그리고 Allow from 192.168.0.203 설정으로 인하여 이 모니터링페이지를 웹브라우저로 확인가능한 곳은 192.168.0.203 IP 사용자만 가능하다. 당연히 192.168.0.203 사용자는 아파치웹서버의 관리자일 것이다.

    만약 특정 IP 주소가 아닌 네트워크로 지정하고자 한다면 다음과 같이 하면 된다.

     

    [아파치 모니터링을 위하여 httpd.conf의 설정] : 특정 네트워크 사용자 모드 허용

    <Location /server-status>
        SetHandler server-status
        Order deny,allow
        Deny from all
        Allow from 192.168.0.0/24
    </Location>

    즉, 192.168.0.0번 IP 사용자부터 192.168.0.255 사용자까지만 모니터링페이지를 로딩할 수 있다는 의미이다. 위의 설정은 관리자에 소속된 사용자들만 접속을 허용하기 위한 설정이라고 생각하면 된다.

     

    이제 서버모니터링을 웹브라우저로 해보자. 먼저 아파치를 재시작시켜야 한다.

    http://192.168.0.201/server-status

    또한 주기적인 갱신으로 계속적인 모니터링을 하려면 다음과 같이 refresh 주기를 주면 된다. 단위는 초이다.

    http://192.168.0.201/server-status?refresh=5

     

     

    이 부분에 대한 대략적인 설명은 다음과 같다.

     

      -   Server Version : 아파치서버의 버전을 나타낸다. 

      -   Server Built : 아파치서버가 설치된 년, 월, 일, 시

      -   Current Time : 현재 모니터링하는 년, 월, 일, 요일, 시간

      -   Restart Time : 아파치서버가 재동작한 년, 월, 일, 요일, 시간

      -   Parent Server Generation : 서버 부하방지을 위한 아파치서버 생성갯수 총서버 개수중 요구에 응하고 있는 서버의 개수와 놀고 있는 서버의 개수 Scoreboard Key 에 대한 정보  

      -   "-" : 응답을 하기 위해 대기중임을 나타냄.

      -   "S" : 시작되고 있음을 나타냄.

      -   "R" : 응답을 위해 요구사항을 해석하고 있음.

      -   "L" : 요구에 대한 응답을 하고 있음.

      -   "K" : 계속연결중임.

      -   "D" : DNS서버에 요구도메인 검색중임.

      -   PID key : 프로세스정보를 보여준다.

    Posted by 서오석
    ,
    인터넷 페이지 오류들 인터넷 페이지 오류들
    어딘가에서 스크랩 한 글..;; 어디서 했는지 기억이 안나..

    ▶ 403 Forbidden/Access Denied (403 금지/액세스 거부)

    이 웹 사이트는 패스워드와 같은 특별한 액세스 승인을 필요로 하는 경우입니다.

    ▶ 404 Not Found (404 찾을 수 없음)

    브라우저가 호스트 컴퓨터는 찾았으나 요청된 특정 도큐먼트를 찾지 못한 경우입니다.
    정확한 주소를 입력했는지 확인해 봅니다. 그 페이지는 해당 웹 사이트에서 제거되었을 수도 있고 위치가 바뀌었을 수도 있습니다.
    파일명을 떼어내고 주소를 다시 한 번 입력해 봅니다. 즉, 한 단계 위의 웹 사이트를 찾아 봅니다.

    ▶ 503 Service Unavailable (503 서비스 불가)

    해당 웹 사이트의 서버에 과부하가 걸린 경우입니다.
    몇 초 후에 다시 시도해 봅니다.

    ▶ Bad file request (잘못된 파일 요청)

    온라인 폼 또는 HTML 코드가 잘못된 경우입니다.

    ▶ Connection refused by host (호스트의 접속 거부)

    위에 있는 ‘403 Forbidden/Access Denied’ 에러와 유사한 상황입니다.

    ▶ Failed DNS lookup (DNS 찾기 실패)

    해당 웹 사이트의 URL이 적절한 IP 주소로 전환될 수 없는 경우입니다.
    이런 에러는 상용 사이트에서 빈번하게 발생하는데 IP 주소 전환을 담당하는 컴퓨터들이 과부하 상태에 놓이기 때문이라고 합니다.
    물론, 주소를 잘못 입력한 경우에도 발생할 수 있습니다.
    주소를 다시 한 번 입력해 보거나, 혼잡하지 않을 것 같은 시간에 다시 시도해 봅니다.

    ▶ Helper application not found

    보조 응용프로그램(helper application)을 필요로 하는 파일을 다운받으려 하는데, 인터넷 익스플로러가 찾지 못하는 경우입니다.
    이런 경우에는 아무 Windows 창이나 열어서 ‘보기(V)’의 ‘폴더 옵션(O)’에 있는 ‘파일 형식’ 탭을 선택하여 보조 응용프로그램을 위한 디렉토리 및 파일명이 정확하게 입력되도록 합니다.

    ▶ Not found (찾을 수 없음)

    하이퍼링크가 가리키는 웹 페이지가 더 이상 존재하지 않음을 나타냅니다.

    ▶ Site unavailable (사이트 사용 불가)

    너무 많은 사람들이 동시에 액세스하려 하면 온라인상에 노이즈가 생겨 해당 사이트가 다운될 수도 있고, 아니면 더 이상 그 사이트가 존재하지 않는 경우일 수도 있습니다.
    주소를 잘못 입력해도 나올 수 있습니다.

    ▶ 각 Error 코드별 의미

    100 : Continue
    101 : Switching protocols
    200 : OK, 에러없이 전송 성공
    201 : Created, POST 명령 실행 및 성공
    202 : Accepted, 서버가 클라이언트 명령을 받음
    203 : Non-authoritative information, 서버가 클라이언트 요구 중 일부 만 전송
    204 : No content, 클라언트 요구을 처리했으나 전송할 데이터가 없음
    205 : Reset content
    206 : Partial content
    300 : Multiple choices, 최근에 옮겨진 데이터를 요청
    301 : Moved permanently, 요구한 데이터를 변경된 임시 URL에서 찾았음
    302 : Moved temporarily, 요구한 데이터가 변경된 URL에 있음을 명시
    303 : See other, 요구한 데이터를 변경하지 않았기 때문에 문제가 있음
    304 : Not modified
    305 : Use proxy
    400 : Bad request, 클라이언트의 잘못된 요청으로 처리할 수 없음
    401 : Unauthorized, 클라이언트의 인증 실패
    402 : Payment required, 예약됨
    403 : Forbidden, 접근이 거부된 문서를 요청함
    404 : Not found, 문서를 찾을 수 없음
    405 : Method not allowed, 리소스를 허용안함
    406 : Not acceptable, 허용할 수 없음
    407 : Proxy authentication required, 프록시 인증 필요
    408 : Request timeout, 요청시간이 지남
    409 : Conflict
    410 : Gone, 영구적으로 사용할 수 없음
    411 : Length required
    412 : Precondition failed, 전체조건 실패
    413 : Request entity too large,
    414 : Request-URI too long, URL이 너무 김
    415 : Unsupported media type
    500 : Internal server error, 내부서버 오류(잘못된 스크립트 실행시)
    501 : Not implemented, 클라이언트에서 서버가 수행할 수 없는 행동을 요구함
    502 : Bad gateway, 서버의 과부하 상태
    503 : Service unavailable, 외부 서비스가 죽었거나 현재 멈춤 상태
    504 : Gateway timeout
    505 : HTTP version not supported
    507 : 짜라가 로그인 했습니다. 똘끼를 피하려면 컴퓨터를 꺼주세요..


    지금 나는 302의 에러와 싸우고 있다..-0-;;

    이녀석의 302는 아무래도 액션단 안에 리다이렉트 되는 부분이 있으면 나는 에러인 것 같다..--;; 물론 아직 웹에 관련된 지식이 많지 않아 확인은 못했다는..;;
    Posted by 서오석
    ,


    위 파일을 다운받아 리눅스 서버에 갖다 놓는다.

    tar xvzf cronolog-1.6.2.tar.gz 로 압축을 푼다

    명령어는 다음과 같다

    ./configure
    make && make install

    설치 완료!
    /usr/local/sbin/ 에 설치되어 있음을 확인.

    httpd.conf 를 수정

    vi /usr/local/apache/conf/httpd.conf

    기존

    CustomLog logs/access_log combined

    이걸 이렇게 변경

    CustomLog "|/usr/local/sbin/cronolog /data2/server/apache/logs/info.daum.net.access_log.%Y.%m.%d" common

    이 설정은 info.daum.net.access_log 파일을

    info.daum.net.access_log.20060322
    info.daum.net.access_log.20060323

    이런 식으로 일자별로 분할해 주는 옵션이다.

    그리고 마지막으로 /bin/apachectl restart

    끝~!
    Posted by 서오석
    ,

    이번 회사소개 만들면서 버츄얼 호스트때문에 머리 깨지는 줄 알았다.

    2일을 그냥 날려먹었다..--;;

    recruit.daum.net 도메인을 받았는데 아파치 설정에 rewrite할 줄 몰라 너무 애먹었다.

    물론 이번 공채 지원하는 사람들이 이것 때문에 불편했을거다..

    아파치 설정에서 httpd.conf를 연 다음에 대략 중간에 다음과 같이 쓰면 된다.

     RewriteEngine On      
       RewriteCond %{HTTP_HOST} ^recruit\.daum\.net$ 
            이건 Rewrite Condition이다 만약  %{HTTP_HOST}가 recruit.daum.net이라면
            True로 반환해서 아래의 RewriteRule을 진행하게 된다.

       RewriteRule ^/$ http://recruit.daum.net/Daum/recruit/currentOpportunities.do [L]
            URL창에 들어온 URL 뒷부분이 그냥 / 이면
            http://recruit.daum.net/Daum/recruit/currentOpportunities.do를 수행한다.
            뒤에 붙은 [L]은 수행후 RewriteRule을 종료하란 것이다.
            그러니까 저 currentOpportunities.do를 날려준 후에 위의 컨디션에 대한 RewriteRule을
            종료시키는 것이다.

       RewriteCond %{HTTP_HOST} ^ir\.daum\.net$
           다시 컨디션을 체크하고..
       RewriteRule ^/$ http://ir.daum.net/Daum/ir/stockInformation.do [L]
           다시 Rewrite를 수행 후 Rule 종료.
    뭐 대략 이렇다.
     

    원본 소스를 긁어다 대충 약간 붙여야겠다.

    httpd.conf의 일부



    Posted by 서오석
    ,
    http://www.cyworld.com/lovemo_two/1864531

    리눅스에서 ip보실 경우에 우선 ifconfig의 권한은 다음과 같습니다.

    -rwxr-xr-x 1 root root 121680 8월 26 2003 /sbin/ifconfig

    소유자가 root이므로 슈퍼유저(root)로 ifconfig 명령어가 실행되어ip를 볼 수 있습니다.

    [root@ip199 up2]# ifconfig eth0
    eth0 Link encap:Ethernet HWaddr 00:30:6E:F3:DB:6E
    inet addr:192.168.1.43 Bcast:192.168.1.255 Mask:255.255.255.0
    UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
    RX packets:1497719 errors:1 dropped:0 overruns:0 frame:1
    TX packets:1507129 errors:0 dropped:0 overruns:0 carrier:0
    collisions:0 txqueuelen:1000
    RX bytes:1421021260 (1355.1 Mb) TX bytes:1439077789 (1372.4 Mb)
    Interrupt:53 Base address:0xd00 Memory:80020000-80020038

    위의 /sbin/ifconfig 권한은 other 사용자도 읽기와 실행이 가능합니다.
    따라서 badugizzang 사용자로 ifconfig 실행시 다음과 같은 메시지가 나옵니다.

    [badugizzang@ip199 badugizzang]$ ifconfig
    -bash: ifconfig: command not found

    이것은 badugizzang의 PATH에 /sbin이 없기 때문입니다.

    [badugizzang@ip199 badugizzang]$ echo $PATH
    /usr/kerberos/bin:/bin:/usr/bin:/usr/local/bin:/usr/bin/X11:/usr/X11R6/bin:/home/badugizzang/bin

    따라서 절대경로(/sbin/ifconfig)를 사용하여 다음과 같이 확인 할 수 있습니다.

    [badugizzang@ip199 badugizzang]$ /sbin/ifconfig eth0
    eth0 Link encap:Ethernet HWaddr 00:30:6E:F3:DB:6E
    inet addr:192.168.1.43 Bcast:192.168.1.255 Mask:255.255.255.0
    UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
    RX packets:1497897 errors:1 dropped:0 overruns:0 frame:1
    TX packets:1507266 errors:0 dropped:0 overruns:0 carrier:0
    collisions:0 txqueuelen:1000
    RX bytes:1421038138 (1355.2 Mb) TX bytes:1439094067 (1372.4 Mb)
    Interrupt:53 Base address:0xd00 Memory:80020000-80020038

    * 결론
    ifconfig 권한의 설정에 따라서 소유자, 그룹, 그외의 사용자가 읽거나 쓰거나 실행 할 수 있는 것입니다.
    님의 경우 먼저 ifconfig의 권한을 확인하시면 문제점이 해결 될 것입니다.

    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    리눅스 파일 내용 검색  (1) 2009.07.28
    chown 사용하기  (0) 2008.10.27
    회사에서 배운 리눅스 명령어들.  (1) 2008.09.19
    Posted by 서오석
    ,
     nslookup file.youthvoice.daum.net  -> 서버 이름과  주소를 보여준다.

    iconv -f utf-8 -t euc-kr index.html > index2.html -> 인코딩을 변경한다.

    grep -r 10.10.10.10 *  -> 하위 폴더에 10.10.10.10이란 내용을 죄다 찾는다.

    tail -f * -> 로그를 실시간으로 본다.

    find / -name index.html -print  -> 루트 밑에 index.html을 찾는다~

    grep -v ^# httpd.conf | more -> 아파치 httpd.conf 안에 주석달린거 다 날려버리고 주석 없는거 만 보여주기

     cat /proc/meminfo -> 서버의 메모리 사양 확인

    cat /proc/cpuinfo -> 서버의 Cpu 사양 확인

    mpstat -P ALL 1 -> 메모리 사용률 보여주기

    iostat -> I/O 상태 보여주기 뒤에 숫자 붙이면 그 숫자 초 만큼 보여줌



    '서버 이야기 > Linux 이야기' 카테고리의 다른 글

    리눅스 명령어 모음  (0) 2009.08.05
    apache 재시작 문제  (0) 2009.07.31
    리눅스 파일 내용 검색  (1) 2009.07.28
    chown 사용하기  (0) 2008.10.27
    리눅스 IP, Path 설정  (0) 2008.09.25
    Posted by 서오석
    ,