Linux 학습, 기초 과정: RPM 및 YUM 패키지 관리


소프트웨어 새로 추가 및 시스템을 최신 상태로 유지




Ian Shields, 선임 프로그래머, IBM Japan


요약: Linux® 시스템에서 패키지를 설치, 업그레이드 및 관리하는 방법을 학습할 수 있는 기회입니다.이 기사에서는 Red Hat에서 개발한 RPM(Red Hat Package Manager)뿐 아니라, 원래는 듀크대학교 물리학과에서 Red Hat Linux 시스템을 관리하기 위해 개발한 YUM(Yellowdog Updater Modified)에 초점을 맞춰 설명합니다. 이 기사에 소개된 자료를 이용해 Linux 시스템 관리자 인증을 획득하기 위한 LPI 101 시험에 대비한 공부를 하거나, 그냥 소프트웨어를 새로 추가하고 시스템을 최신 상태로 유지하는 최선의 방법을 탐구할 수도 있습니다






개요


이 기사에서는 RPM과 YUM 도구를 사용하여 Linux 시스템에서 패키지를 관리하는 방법을 학습할 수 있다. 그 내용은 다음과 같다.


RPM과 YUM을 사용하여 패키지 설치, 다시 설치, 업그레이드 및 제거


버전, 상태, 종속성, 무결성 및 서명을 포함하여, RPM 패키지에 관한 정보 획득


패키지에서 제공하는 파일 확인 및 특정 파일이 어떤 패키지에서 온 것인지 찾기




이 기사는 Linux Professional Institute의 Junior Level Administration(LPIC-1) 시험 101의 Topic 102에서 Objective 102.5에 대비하는 데 도움이 된다. 이 목적의 가중치는 3이다.


전제 조건


본 시리즈에 수록된 기사에서 최대한 많은 도움을 받으려면 Linux에 대한 기초적 지식과 이 기사에서 다루는 명령을 실습할 수 있도록 작동 중인 Linux 시스템이 있어야 한다. 때로는 한 프로그램의 다른 버전들이 서로 결과물 형식이 다를 때도 있으므로, 결과가 항상 여기서 예시하는 내용 및 표시하는 그림과 정확히 일치 않을 수도 있다. 특히, 여기서 보여주는 결과물 중 다수는 이미 시스템에 설치되어 있는 패키지에 따라 큰 차이가 난다. 독자 자신의 결과물도 다를 수 있지만, 중요한 공통 사항을 인식할 수 있어야 한다.






패키지 관리 소개


Ian과 연락하기


Ian은 가장 인기있고 많은 글을 쓰는 저자 중 한 명이다. developerWorks에 실린Ian의 모든 기사를 살펴보자. My developerWorks에서 Ian의 프로파일을 볼 수 있으며 Ian과 다른 저자 및 그를 좋아하는 여러 독자와 연락할 수 있다.




과거에는 많은 Linux 프로그램이 소스 코드로 배포되었고, 사용자는 필요한 매뉴얼 페이지, 구성 파일 등과 함께, 필수 프로그램 또는 프로그램 세트에 Linux 프로그램을 빌드했다. 요즘에는 대부분의 Linux 배포자가패키지라고 하는 미리 빌드된 프로그램 또는 프로그램 세트를 사용하며, 이런 패키지는 배포 시 바로 설치할 수 있도록 출고된다. 이 기사에서는 패키지를 설치, 업데이트 및 제거하는 데 도움이 되는 패키지 관리 도구에 관한 내용을 학습할 수 있다. 이 기사에서는 Red Hat에서 개발한RPM(Red Hat Package Manager)뿐 아니라, 원래는 듀크대학교 물리학과에서 Red Hat Linux 시스템을 관리하기 위해 개발한YUM(Yellowdog Updater Modified)에 초점을 맞춰 설명한다. 본 시리즈의 또 다른 기사인 "Learn Linux 101: Debian package management"에서는 Debian 시스템에서 사용하는 패키지 관리 도구에 대해 다룬다.


사용자 관점에서 볼 때, 기본적인 패키지 관리 기능은 명령에 의해 제공된다. Linux 개발자들이 Linux를 더 사용하기 쉽게 만들기 위해 노력한 결과, 기본 도구의 일부 복잡한 부분을 최종 사용자에게는 보이지 않도록 숨겨주는 GUI 도구를 비롯한 다른 도구들로 기본 도구를 보완했다. 다른 도구 중 몇 가지에 관해서는 독자의 이해를 돕기 위해 언급하겠지만, 본 기사와 Debian package management에 관한 기사에서는 기본 도구에 초점을 맞춰 설명한다.


RPM, YUM 및 APT(Debian 시스템용)는 유사한 점이 많다. 이들 모두 패키지를 설치하고 제거할 수 있다. 설치한 패키지에 관한 정보는 데이터베이스에 보관된다. 이 세 가지 모두 기본적인 명령행 기능이 있고, 추가 도구를 통해 사용자에게 친숙한 인터페이스를 제공할 수 있다. 또한, 이들 모두 인터넷에서 패키지를 검색할 수 있다.


Linux 시스템을 설치할 때, 일반적으로 다수의 패키지를 선택하여 설치하게 된다. 이렇게 선택하는 패키지 세트는 서버, 데스크탑 또는 개발자 워크스테이션과 같이 시스템의 용도에 따라 사용자 정의할 수 있다. 그리고 언젠가는 추가된 기능을 위해 새 패키지를 설치하거나, 가지고 있는 패키지를 업데이트하거나, 더 이상 필요하지 않거나 새 패키지의 등장으로 쓸모없어진 패키지를 제거해야 할 때가 있을 것이다. 이런 작업을 수행하는 방법과 어떤 패키지에 특정 명령이 들어 있을지 찾는 것과 같은 관련 과제 중 몇 가지를 살펴보자.


RPM


Red Hat에서는 1995년에 RPM을 선보였다. RPM은 현재 LSB(Linux Standard Base)에서 패키징을 위해 사용되는 패키지 관리 시스템이다. rpm 명령 옵션은 다음 작업에 대해 세 가지 하위 그룹으로 분류된다.


패키지 쿼리 및 확인


패키지 설치, 업그레이드 및 제거


기타 기능 수행




본 기사에서는 첫 두 명령 옵션 세트에 초점을 맞춰 설명하기로 한다. RPM에 대한 매뉴얼 페이지에서 기타 기능에 관한 정보를 찾을 수 있다.


또한, rpm은 RPM에서 사용되는 기본 명령의 명령 이름인 반면, .rpm은 RPM 파일에 사용하는 확장자라는 점에 유의해야 한다. 따라서 "rpm" 또는 "xxx rpm"은 일반적으로 RPM 파일을 지칭하고, rpm은 보통 명령을 가리킨다.


YUM


YUM은 종속성 관리를 포함한 자동 업데이트 및 패키지 관리 기능을 RPM 시스템에 추가한 것이다. 시스템에 설치된 패키지를 이해하는 것 외에, Debian APT(Advanced Packaging Tool)와 같은 YUM은 일반적으로 네트워크 연결을 통해 액세스할 수 있는 패키지 콜렉션인 저장소에서 작동한다.






RPM 패키지 설치


Lisp를 학습하고 싶은데, 한 동료가 gcl 명령을 사용해보라고 한다고 가정해보자. gcl --help를 사용해보거나 which gcl 또는type gcl을 사용해볼 수도 있을 것이다. 그러나 시스템에서 gcl을 찾을 수 없는 경우 Listing 1에 표시된 것과 유사한 출력이 나타날 수 있다.



Listing 1. gcl 명령이 없는 경우

[ian@echidna ~]$ gcl --help  bash: gcl: command not found    [ian@echidna ~]$ which gcl  /usr/bin/which: no gcl in (/usr/lib64/qt-3.3/bin:/usr/kerberos/sbin:/usr/kerber  os/bin:/usr/lib64/ccache:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/  sbin:/home/ian/bin)    [ian@echidna ~]$ type gcl  bash: type: gcl: not found





동료에게 다시 확인하여 어떤 패키지를 설치할지 찾아내거나 단지 gcl 명령이 gcl 패키지에 있을 것으로 추측할 수도 있을 것이다. 이런 추측이 종종 맞을 때도 있지만, 항상 옳은 것은 아니다. 나중에 올바른 패키지를 찾는 방법을 살펴보겠다. 이 경우에는 gcl 패키지가 반드시 필요하다. 패키지 사본을 다운로드하거나 어디선가 얻었다고 가정하면, Listing 2에 나타낸 것처럼 rpm 명령과 -i(install) 옵션을 사용하여 설치할 수 있을 것이다.



Listing 2. rpm으로 gcl 설치 - 1

[root@echidna ~]# rpm -i gcl-2.6.8-0.6.20090701cvs.fc12.x86_64.rpm  error: Failed dependencies:  gcl-selinux is needed by gcl-2.6.8-0.6.20090701cvs.fc12.x86_64





rpm 명령에서는 패키지에 종속성이 있다는 것을 알지만, 불행히도 이 명령으로 그런 종속성을 해결할 수는 없다. 종속 패키지를 구해 다시 시도한 후 추가적인 종속성이 있는지 확인해야 한다.—그리고 모든 종속성이 충족될 때까지 이 과정을 계속 수행한다. 한 가지 좋은 점은 rpm 명령에 설치할 패키지 목록을 제공할 수 있고, 모든 종속성이 충족되는 경우 이 명령으로 목록에 있는 모든 패키지를 옳은 순서대로 설치할 수 있다는 점이다. 따라서 최소한 각 패키지를 옳은 순서에 따라 수동으로 설치하지 않아도 된다는 점이 좋다.


Debian의 APT를 사용해왔다면, 아마 지금쯤은 종속 항목을 포함하여 필요한 것을 간단히 찾아서 이동하여 그냥 설치하면 되는 apt-get 명령과 같은 것이 있었더라면 하는 생각이 들 것이다. RPM 기반 시스템의 경우, YUM(Yellowdog Updater Modified)이 바로 그런 기능을 제공한다. Listing 3은 yum 명령과 install 옵션을 사용하여 gcl과 필수적인 gcl;-selinux 소프트웨어의 설치 방법을 나타낸 것이다.



Listing 3. yum을 이용한 gcl 설치

[root@echidna ~]# yum install gcl  Loaded plugins: presto, refresh-packagekit  Setting up Install Process  Resolving Dependencies  --> Running transaction check  ---> Package gcl.x86_64 0:2.6.8-0.7.20100201cvs.fc12 set to be updated  --> Processing Dependency: gcl-selinux for package: gcl-2.6.8-0.7.20100201cvs.fc12.x86_64  --> Running transaction check  ---> Package gcl-selinux.x86_64 0:2.6.8-0.7.20100201cvs.fc12 set to be updated  --> Finished Dependency Resolution    Dependencies Resolved    =====================================================================================   Package           Arch         Version                          Repository     Size  =====================================================================================  Installing:   gcl               x86_64       2.6.8-0.7.20100201cvs.fc12       updates       6.3 M  Installing for dependencies:   gcl-selinux       x86_64       2.6.8-0.7.20100201cvs.fc12       updates        17 k    Transaction Summary  =====================================================================================  Install       2 Package(s)  Upgrade       0 Package(s)    Total download size: 6.4 M  Installed size: 40 M  Is this ok [y/N]: y  Downloading Packages:  Setting up and reading Presto delta metadata  updates/prestodelta                                           | 964 kB     00:01       Processing delta metadata  Package(s) data still to download: 6.4 M  (1/2): gcl-2.6.8-0.7.20100201cvs.fc12.x86_64.rpm              | 6.3 MB     00:12       (2/2): gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64.rpm      |  17 kB     00:00       -------------------------------------------------------------------------------------  Total                                                398 kB/s | 6.4 MB     00:16       Running rpm_check_debug  Running Transaction Test  Transaction Test Succeeded  Running Transaction    Installing     : gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64                 1/2     Installing     : gcl-2.6.8-0.7.20100201cvs.fc12.x86_64                         2/2     Installed:    gcl.x86_64 0:2.6.8-0.7.20100201cvs.fc12                                                Dependency Installed:    gcl-selinux.x86_64 0:2.6.8-0.7.20100201cvs.fc12                                        Complete!





Listing 3의 출력을 보면 YUM이 "updates"라는 저장소에서 gcl.x86_64 0:2.6.8-0.7.20100201cvs.fc12와 gcl-selinux.x86_64 0:2.6.8-0.7.20100201cvs.fc12를 찾아(그에 관한 자세한 내용은 곧 설명함) 총 다운로드 크기를 결정했음을 알 수 있다. "y"로 응답하여 트랜잭션에 동의한 후, 두 패키지 모두 다운로드한 다음 종속 항목과 gcl을 차례대로 설치했다. 본 기사 후반부에 종속성에 관해 설명하겠다.






패키지 위치


이전 섹션에서 RPM 패키지 설치 방법을 살펴보았다. 하지만, RPM 패키지는 어디서 온 것일까? yum은 어디서 패키지를 다운로드할지 어떻게 아는 것일까? 출발점은 보통 여러 개의 repo 파일이 들어 있는 /etc/yum.repos.d/ 디렉토리이다. 이 디렉토리는 ropo 파일의 기본 위치이지만, YUM 구성 파일에 다른 위치(보통 /etc/yum.conf)가 지정될 수도 있다. Listing 4에서는 Fedora 12 시스템에 우리가 gcl을 설치한 위치에 해당하는 fedora-updates.repo를 보여준다.


전형적인 repo 파일은 세 개의 섹션으로 나뉘는데, 각각 일반 패키지, 디버그 패키지 및 원본 패키지를 위한 것이다. 보통, 다른 위치 또는 미러에서 사용 가능한 배포 패키지의 사본이 여러 개 있을 것이다. 따라서 repo 파일은 각 섹션에 대한 최신 미러 목록을 찾을 곳을yum에 알려준다. 배포 릴리스 레벨과 시스템 아키텍처가 매개변수화되므로, yum은 https://mirrors.fedoraproject.org/metalink?repo=updates-released-f12&arch=x86_64에서 내 x86_64 Fedora 12 시스템에 대한 목록을 다운로드한다.


저장소 위치 외에도, repo 파일은 특정 저장소를 사용하는지 여부와 다운로드한 패키지를 확인하는 데 GPG 서명을 사용해야 할지 여부를 알려준다.



Listing 4. /etc/yum.repos.d/*.repo

[ian@echidna ~]$ cat /etc/yum.repos.d/fedora-updates.repo  [updates]  name=Fedora $releasever - $basearch - Updates  failovermethod=priority  #baseurl=http://download.fedoraproject.org/pub/fedora/linux/updates/$releasever  /$basearch/  mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=updates-released-f$r  eleasever&arch=$basearch  enabled=1  gpgcheck=1  gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-$basearch    [updates-debuginfo]  name=Fedora $releasever - $basearch - Updates - Debug  failovermethod=priority  #baseurl=http://download.fedoraproject.org/pub/fedora/linux/updates/$releasever  /$basearch/debug/  mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=updates-released-deb  ug-f$releasever&arch=$basearch  enabled=0  gpgcheck=1  gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-$basearch    [updates-source]  name=Fedora $releasever - Updates Source  failovermethod=priority  #baseurl=http://download.fedoraproject.org/pub/fedora/linux/updates/$releasever  /SRPMS/  mirrorlist=https://mirrors.fedoraproject.org/metalink?repo=updates-released-sou  rce-f$releasever&arch=$basearch  enabled=0  gpgcheck=1  gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-$basearch





YUM과 RPM은 로컬 데이터베이스를 사용하여 어떤 패키지가 설치되어 있는지 확인한다. 로컬 데이터베이스에 저장되어 있는 패키지에 관한 메타데이터는 사용되는 저장소에서 검색된다. 로컬 데이터베이스에 대해 걱정할 필요는 거의 없겠지만, yum clean 명령을 사용하여 로컬에 저장된 다양한 정보를 정리하고 yum makecache 명령을 사용하여 사용하는 repo에 관한 정보를 로컬 데이터베이스에서 작성한다. 예를 들어, repo 구성을 변경하는 경우 이 작업을 하게 될 것이다.






RPM 패키지 제거


패키지를 제거하려면 yum의 remove 옵션이나 rpm의 -e 옵션을 사용하면 된다. rpm -e를 사용하여 gcl을 제거하기 위한 테스트 실행이 Listing 5에 표시되어 있다. 패키지를 제거할 수 있는 경우 출력은 없다.



Listing 5. gcl 제거 테스트

[root@echidna ~]# rpm -e --test gcl





apt-get을 이용한 Debian 패키지의 시뮬레이션 제거와는 달리, RPM 시스템에서는 자동으로 추가된 패키지에 관한 정보는 유지하지 않으므로, 어떤 종속성도 제거될 수 있는지 찾을 수 있는 분명한 방법은 없다. 하지만, 단일 명령으로 제거할 패키지를 여러 개 지정하면 종속성을 가진 패키지에 앞서 종속성이 없는 패키지가 먼저 제거된다.


rpm을 사용하여 패키지를 제거하는 경우, 패키지를 설치할 때와는 달리 패키지가 제거되기 전에는 프롬프트가 나타나지 않는다. 하지만, 다른 패키지에 필수적인 패키지를 제거하려 하는 경우 제거 작업이 수행되지 않고 Listing 6에 표시된 것과 같은 오류 메시지가 나타난다.



Listing 6. rpm으로 종속 패키지 제거

[root@echidna ~]# rpm -e gcl-selinux  error: Failed dependencies:   gcl-selinux is needed by (installed) gcl-2.6.8-0.7.20100201cvs.fc12.x86_64





yum remove를 대신 사용하는 경우에는 트랜잭션 테스트가 수행된 후 프롬프트가 표시된다. 제거하려는 패키지가 설치된 다른 패키지에 대한 종속 패키지인 경우에는, Listing 7에 나타낸 것처럼 YUM이 해당 패키지뿐 아니라 종속 패키지까지 제거한다.



Listing 7. yum으로 종속 패키지 제거

[root@echidna ~]# yum remove gcl-selinux  Loaded plugins: presto, refresh-packagekit  Setting up Remove Process  Resolving Dependencies  --> Running transaction check  ---> Package gcl-selinux.x86_64 0:2.6.8-0.7.20100201cvs.fc12 set to be erased  --> Processing Dependency: gcl-selinux for package: gcl-2.6.8-0.7.20100201cvs.fc12.x86_64  --> Running transaction check  ---> Package gcl.x86_64 0:2.6.8-0.7.20100201cvs.fc12 set to be erased  --> Finished Dependency Resolution    Dependencies Resolved    =====================================================================================   Package          Arch        Version                            Repository     Size  =====================================================================================  Removing:   gcl-selinux      x86_64      2.6.8-0.7.20100201cvs.fc12         @updates       90 k  Removing for dependencies:   gcl              x86_64      2.6.8-0.7.20100201cvs.fc12         @updates       40 M    Transaction Summary  =====================================================================================  Remove        2 Package(s)  Reinstall     0 Package(s)  Downgrade     0 Package(s)    Is this ok [y/N]: n  Exiting on user Command  Complete!  









RPM 패키지 업그레이드


이제 RPM을 설치 및 제거하는 방법을 알고 있으므로, RPM 패키지를 새 레벨로 업그레이드하는 방법을 살펴보자. yum update를 사용하여 전체 시스템을 업데이트하거나 단일 패키지 또는 와일드카드 스펙을 지정할 수 있다. Listing 8은 이름이 "gr"로 시작되는 패키지를 전부 업데이트하는 방법을 설명한 것이다. 아포스트로피를 사용하여 "*"의 쉘 확장을 막는다는 점에 유의한다.



Listing 8. yum update를 이용한 업데이트

[root@echidna ~]# yum update 'gr*'  Loaded plugins: presto, refresh-packagekit  Setting up Update Process  Resolving Dependencies  --> Running transaction check  ---> Package grep.x86_64 0:2.6.3-1.fc12 set to be updated  ---> Package groff.x86_64 0:1.18.1.4-20.fc12 set to be updated  --> Finished Dependency Resolution    Dependencies Resolved    =====================================================================================   Package         Arch             Version                    Repository         Size  =====================================================================================  Updating:   grep            x86_64           2.6.3-1.fc12               updates           228 k   groff           x86_64           1.18.1.4-20.fc12           updates           1.5 M    Transaction Summary  =====================================================================================  Install       0 Package(s)  Upgrade       2 Package(s)    Total download size: 1.7 M  Is this ok [y/N]: y  Downloading Packages:  Setting up and reading Presto delta metadata  Processing delta metadata  Download delta size: 854 k  http://fedora.fastsoft.net/pub/linux/fedora/linux/updates/12/x86_64/drpms/grep-2.5.3-  6.fc12_2.6.3-1.fc12.x86_64.drpm: [Errno 14] HTTP Error 404 : http://fedora.fastsoft.n  et/pub/linux/fedora/linux/updates/12/x86_64/drpms/grep-2.5.3-6.fc12_2.6.3-1.fc12.x86_  64.drpm   Trying other mirror.  (1/2): grep-2.5.3-6.fc12_2.6.3-1.fc12.x86_64.drpm             | 214 kB     00:00       (2/2): groff-1.18.1.4-18.fc12_1.18.1.4-20.fc12.x86_64.drpm    | 640 kB     00:00       Finishing rebuild of rpms, from deltarpms  <delta rebuild>                                               | 1.7 MB     00:02       Presto reduced the update size by 52% (from 1.7 M to 854 k).  Running rpm_check_debug  Running Transaction Test  Transaction Test Succeeded  Running Transaction    Updating       : grep-2.6.3-1.fc12.x86_64                                      1/4     Updating       : groff-1.18.1.4-20.fc12.x86_64                                 2/4     Cleanup        : grep-2.5.3-6.fc12.x86_64                                      3/4     Cleanup        : groff-1.18.1.4-18.fc12.x86_64                                 4/4     Updated:    grep.x86_64 0:2.6.3-1.fc12             groff.x86_64 0:1.18.1.4-20.fc12                Complete!





RPM 파일이 있는 곳을 알거나 RPM 파일을 다운로드한 경우, rpm 명령을 사용하여 업데이트할 수도 있다. 이는 -i 옵션 대신 -U 또는 -F 옵션을 사용하는 점을 제외하면 설치와 유사하다. 이 두 옵션의 차이점은 -U 옵션을 사용하면 기존 패키지가 업그레이드되거나 이미 설치된 패키지가 없는 경우 패키지가 설치되는 반면, -F 옵션을 사용하면 이미 설치된 패키지만 업그레이드되거나 새로 갱신된다는 점이다. 이 때문에, 특히 명령행에 RPM 목록이 포함되어 있을 때 -U 옵션이 자주 사용된다. 이런 식으로, 설치 안 된 패키지가 설치되고 이미 설치된 패키지는 업그레이드된다. 진행률을 나타내기 위해 -v(verbose) 및 -h(hash 표시)의 두 가지 다른 옵션이 자주 사용된다. Listing 9는 rpm 명령을 사용하여 vim-common, vim-enhanced 및 vim-minimal 패키지를 업데이트하는 방법을 나타낸 것이다. 루트의 홈 디렉토리에 이미 다운로드한 vim-common 및 vim-enhanced 패키지가 있으며, 업데이트 미러 중 하나에서 vim-minimal 패키지를 검색한다.



Listing 9. rpm을 이용한 패키지 업데이트

[root@echidna ~]# ls *.rpm  vim-common-7.2.411-1.fc12.x86_64.rpm  vim-enhanced-7.2.411-1.fc12.x86_64.rpm  [root@echidna ~]# rpm -Uvh *.rpm http://mirrors.usc.edu/pub/linux/distributions\  > /fedora/linux/updates/12/x86_64/vim-minimal-7.2.411-1.fc12.x86_64.rpm  Retrieving http://mirrors.usc.edu/pub/linux/distributions/fedora/linux/updates/12/x86  _64/vim-minimal-7.2.411-1.fc12.x86_64.rpm  Preparing...                ########################################### [100%]     1:vim-common             ########################################### [ 33%]     2:vim-enhanced           ########################################### [ 67%]     3:vim-minimal            ########################################### [100%]  









RPM 패키지 쿼리


앞의 예에서 rpm 명령으로 rpm을 설치하려면 gcl-2.6.8-0.6.20090701cvs.fc12.x86_64.rpm과 같은 패키지 파일의 전체 이름(또는 URL)이 필요하다. 이에 반해, yum으로 설치하거나 어느 한 명령으로 rpm을 제거하려면 gcl과 같은 패키지 이름만 있으면 된다. APT와 마찬가지로, RPM은 설치된 패키지의 내부 데이터베이스를 유지하므로, 패키지 이름을 사용하여 설치된 패키지를 조작할 수 있다. 이 섹션에서는 rpm 명령의 -q(query) 옵션이나 연관된 yum 쿼리를 사용하여 이 데이터베이스에서 사용 가능한 몇 가지 정보를 살펴본다.


기본 쿼리에서는 단순히 패키지 설치 여부만 묻고, 설치된 경우 어떤 버전인지 묻는다. -i 옵션을 추가하고 패키지에 관한 정보를 얻는다. 패키지를 설치, 업그레이드 또는 제거하려면 루트 권한이 있어야 하지만, 루트 권한이 없는 사용자는 rpm 데이터베이스를 상대로 쿼리를 수행할 수 있다.



Listing 10. gcl에 관한 정보 표시

                      [ian@echidna ~]$ yum list gcl  Loaded plugins: presto, refresh-packagekit  Installed Packages  gcl.x86_64                  2.6.8-0.7.20100201cvs.fc12                  @updates  [ian@echidna ~]$ rpm -q gcl  gcl-2.6.8-0.7.20100201cvs.fc12.x86_64    [ian@echidna ~]$ yum info gcl  Loaded plugins: presto, refresh-packagekit  Installed Packages  Name       : gcl  Arch       : x86_64  Version    : 2.6.8  Release    : 0.7.20100201cvs.fc12  Size       : 40 M  Repo       : installed  From repo  : updates  Summary    : GNU Common Lisp  URL        : http://www.gnu.org/software/gcl/  License    : GPL+ and LGPLv2+  Description: GCL is a Common Lisp currently compliant with the ANSI standard.             : Lisp compilation produces native code through the intermediary of             : the system's C compiler, from which GCL derives efficient             : performance and facile portability. Currently uses TCL/Tk as GUI.    [ian@echidna ~]$ rpm -qi gcl  Name        : gcl                          Relocations: (not relocatable)  Version     : 2.6.8                             Vendor: Fedora Project  Release     : 0.7.20100201cvs.fc12          Build Date: Tue 23 Mar 2010 03:20:36 PM EDT  Install Date: Wed 05 May 2010 01:01:34 PM EDT      Build Host: x86-02.phx2.fedoraproject.  org  Group       : Development/Languages         Source RPM: gcl-2.6.8-0.7.20100201cvs.fc12.sr  c.rpm  Size        : 41667750                         License: GPL+ and LGPLv2+  Signature   : RSA/8, Tue 23 Mar 2010 04:14:06 PM EDT, Key ID 9d1cc34857bbccba  Packager    : Fedora Project  URL         : http://www.gnu.org/software/gcl/  Summary     : GNU Common Lisp  Description :  GCL is a Common Lisp currently compliant with the ANSI standard.  Lisp  compilation produces native code through the intermediary of the  system's C compiler, from which GCL derives efficient performance and  facile portability. Currently uses TCL/Tk as GUI.





더 광범위한 목록에는 RPM 패키지와 연관될 수 있는 태그 중 일부도 함께 표시된다. rpm과 yum은 약간 다른 형식으로 약간 다른 정보를 표시하는 것을 알 수 있다. 본 기사에서는 표준 출력 옵션에서 제공하는 기본 출력을 고수하기로 한다. rpm --queryformat 옵션을 사용하여 사용자 정의 쿼리 출력을 빌드하려면 매뉴얼 페이지를 참조한다. 가지고 있는 rpm 버전에서 지원하는 모든 태그를 알고 싶으면 rpm --querytags를 실행해보면 된다.


Listing 10에 나타낸 것처럼, yum을 사용하여 설치된 패키지를 나열할 수 있다. 또한, 사용 가능한 업데이트가 있는 패키지, 설치를 위해 사용 가능한 패키지, 사용되지 않음 또는 최근에 저장소에 추가됨과 같은 다른 특성을 가진 패키지를 나열할 수도 있다. 더구나 yum을 사용하여 패키지를 검색할 수도 있다. Listing 11에는 texmacs 패키지는 설치되어 있지 않지만 fedora 저장소에서 사용 가능한 것을 볼 수 있다. "texmacs"를 검색하면 texmacs를 언급하는 4개의 패키지가 나타난다. TeXmacs* 패키지가 검색된 이유를 쉽게 알 수 있다. yum info pydot를 사용하여 pydot 패키지도 언급된 이유를 찾아낸다.



Listing 11. gcl에 관한 정보 표시

                      [ian@echidna ~]$ yum list texmacs  Loaded plugins: presto, refresh-packagekit  Available Packages  TeXmacs.x86_64                         1.0.7.2-2.fc12                          fedora  [ian@echidna ~]$ yum search texmacs  Loaded plugins: presto, refresh-packagekit  ================================= Matched: texmacs ==================================  TeXmacs-devel.i686 : Development files for TeXmacs  TeXmacs-devel.x86_64 : Development files for TeXmacs  TeXmacs.x86_64 : Structured wysiwyg scientific text editor  pydot.noarch : Python interface to Graphviz's Dot language  





나머지 쿼리 예제에서는 주로 rpm을 사용하는데, 여기에 더 광범위한 옵션 세트가 있기 때문이다. 이들 예제 중 다수는 yum으로도 수행할 수 있는데, yum에는 기본적인 rpm 옵션에는 없는 기능이 몇 가지 있다. 자세한 내용은 매뉴얼 페이지를 참조한다.


RPM 패키지와 그에 포함된 파일


패키지에 무엇이 들어 있는지, 특정 파일이 어떤 패키지에 있던 것인지 등을 알고 싶을 때가 종종 있을 것이다. gcl 패키지에 있는 파일 목록을 보려면 Listing 12에 나타낸 것처럼 -ql 옵션을 사용한다. 이 패키지에는 수많은 파일이 있으므로, 출력 중 일부만 표시했다.



Listing 12. gcl 패키지에 있는 파일 표시

[ian@echidna ~]$ rpm -ql gcl  /usr/bin/gcl  /usr/lib/gcl-2.6.8  /usr/lib/gcl-2.6.8/clcs  /usr/lib/gcl-2.6.8/clcs/sys-proclaim.lisp  /usr/lib/gcl-2.6.8/cmpnew  /usr/lib/gcl-2.6.8/cmpnew/gcl_cmpmain.lsp  /usr/lib/gcl-2.6.8/cmpnew/gcl_cmpopt.lsp  /usr/lib/gcl-2.6.8/cmpnew/gcl_collectfn.lsp  .  .  .  /usr/share/info/gcl-tk.info.gz  /usr/share/info/gcl.info-1.gz  /usr/share/info/gcl.info-2.gz  /usr/share/info/gcl.info-3.gz  /usr/share/info/gcl.info-4.gz  /usr/share/info/gcl.info-5.gz  /usr/share/info/gcl.info-6.gz  /usr/share/info/gcl.info-7.gz  /usr/share/info/gcl.info-8.gz  /usr/share/info/gcl.info-9.gz  /usr/share/info/gcl.info.gz  /usr/share/man/man1/gcl.1.gz





쿼리에 -c 옵션을 추가하여 나열되는 파일을 구성 파일로만 한정할 수 있다. 이와 유사하게, -d 옵션을 사용하면 표시되는 파일이 문서 파일만으로 제한된다.


패키지 파일 쿼리


위 패키지 쿼리 명령은 RPM 데이터베이스에 설치된 패키지에 대해 쿼리한다. 방금 패키지를 다운로드한 상태에서 같은 종류의 정보를 원하는 경우, (패키지 설치에 사용할) 패키지 파일 이름을 지정하는 것 외에도, 쿼리에 -p(package file) 옵션을 사용하여 이 정보를 얻을 수 있다. Listing 13에는 앞서 다운로드한 두 vim 패키지에 대해 이 정보가 표시된다. 파일이 루트의 홈 디렉토리에 있었기 때문에 이것을 루트로만 실행한다. -l과 같은 다른 쿼리 옵션을 추가하여 파일 목록을 표시하거나 -i 옵션을 추가하여 정보를 나열할 수 있다.



Listing 13. 두 개의 vim 패키지에 대한 패키지 파일 정보 표시

[root@echidna ~]# rpm -qp *.rpm  vim-common-7.2.411-1.fc12.x86_64  vim-enhanced-7.2.411-1.fc12.x86_64





설치된 모든 패키지 쿼리


-a 옵션을 사용하면 설치된 모든 패키지에 쿼리가 적용된다. 이렇게 하면 많은 출력이 생성될 수 있으므로 대개의 경우 하나 이상의 필터와 함께 이 옵션을 사용하는데, 목록을 정렬하려면 sort, 목록 페이지를 전후로 이동하려면 more 또는 less, 패키지 또는 파일 수를 확인하려면 wc, 이름이 확실치 않아 패키지를 검색하려면 grep을 사용한다. Listing 14는 다음 쿼리를 나타낸 것이다.


시스템에 있는 모든 패키지가 정렬되어 표시되는 목록


시스템에 있는 모든 패키지의 개수


시스템에 있는 모든 패키지에 있는 모든 파일의 개수


RPM과 함께 설치된 모든 문서 파일의 개수


이름에 "gcl"(대/소문자 구분)이 포함된 모든 패키지 검색





Listing 14. 모든 패키지에 대한 쿼리

                      [ian@echidna ~]$ rpm -qa | sort | more  aalib-libs-1.4.0-0.18.rc5.fc12.x86_64  abrt-1.0.8-2.fc12.x86_64  abrt-addon-ccpp-1.0.8-2.fc12.x86_64  abrt-addon-kerneloops-1.0.8-2.fc12.x86_64  abrt-addon-python-1.0.8-2.fc12.x86_64  abrt-desktop-1.0.8-2.fc12.x86_64  abrt-gui-1.0.8-2.fc12.x86_64  abrt-libs-1.0.8-2.fc12.x86_64  abrt-plugin-bugzilla-1.0.8-2.fc12.x86_64  abrt-plugin-logger-1.0.8-2.fc12.x86_64  abrt-plugin-runapp-1.0.8-2.fc12.x86_64  abyssinica-fonts-1.0-5.fc12.noarch  acl-2.2.49-2.fc12.x86_64  ...  [ian@echidna ~]$ rpm -qa | wc -l  1792  [ian@echidna ~]$ rpm -qal | wc -l  281052  [ian@echidna ~]$ rpm -qad | wc -l  45686  [ian@echidna ~]$ rpm -qa | grep -i gcl  gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64  gcl-2.6.8-0.7.20100201cvs.fc12.x86_64  





rpm -qa를 사용하면 여러 시스템을 손쉽게 관리할 수 있다. 한 시스템에 있는 파일로 정렬된 출력을 리디렉션한 후 다른 시스템에서도 똑같이 하는 경우, diff 프로그램을 사용하면 차이점을 찾을 수 있다.


어떤 패키지가 파일을 소유하고 있는가?


모든 패키지와 패키지에 있는 모든 파일의 목록을 표시할 수 있으므로, 어떤 패키지에 어떤 파일이 있는지 찾기 위해 필요한 정보를 모두 가지고 있는 셈이다. 하지만, rpm 명령을 사용할 때 -f(또는 --file) 옵션을 추가하면 어떤 파일이 있는 패키지를 찾는 데 도움이 된다. 앞서 본 vim 패키지 중 어떤 패키지에서 실제로 vim 명령을 제공하는지 알고 싶다고 해보자. 파일의 전체 경로가 필요할 것이다. Listing 15는 which 명령을 사용하여 vim 명령에 대한 전체 경로를 찾는 방법과 이 출력을 rpm -qf 명령에 대한 입력으로 사용하기 위한 편리한 팁을 나타낸 것이다. `which guile-config`를 둘러싼 눈금 표시가 역방향의 눈금으로 표시된다는 점에 유의한다. Bash 쉘에서 이것을 다르게 사용하는 방법은 $(which vim)을 사용하는 것이다.



Listing 15. vim 실행 파일을 제공하는 패키지 찾기

                      [ian@echidna ~]$ which vim  /usr/bin/vim  [ian@echidna ~]$ rpm -qf `which vim`  vim-enhanced-7.2.411-1.fc12.x86_64  [ian@echidna ~]$ rpm -qf $(which vim)  vim-enhanced-7.2.411-1.fc12.x86_64





RPM 종속성


앞에서 종속성 때문에 gcl-selinux 패키지 지우기에 실패한 것을 보았다. 파일 외에도, RPM 패키지에는 다른 패키지가 종속될 수 있는 임의의 기능이 포함될 수 있다.


앞서 본 바와 같이, 이 문제는 보통 잘 풀린다. 한 번에 여러 개의 패키지를 설치해야 하고 이들 중 일부 패키지가 다른 패키지에 종속될 수 있는 경우에는 단순히 yum을 사용하거나 rpm -Uvh 명령에 전체 목록을 제공하면 종속성이 분석되고 설치 작업이 올바른 순서로 수행된다.


패키지를 설치하거나 지우고 오류 메시지를 받는 것 외에도, 패키지에서 꼭 필요하거나 패키지가 종속되는 파일이나 기능이 무엇인지 찾는 방법이 있다.


rpm 명령에서는 설치된 패키지나 패키지 파일이 어떤 기능에 종속되거나 어떤 기능을 요구하는지 찾기 위해 이런 패키지나 패키지 파일을 조사하는 옵션을 제공한다. 이는 --requires 옵션으로, -R로 줄여서 표시할 수 있다. Listing 16은 gcl에서 필수적인 기능을 나타낸 것이다. RPM 데이터베이스 대신 패키지 파일을 쿼리하려면 -p 옵션을 추가하고 전체 RPM 파일 이름을 사용한다.



Listing 16. gcl에서 필수적인 것

[ian@echidna ~]$ rpm -qR gcl  /bin/sh    /bin/sh    /bin/sh    /sbin/install-info    /sbin/install-info    gcl-selinux    libX11.so.6()(64bit)    libc.so.6()(64bit)    libc.so.6(GLIBC_2.11)(64bit)    libc.so.6(GLIBC_2.2.5)(64bit)    libc.so.6(GLIBC_2.3)(64bit)    libc.so.6(GLIBC_2.3.4)(64bit)    libc.so.6(GLIBC_2.4)(64bit)    libc.so.6(GLIBC_2.7)(64bit)    libc.so.6(GLIBC_2.8)(64bit)    libdl.so.2()(64bit)    libgmp.so.3()(64bit)    libm.so.6()(64bit)    libm.so.6(GLIBC_2.2.5)(64bit)    libreadline.so.6()(64bit)    libtcl8.5.so()(64bit)    libtk8.5.so()(64bit)    libz.so.1()(64bit)    rpmlib(CompressedFileNames) <= 3.0.4-1  rpmlib(FileDigests) <= 4.6.0-1  rpmlib(PayloadFilesHavePrefix) <= 4.0-1  rtld(GNU_HASH)    rpmlib(PayloadIsXz) <= 5.2-1  





기능과 그 기능을 제공하는 패키지를 일치시키는 것은 다소 미묘한 문제일 수 있다. 여기서는 yum 명령과 deplist 옵션을 함께 사용하면 도움이 될 수 있다. 해당 버전에서 규정되지 않은 패키지 이름만 제공하면 알려진 다른 버전에 대한 목록을 얻을 수 있다. Listing 17은 설치되어 있는 gcl의 버전에 대한 종속성 목록만 얻는 방법을 나타낸 것이다.



Listing 17. yum deplist를 사용하여 gcl에서 필요한 것을 찾는 방법

[ian@echidna ~]$ yum deplist $(rpm -q gcl)  Loaded plugins: presto, refresh-packagekit  Finding dependencies:   package: gcl.x86_64 2.6.8-0.7.20100201cvs.fc12    dependency: libc.so.6(GLIBC_2.3.4)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: gcl-selinux     provider: gcl-selinux.x86_64 2.6.8-0.6.20090701cvs.fc12     provider: gcl-selinux.x86_64 2.6.8-0.7.20100201cvs.fc12    dependency: libgmp.so.3()(64bit)     provider: gmp.x86_64 4.3.1-5.fc12    dependency: libc.so.6(GLIBC_2.8)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libc.so.6(GLIBC_2.4)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libc.so.6()(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: /sbin/install-info     provider: info.x86_64 4.13a-7.fc12     provider: info.x86_64 4.13a-9.fc12    dependency: libX11.so.6()(64bit)     provider: libX11.x86_64 1.3-1.fc12    dependency: libc.so.6(GLIBC_2.7)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libtcl8.5.so()(64bit)     provider: tcl.x86_64 1:8.5.7-4.fc12     provider: tcl.x86_64 1:8.5.7-5.fc12    dependency: libc.so.6(GLIBC_2.11)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libtk8.5.so()(64bit)     provider: tk.x86_64 1:8.5.7-2.fc12     provider: tk.x86_64 1:8.5.7-3.fc12    dependency: libc.so.6(GLIBC_2.3)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libm.so.6()(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libz.so.1()(64bit)     provider: zlib.x86_64 1.2.3-23.fc12    dependency: rtld(GNU_HASH)     provider: glibc.i686 2.11-2     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6     provider: glibc.i686 2.11.1-6    dependency: libdl.so.2()(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libreadline.so.6()(64bit)     provider: readline.x86_64 6.0-3.fc12    dependency: /bin/sh     provider: bash.x86_64 4.0.33-1.fc12     provider: bash.x86_64 4.0.35-3.fc12    dependency: libc.so.6(GLIBC_2.2.5)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6    dependency: libm.so.6(GLIBC_2.2.5)(64bit)     provider: glibc.x86_64 2.11-2     provider: glibc.x86_64 2.11.1-6





이 목록에는 각각의 기능에 대해 가능한 공급자도 표시된다. 한 패키지에 대해 둘 이상의 다른 레벨에서 대부분의 종속성이 제공될 수 있음을 알 수 있다. 예를 들어, /bin/sh는 두 가지 레벨의 bash 중 하나에서 가져올 수 있다. Listing 18에 나타낸 것처럼, 약간 창의적인 필터링을 이용해 이 출력을 패키지 이름 목록으로 줄일 수 있다.



Listing 18. 패키지 이름만 표시하도록 yum deplist 출력을 줄이는 방법

[ian@echidna ~]$ yum deplist $(rpm -q gcl) | grep "provider:" | \  > awk '{ print $2 }'|sort|uniq  bash.x86_64  gcl-selinux.x86_64  glibc.i686  glibc.x86_64  gmp.x86_64  info.x86_64  libX11.x86_64  readline.x86_64  tcl.x86_64  tk.x86_64  zlib.x86_64





어떤 패키지를 설치해야 할 것인지만 알면 되는 경우, 항상 yum install을 실행하면 설치 제안 사항에 동의하라는 프롬프트가 나타나기 전에 목록부터 확인할 수 있다.


패키지에서 어떤 기능이 필요한지 알아내는 것 외에도, 어떤 패키지에서 특정 기능을 제공하는지 알아내야 할 수도 있다. 위에서 어떤 패키지가 특정 파일을 소유하고 있는지 찾는 방법을 살펴보았다. Listing 19는 rpm 또는 yum을 사용하여 어떤 패키지에서 gcl-selinux(x86-64) 기능을 제공하는지 찾는 방법을 나타낸 것이다. 설치된 패키지 중 해당 기능을 제공하는 패키지에 관한 정보 외에, YUM을 사용하면 저장소에서 사용 가능한 패키지나 버전도 표시된다. 이들은 fedora 저장소에 있는 원본 2.6.8-0.6 버전과 업데이트 저장소에서 구할 수 있는 업데이트된 2.6.8-0.7 버전이다.



Listing 19. gcl-selinux(x86-64) 기능을 제공하는 패키지 찾기

[ian@echidna ~]$ rpm -q --whatprovides 'gcl-selinux(x86-64)'  gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64  [ian@echidna ~]$ yum whatprovides 'gcl-selinux(x86-64)'  Loaded plugins: presto, refresh-packagekit  gcl-selinux-2.6.8-0.6.20090701cvs.fc12.x86_64 : SELinux policy for GCL images  Repo        : fedora  Matched from:  Other       : gcl-selinux(x86-64)        gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64 : SELinux policy for GCL images  Repo        : updates  Matched from:  Other       : gcl-selinux(x86-64)        gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64 : SELinux policy for GCL images  Repo        : installed  Matched from:  Other       : Provides-match: gcl-selinux(x86-64)









RPM 패키지 파일의 무결성


무결성 확인을 위해, RPM 패키지에는 MD5 또는 SHA1과 같은 다이제스트가 포함되어 있고 보통 디지털 서명이 되어 있다. 디지털 서명이 되어 있는 패키지는 확인을 위한 공개 키가 필요하다. RPM 패키지 파일의 무결성을 확인하려면 rpm의 --checksig(약어는 -K) 옵션을 사용한다. 일반적으로 더 자세한 출력을 얻으려면 -v 옵션을 추가하는 것이 유용하다는 사실을 알 수 있을 것이다. Listing 20은 vim-enhanced RPM에 대한 예제를 나타낸 것이다.



Listing 20. vim-enhanced 패키지 파일의 무결성 확인

                      [root@echidna ~]# rpm -vK vim-enhanced-7.2.411-1.fc12.x86_64.rpm  vim-enhanced-7.2.411-1.fc12.x86_64.rpm:      Header V3 RSA/SHA256 signature: OK, key ID 57bbccba      Header SHA1 digest: OK (f9a199545a515f7ff0716729768b41eb68fe29a8)      V3 RSA/SHA256 signature: OK, key ID 57bbccba      MD5 digest: OK (d4045f1f72d48073e3f401ee9d1f71cf)





다음과 같은 출력 행이 나타날 수 있다.


V3 DSA 서명: NOKEY, 키 ID 16a61572


이것은 서명된 패키지는 있지만 RPM 데이터베이스에 필요한 공개 키는 없다는 의미이다. RPM의 이전 버전에서는 다른 확인 결과를 표시할 수도 있다.


어떤 패키지가 서명되어 있고 이를 어떤 서명에 대해 확인하려는 경우, 알맞은 서명 파일을 찾아서 RPM 데이터베이스로 가져와야 한다. 우선, 키를 다운로드하고 키의 지문을 확인한 후 rpm --import 명령을 사용하여 키를 가져와야 한다. 자세한 내용은 RPM 매뉴얼 페이지를 참조한다. RPM 홈 페이지(링크는 참고자료 참조)에서 서명된 2진 파일에 관한 자세한 내용을 확인할 수도 있다.






설치된 패키지 확인


rpm의 무결성 확인과 같이, rpm -V를 사용하여 설치된 파일의 무결성을 확인할 수도 있다. 이 단계에서는 rpm에서 파일이 설치된 이후로 파일이 수정된 적이 없음을 확인한다. Listing 21에 표시된 것처럼, 패키지가 여전히 양호한 상태이면 이 명령을 실행할 때 아무 것도 출력되지 않지만, -v 옵션을 추가하면 훨씬 더 자세한 출력 결과를 얻을 수 있다.



Listing 21. 설치된 vim-common 패키지 확인

                      [ian@echidna ~]$ rpm -V vim-common





루트 권한을 가진 상태에서 /usr/bin/xxd를 삭제하고 /usr/share/vim/vim72/syntax/bindzone.vim /bin/bash를 바꾸어 vim-common 설치를 손상시켜 보자. 그리고 다시 확인을 해보자. Listing 22에 결과가 표시된다.



Listing 22. vim-common 패키지 무단 변경

                      [root@echidna ~]# rpm -qf /usr/bin/xxd /usr/share/vim/vim72/syntax/bindzone.vim  vim-common-7.2.411-1.fc12.x86_64  vim-common-7.2.411-1.fc12.x86_64  [root@echidna ~]# rm /usr/bin/xxd  rm: remove regular file `/usr/bin/xxd'? y  [root@echidna ~]# cp /bin/bash /usr/share/vim/vim72/syntax/bindzone.vim  cp: overwrite `/usr/share/vim/vim72/syntax/bindzone.vim'? y  [root@echidna ~]# rpm -V vim-common  missing     /usr/bin/xxd  S.5....T.    /usr/share/vim/vim72/syntax/bindzone.vim





이 출력 결과는 /usr/share/vim/vim72/syntax/bindzone.vim 파일이 MD5 합계, 파일 크기 및 mtime 테스트에 실패하는 것을 나타낸다. 이 문제를 해결하는 한 가지 방법은 패키지를 제거한 후 다시 설치하는 것이지만, vim-common에 종속되고 여전히 양호한 상태로 설치되어 있는 다른 패키지가 있다. 이에 대한 해결책은 rpm의 --force 옵션 또는 yum의 reinstall 함수를 사용하여 패키지를 강제로 다시 설치하는 것이다. Listing 23은 yum으로 다시 설치한 후 패키지가 현재 양호하고 삭제된 파일이 복원되었는지 확인하는 방법을 나타낸 것이다.



Listing 23. vim-common 패키지 다시 설치

                      [root@echidna ~]# yum reinstall vim-common  Loaded plugins: presto, refresh-packagekit  Setting up Reinstall Process  Resolving Dependencies  --> Running transaction check  ---> Package vim-common.x86_64 2:7.2.411-1.fc12 set to be updated  --> Finished Dependency Resolution    Dependencies Resolved    =====================================================================================   Package            Arch           Version                     Repository       Size  =====================================================================================  Reinstalling:   vim-common         x86_64         2:7.2.411-1.fc12            updates         6.0 M    Transaction Summary  =====================================================================================  Remove        0 Package(s)  Reinstall     1 Package(s)  Downgrade     0 Package(s)    Total download size: 6.0 M  Installed size: 17 M  Is this ok [y/N]: y  Downloading Packages:  Setting up and reading Presto delta metadata  updates/prestodelta                                           | 969 kB     00:00       Processing delta metadata  Package(s) data still to download: 6.0 M  vim-common-7.2.411-1.fc12.x86_64.rpm                          | 6.0 MB     00:01       Running rpm_check_debug  Running Transaction Test  Transaction Test Succeeded  Running Transaction  Warning: RPMDB altered outside of yum.    Installing     : 2:vim-common-7.2.411-1.fc12.x86_64                            1/1     Installed:    vim-common.x86_64 2:7.2.411-1.fc12                                                     Complete!  [root@echidna ~]# rpm -V vim-common  [root@echidna ~]# ls /usr/bin/xxd  /usr/bin/xxd  





더 강력한 기능이 필요한 경우


대체로 패키지 관리 시스템에서는 패키지를 순서대로 보관한다. 하지만, 패키지의 중요한 부분인 어떤 파일을 어떻게 해서든 삭제하고—패키지를 제거하지 않고 다시 설치해도 문제가 해결되지 않는 경우—패키지를 제거한 후 다시 설치해야 할 수도 있다. 그런 경우, 아마 기존 사본에 종속되지 않는 모든 패키지를 설치 제거하고 다시 설치할 필요 없이 기존 사본을 삭제하고 다시 설치하고 싶을 것이다. 이렇게 하려면 패키지를 제거할 때 rpm 명령의 --nodeps 옵션을 사용하여 종속성 확인을 생략하면 된다. Listing 24는 앞서 실습한 것처럼 이렇게 하면 vim-common 패키지의 일부인 /usr/bin/xxd 파일을 실수로 제거한 경우 어떻게 되는지를 나타낸 것이다.



Listing 24. rpm을 이용한 패키지 업데이트

[root@echidna ~]# rm /usr/bin/xxd  rm: remove regular file `/usr/bin/xxd'? y  [root@echidna ~]# # Oops! we needed that file  [root@echidna ~]# rpm -Fvh vim-common-7.2.411-1.fc12.x86_64.rpm   [root@echidna ~]# ls /usr/bin/xxd  ls: cannot access /usr/bin/xxd: No such file or directory  [root@echidna ~]# # Oh! Freshening the package didn't replace the missing file  [root@echidna ~]# rpm -e vim-common  error: Failed dependencies:   vim-common = 2:7.2.411-1.fc12 is needed by (installed) vim-enhanced-2:7.2.411-1.f  c12.x86_64  [root@echidna ~]# # Can't remove vim-common because vim-enhanced needs it  [root@echidna ~]# rpm -e --nodeps vim-common  [root@echidna ~]# # Bypassing the dependency check allowed removal  [root@echidna ~]# rpm -Uvh vim-common-7.2.411-1.fc12.x86_64.rpm   Preparing...                ########################################### [100%]     1:vim-common             ########################################### [100%]  [root@echidna ~]# # Update (or install) vim-common again  [root@echidna ~]# ls /usr/bin/xxd  /usr/bin/xxd  [root@echidna ~]# # And /usr/bin/xxd is back  





이제는 사고가 발생하여 통상적인 업데이트 프로세스에 실패하는 경우 업데이트하거나 복구하기 위한 몇 가지 접근 방식을 알게 되었을 것이다. RPM을 설치할 때 종속성 확인을 생략할 수도 있지만, 이는 대체로 좋은 방법이 아니다.






저장소에서 RPM 다운로드


yum을 사용하면 저장소에서 패키지가 자동으로 검색되지만, 네트워크로 연결되지 않은 시스템에 RPM을 설치하거나 그 내용을 검사하거나 다른 이유로 RPM을 다운로드하여 저장하고 싶을 때가 있을 것이다. Listing 25에 나타낸 것처럼 yumdownloader 명령을 사용할 수 있다. 예제의 경우, 패키지가 이미 설치되어 있으므로 추가로 다운로드할 패키지는 없다. 그런 패키지가 있는 경우 --resolve 옵션을 사용하면 패키지도 다운로드된다.



Listing 25. gcl 패키지 다운로드

[ian@echidna ~]$ yumdownloader --resolve gcl  Loaded plugins: presto, refresh-packagekit  adobe-linux-i386                                                               17/17  --> Running transaction check  ---> Package gcl.x86_64 0:2.6.8-0.7.20100201cvs.fc12 set to be updated  --> Finished Dependency Resolution  gcl-2.6.8-0.7.20100201cvs.fc12.x86_64.rpm                     | 6.3 MB     00:01     









rpm2cpio 사용


RPM을 다운로드한 후 설치하지 않고 그 내용을 검사할 필요가 있는 경우, rpm2cpio 명령을 사용하면 내용을 cpio 아카이브로 변환한 다음 cpio 명령을 통해 아카이브를 필터링하여 패키지에 있는 개별 파일이나 모든 파일을 추출할 수 있다. Listing 26은 gcl-selinux 패키지에 대해 이 작업을 수행하는 방법과 어떤 파일과 디렉토리의 압축이 풀렸는지를 나타낸 것이다. 이들 명령에 관한 추가 정보는rpm2cpio 및 cpio의 매뉴얼 페이지를 참조한다.



Listing 26. rpm2cpio로 gcl-selinux 패키지 압축 풀기

[ian@echidna ~]$ yumdownloader gcl-selinux  Loaded plugins: presto, refresh-packagekit  gcl-selinux-2.6.8-0.7.20100201cvs.fc12.x86_64.rpm        |  17 kB     00:00       [ian@echidna ~]$ mkdir gcl-selinux  [ian@echidna ~]$ cd gcl-selinux  [ian@echidna gcl-selinux]$ rpm2cpio ../gcl-selinux*.rpm | cpio -idv  ./usr/share/selinux/packages/gcl  ./usr/share/selinux/packages/gcl/gcl.pp  182 blocks  [ian@echidna gcl-selinux]$ find .  .  ./usr  ./usr/share  ./usr/share/selinux  ./usr/share/selinux/packages  ./usr/share/selinux/packages/gcl  ./usr/share/selinux/packages/gcl/gcl.pp







RPM 찾기


앞에서 YUM이 패키지 이름뿐 아니라 설명도 검색하는 검색 기능을 제공한다는 사실을 살펴보았다. 설치되어 있지 않은 프로그램이 어떤 패키지에 들어 있는지 찾아야 하는 경우, 다른 방법이 몇 가지 있다.


어떤 패키지에 해당 프로그램이 들어 있는지 추측하여 설치는 하지 않고 패키지를 다운로드할 수 있다. 패키지를 다운로드한 후 패키지를 조사할 수 있다.


인터넷을 검색할 수 있다.


아래에서 설명하는 command-not-found 기능을 사용할 수도 있다.




시스템 도구를 통해 특정 RPM을 찾을 수 없는 경우, RPM을 찾는 데 유용한 인터넷 자원은 Rpmfind.Net 서버이다(링크는 참고자료 참조).


Command not found


Bash 쉘에서 어떤 명령을 검색했는데 찾지 못하는 경우, 쉘에서는 command_not_found_handle이라는 이름의 쉘 함수를 검색한다.command_not_found_handle 함수가 있는 경우 이 함수는 원래 명령과 원래 인수를 자신의 인수로 하여 호출되고 함수의 종료 상태는 쉘의 종료 상태가 된다. 이 함수가 정의되어 있지 않은 경우 쉘에서는 오류 메시지를 인쇄하고 종료 상태인 127을 리턴한다. 이 함수는 보통 시스템 /etc/bash.bashrc 파일에서 설정된다. Listing 27은 command-not-found 기능을 검색한 후 설치한 방법을 나타낸 것이다.



Listing 27. command-not-found 기능을 찾아서 설치하는 방법

[root@echidna ~]# yum search command-not-found  Loaded plugins: presto, refresh-packagekit  ========================== Matched: command-not-found ==========================  PackageKit-command-not-found.x86_64 : Ask the user to install command line                                      : programs automatically  You have new mail in /var/spool/mail/root  [root@echidna ~]# yum install PackageKit-command-not-found.x86_64  Loaded plugins: presto, refresh-packagekit  Setting up Install Process  Resolving Dependencies  --> Running transaction check  ---> Package PackageKit-command-not-found.x86_64 0:0.5.7-2.fc12 set to be updated  --> Finished Dependency Resolution    Dependencies Resolved    ================================================================================   Package                          Arch       Version          Repository   Size  ================================================================================  Installing:   PackageKit-command-not-found     x86_64     0.5.7-2.fc12     updates     102 k    Transaction Summary  ================================================================================  Install       1 Package(s)  Upgrade       0 Package(s)    Total download size: 102 k  Installed size: 262 k  Is this ok [y/N]: y  Downloading Packages:  Setting up and reading Presto delta metadata  Processing delta metadata  Package(s) data still to download: 102 k  PackageKit-command-not-found-0.5.7-2.fc12.x86_64.rpm     | 102 kB     00:00       Running rpm_check_debug  Running Transaction Test  Transaction Test Succeeded  Running Transaction    Installing     : PackageKit-command-not-found-0.5.7-2.fc12.x86_64         1/1     Installed:    PackageKit-command-not-found.x86_64 0:0.5.7-2.fc12                                Complete!  





Listing 28은 PackageKit-command-not-found를 설치한 후 함수 핸들이 어떻게 정의되는지를 나타낸 것이다. 함수에서 검색을 수행할 수 없는 경우 함수는 표준 시스템 작동을 모방하여 127을 리턴한다.



Listing 28. command_not_found_handle

[ian@echidna ~]$ type command_not_found_handle  command_not_found_handle is a function  command_not_found_handle ()   {       runcnf=1;      retval=127;      [ ! -S /var/run/dbus/system_bus_socket ] && runcnf=0;      [ ! -x /usr/sbin/packagekitd ] && runcnf=0;      if [ $runcnf -eq 1 ]; then          /usr/libexec/pk-command-not-found $1;          retval=$?;      else          echo "bash: $1: command not found";      fi;      return $retval  }





Listing 1에서 했던 것처럼 gcl을 실행하기 전에 command_not_found_handle이 설치되어 있었다면 Listing 29와 같은 결과를 얻었을 것이다.



Listing 29. command_not_found_handle로 gcl 시도

[ian@echidna ~]$ gcl  Command not found. Install package 'gcl' to provide command 'gcl'? [N/y]   







기타 도구


yum과 rpm 외에, 배포자는 저장소에서 패키지를 설치하거나 전체 시스템을 업데이트하기 위해 다른 도구를 제공할 수 있다. 이런 도구는 그래픽 도구나 명령행 도구 또는 두 가지 모두일 수 있다. 몇 가지 예를 들면 다음과 같다.


YaST(SUSE)


up2date(Red Hat)


Mandrake Software Management(Mandriva)




보통 이런 도구들은 자동 또는 반자동 방식으로 여러 가지 패키지 업데이트를 처리한다. 또한, 저장소의 내용을 표시하거나 패키지를 검색하기 위한 기능을 제공할 수도 있다. 자세한 내용은 배포 제품의 설명 문서를 참조한다.






PackageKit


소프트웨어 설치 및 업데이트를 더 쉽게 만들기 위해 디자인된 시스템인 PackageKit을 언급하지 않고 패키지 설치에 관한 논의를 마칠 수는 없다. 이는 다른 배포 버전에서 사용되는 모든 소프트웨어 그래픽 도구를 통합하자는 취지이다. PackageKit은 시스템에서 활성화된 디먼을 사용하는데, 이는 디먼이 필요할 때만 활성화된다는 뜻이다. Packagekit에는 Gnome(gnome-packagekit) 및 KDE(KPackageKit)에 대한 버전이 있다. 위에서 설명한 command-not-found 핸들 역시 PackageKit에 속한다. Packagekit에는 콘솔에서 패키지 관리 기능을 수행하기 위한 pkcon 명령과 패키지 킷 활동을 모니터하기 위한 pkmon 명령이 포함된다. 또한, 소프트웨어 패키지를 추가하거나 시스템을 업데이트하기 위한 그래픽 도구도 포함된다. 그림 1은 Software Update 그래픽 인터페이스의 예를 나타낸 것이다.



그림 1. Fedora 12(Gnome)의 Software Update 그래픽 인터페이스


여기서 다룬 것보다 훨씬 많은 RPM 및 YUM 패키지 관리 시스템이 있다. 추가 링크는 참고자료를 참조한다.



참고자료


교육


developerWorks roadmap for LPIC-1에서 2009년 4월 시험 목적을 바탕으로 실시되는 LPIC-1 인증 시험 공부에 도움이 되는 developerWorks 기사를 찾을 수 있다.




LPIC Program 사이트를 방문하면 Linux Professional Institute에서 제공하는 세 가지 레벨의 Linux 시스템 관리 인증에 대한 자세한 목적, 과제 목록 및 샘플 문제를 확인할 수 있다. 특히, LPI exam 101과 LPI exam 102에 대해서는 2009년 4월 시험 목적을 확인한다. 최신 시험 목적은 항상 LPIC Program 사이트를 참조한다.




Linux 기초를 학습하고 2009년 4월 이전의 LPI 시험 목적을 바탕으로 하는 시스템 관리자 인증 시험을 준비하려면 developerWorks에 관한 전체 LPI exam prep series를 검토한다.




RPM 홈 페이지에서 RPM 소프트웨어 패키징 도구에 관한 최신 정보와 RPM에 관한 더 많은 정보를 볼 수 있는 포인터를 찾을 수 있다. 




Maximum RPM(도서)에서는 RPM의 모든 측면을 포괄적이고 체계적으로 다룬 내용을 살펴볼 수 있다. 하드카피와 소프트카피 형식으로 모두 제공된다. 




LSB Home에서 표준 2진 운영 환경을 개발하기 위한 FSG(Free Standards Group) 프로젝트인 LSB(Linux Standard Base)에 관해 학습할 수 있다. 




PackageKit에 대한 자세한 내용은 PackageKit 홈 페이지를 참조한다.




Linux Documentation Project에는 특히 HOWTO(기술 노하우)를 포함한 다양하고 유용한 문서가 수록되어 있다. 




developerWorks 리눅스 영역에서는 Linux 개발자와 관리자에게 도움이 되는 수백 편의 사용법 기사 및 튜토리얼과 다운로드, 토론 포럼 및 기타 다양한 참고자료를 볼 수 있다. 




developerWorks 기술 행사 및 웹 캐스트를 통해 다양한 IBM 제품 및 IT 산업 주제에 대한 최신 정보를 얻을 수 있다. 




무료 developerWorks Live! briefing을 통해 최신 IBM 제품 및 도구에 대한 정보뿐만 아니라 IT 업계의 최신 경향까지도 빠르게 확인할 수 있다. 




developerWorks on-demand demos에서는 입문자를 위한 제품 설치 및 설정부터 숙련된 개발자를 위한 고급 기능까지 망라된 다양한 데모를 제공한다. 




Twitter의 developerWorks를 팔로우(follow)하거나 developerWorks에 대한 Linux 트윗(tweet)의 피드를 구독하자. 






제품 및 기술 얻기


Fedora/12 Public Active Mirrors와 같은 배포 미러 중 하나에 있는 패키지를 찾아본다.




Rpmfind.Net과 RPM Search에서 해당 배포 버전에 맞는 RPM을 검색한다. 




자신에게 가장 적합한 방법으로 IBM 제품을 평가해 보자. 시험판 제품을 다운로드하거나 온라인으로 제품을 사용해 보거나 클라우드 환경에서 제품을 사용하거나 SOA Sandbox에서 SOA(Service Oriented Architecture)를 효과적으로 구현하는 방법을 배울 수 있다. 






토론


포럼에 참여하기.




My developerWorks 커뮤니티에 참여하자. 개발자 중심 블로그, 포럼, 그룹 및 Wiki 검색 중에 다른 developerWorks 사용자와 의견을 교환해 보자. 






필자소개


Ian Shields는 developerWorks 리눅스 영역을 위한 리눅스 프로젝트 다수를 수행하고 있다. Shields는 노스 캐롤라이나 주 소재 IBM 리서치 트라이앵글 파크에서 선임 프로그래머로 일한다. Shields는 1973년 시스템 엔지니어로 오스트레일리아, 캔베라에 있는 IBM 사무실에 들어갔으며 캐나다 몬트리얼과 노스 캐롤라이나 주 RTP에서 통신 시스템과 배포 컴퓨팅 부문에서 일해왔다. Shields는 특허 여러 건을 획득했으며, 논문 여러 건을 발표했다. Shields는 순수 수학과 철학 학사 학위를 오스트레일리안 국립 대학에서 받았다. 노스 캐롤라이나 주립 대학에서 컴퓨터 과학 분야를 대상으로 석사와 박사 학위를 받았다. 전자편지 주소는 ishields@us.ibm.com이다.








'리눅스관련' 카테고리의 다른 글

Debian VMware Tools 설치하기  (0) 2011.06.06
ubuntu taxt 모드 에서 사용하는 명령어  (0) 2011.06.06
Git 명령어 정리  (0) 2011.06.06
samba IP allow setting  (0) 2011.06.06
CenOS 유용한 명령어  (0) 2011.06.06


[프로세스 관련 명령어]

▣학습목표
1. 프로세스 관련 용어를 이해한다.
2. 프로세스 명령어를 익힌다.

▣용어정리
1. 프로그램 : 하드디스크에 저장되어 있는 파일중에서 
                 실행가능한 파일
2. 프로세스 : 메모리에 로딩된 프로그램
3. 데    몬  : 부팅중에 메모리에 로딩되어 종료될 때까지 
                 상주해 있는 프로그램
         (윈도우에서는 서비스라 부른다.)

프로세스는 여러 가지 자원(CPU,메모리,장치)을 사용한다.
프로세스는 해당 명령을 수행하기 위해 CPU 를 점유하기도 하고
명령어와 데이터를 저장하기 위해 물리적인 메모리를 사용한다.
프로세스는 운영체제의 제어를 받으면서 실행,대기,중단,좀비 의
한 상태를 갖는다.
실행(running) : 프로세스가 현재 실행중인 상태
대기(waiting) : 운영체제가 자원을 할당해 주기를 기다리는 상태
중단(stopped) : 인터럽트를 받는 경우
좀비(zombie)  : 프로세스가 종료된 상태이지만 정보가 완전히 
                     삭제되지 않고 남아 있는 경우
리눅스 프로세스는 프로그램을 실행하는데 필요한 PID,UID,GID 정보를 포함한다.

PID(Process ID)   : 프로세스가 시작할 때 할당받는 프로세스 식별번호
UID(User ID)      : 사용자 번호
GID(Group ID)    : 그룹 번호

프로세스 정보가 있는 디렉토리 : /proc
/proc 에는 각 프로세스에 해당하는 PID 디렉토리가 있다.
/proc 는 가상의 디렉토리로 커널 메모리를 마운트 한 것이다.

 

 

 


▣프로그램 실행 방식
1. foreground : 전면실행(터미널을 프로그램이 점유하고 있는
                    상태로 프로그램이 종료 될 때까지 다른 명령어
             를 실행할 수 없다.)

2. background : 후면실행(프로그램은 실행되면서 쉘프롬프트가 
                     나타나므로 프로그램을 계속 실행시킬 수 있다.)
                     예) 윈도우 도스창

---> 리눅스 터미널은 디폴트가 포그라운드 방식이다.
백그라운드 실행시키는 방법 : 명령어 &  또는 명령어&

 

 

 

 

 

 

 

#oclock
---> 기본적으로 포그라운드 로 실행된다.

시계종료(마우스 이용)

 


#oclock  &
[1]  1234
#oclock  &
[2]  1235
#oclock&
[3]  1236

백그라운드로 프로그램을 실행시키면 번호가 두 개 나타나는데
첫번째 번호는 백그라운드로 실행된 프로그램 갯수 번호
두번째는 프로세스 아이디(PID) 이다.
리눅스 운영체제는 파일,프로세스,계정 등 을 모두 숫자로 구분해서 관리한다.

PID(Process ID) : 프로세스를 구분하는 번호

 

 

 

 

 

<프로세스 관련 명령어>
#ps
현재 터미널에서 실행된 프로세스만 출력
TTY 는 프로그램이 실행된 터미널을 의미

#tty
현재 사용하고 있는 터미널 출력
(/dev/pts/번호)

 

 

 

 

 

 

 

모든 프로세스 출력하기
#ps  -ef
#ps  aux 또는 ps axu


ps(process status) : 프로세스 상태 출력

옵션
 -a : 모든 프로세스(all) 상태 출력
 -e : 현재 실행중인 모든 프로세스(every) 상태 출력
 -f : full list로 출력
 -l : long list로 출력
 -m : 메모리 정보(쓰레드)를 출력
 -t TTY : 지정한 TTY를 가진 프로세스 정보 출력(ps  -t  pts/2)
 -u : 사용자 이름, 시작시간을 보여준다
 -p PID : 지정한 PID(프로그램 번호)를 가진 프로세스 정보 출력
 -u UID : 지정한 UID(사용자 번호)를 가진 프로세스 정보 출력
 -g GID : 지정한 GID(그룹 번호)를 가진 프로세스 정보 출력
 -x : 제어 터미널을 갖지 않은 프로세스도 출력(? 로 나타나는 프로세스)

 

 

 

 

 

 


#ps  aux  |  more
ps  aux  결과의  헤드라인 항목

PID(Process ID)          : 프로세스마다 주어지는 번호
TTY(Tele TYpewrite)    : 명령어가 실행되는 터미널의 번호
STAT(STATE)             : 실행되고 있는 프로세스 상태
    R                        : 실행 중 혹은 실행될 수 있는 상태
    S                        : sleep
    T                        : 정지된 상태 (suspend)
    Z                        : 좀비 (zombie) 프로세스
    X                        : dead (should never be seen)
    W                       : 스왑 out 된 상태
    <                       : 우선 순위가 인위적으로 높아진 상태

START(START)            : 프로세스가 시작된 시간
TIME(TIME)                : CPU가 사용한 시간
USER(USER)               : 사용자의 이름
COMMAND(COMMAND)  : 사용자가 실행한 명령어
UID(User ID)                : 사용자의 ID
(Parent Group ID)         : 사용자 부모 프로세스의 그룹 ID
PRI(PRIority)               : 실행하는 우선 순위에 따른 프로세스
NI(Nice)                     : nice 에 의한 우선 순위에 따른 프로세스
RSS(Resident Set Size)   : 프로세스가 사용하는 메모리의 크기
SZ(SiZe)                     : 프로세스가 사용하는 자료와 스택의 크기
SHRD(ShaReD)            : 프로세스가 사용하는 공유 메모리
%CPU                        : 프로세스가 사용하는 CPU 점유율
%MEM                      : 프로세스가 사용하고 있는 메모리 점유율
WCHAN                     : 프로세스가 실행하고 있는 커널함수

 

 

 

 

 

#man  ps
ps 명령어에 대한 매뉴얼을 확인하면 위의 정보를 확인할 수 있다.

51 번 라인
525 번 라인
623 번 라인

 

pstree : 프로세스를 트리 구조로 출력
#pstree

 

 

top : 시스템의 전체적인 상황(CPU,메모리,프로세스 정보)을 실시간으로 출력

형식)
top 또는 top -d 초


#top
첫번째 줄 : 시스템의 현재시간, 부팅후 작동한 시간, 현재 사용자 수, load average(CPU 부하 평균값)

load average :
1분, 5분, 15분간의 시스템 평균 부하율

두번째 줄 : 프로세스의 상태(실행,대기,중단,좀비)

세번째 줄 : CPU 상태
us : User 가 사용중인 CPU 사용률(user)
sy : 시스템 이 사용하는 CPU 사용률(system)
ni : nice 에 사용되는 CPU 사용률(nice)
id : 사용되지 않는 CPU 미사용률(idle)
wa : 입출력 대기상태 사용률(wait)
hi : 하드웨어 인터럽트
si : 소프트웨어 인터럽트


네번째 줄, 다섯번째 줄 : 총 사용가능한 메모리, 사용된 메모리, 
                              스왑 메모리 등 메모리에 대한 정보
나머지    : 각 프로세스에 대한 정보
            (기본적으로 CPU 사용률을 기준으로 정렬 된다.)

VIRT : 가상메모리 사용량(SWAP + RES)
RES : 스왑되지 않은 물리적 메모리 사용량(Resident Size)
SHR : 공유 메모리 사이즈

종료 : q


//////////////////////////////////////////////////////////////////////////
#man top

    309        o: VIRT  --  Virtual Image (kb)
    310           The total amount of virtual memory used by the task.   It  inc
    310 ludes
    311           all  code,  data  and  shared  libraries  plus pages that have
    311  been
    312           swapped out.
    313
    314           VIRT = SWAP + RES.
    315
    317        p: SWAP  --  Swapped size (kb)
    318           The swapped out portion of a task’s total virtual memory image
    318 .
    319
    321        q: RES  --  Resident size (kb)
    322           The non-swapped physical memory a task has used.
    323
    324           RES = CODE + DATA.
    325
    327        r: CODE  --  Code size (kb)
    328           The amount of physical memory  devoted  to  executable  code,
    328  also
    329           known as the ’text resident set’ size or TRS.

    332        s: DATA  --  Data+Stack size (kb)
    333           The  amount  of  physical  memory  devoted to other than execu
    333 table
    334           code, also known as the ’data resident set’ size or DRS.
    335
    337        t: SHR  --  Shared Mem size (kb)
    338           The amount of shared memory used by a  task.   It  simply  ref
    338 lects
    339           memory that could be potentially shared with other processes.
    340
//////////////////////////////////////////////////////////////////////////

 

 

 

 

 

 

 

 

nice : 프로그램 실행시 우선순위를 지정하는 명령어
형식)
nice  [-20 에서 19 의 숫자]   [명령어]
(숫자가 작을 수록 우선 순위가 높음)

sleep : 대기 명령어
형식)
sleep  초

 

#nice  -17  sleep 100  &
#ps  -l

 

 

 

 

 


#gnome-system-monitor
시스템 모니터링 프로그램, GUI 방식

 

 


pmap(process map)
프로세스의 메모리 주소 공간을 확인 할 수 있다.
응용 프로그램이 실행될 때 얼마나 많은 라이브러리가 load 되는지 
확인 할 수 있다.

#ps
1234  bash
#pmap PID (ps 결과에서 bash 의 PID 를 입력)

 

 

 

 

 

 

 

 

 


#jobs 
현재 터미널에서 백그라운드로 실행된 프로세스 출력
+ 는 가장 최근의 작업
- 는 그 이전 작업


#fg  %2(또는 fg  2)
2번 시계를 포그라운드로 전환
---> 쉘에 따라서 % 를 사용해야 하는 경우가 있다.

ctrl + z : 프로세스 중지(stop) 시키는 단축키

#jobs


#bg  %2
(2번 시계를 백그라운드로 전환)
#jobs

 

 

 

 

 

 

 

 

 


#ps  -ef  |  grep  oclock
UID   PID   PPID  C  STIME   TTY    TIME      CMD

root  3201  2521  0  16:17   pts/1  00:00:00  oclock
root  3202  2521  0  16:17   pts/1  00:00:00  oclock
root  3203  2521  0  16:17   pts/1  00:00:00  oclock 

grep oclock 은 ps -ef | grep oclock 명령어 자신이 출력된 것임

PID(Process ID)             : 프로세스 아이디
PPID(Parent Process ID) : 부모프로세스 아이디
                                    (oclock 의 부모프로세스는 bash 쉘이 된다.)

 

 

 

 

 


pgrep : 프로세스를 필터링 하는 명령어

//////////////////////////////////////////////////////////////////////////
#man  pgrep

PGREP(1)                           Linux User’s Manual                           PGREP(1)

NAME
       pgrep, pkill - look up or signal processes based on name and other attributes

       -f     The  pattern is normally only matched against the process name.  When -f is
              set, the full command line is used.

       -l     List the process name as well as the process ID. (pgrep only.)
//////////////////////////////////////////////////////////////////////////

#pgrep  oclock
#pgrep  -lf  oclock 또는 #pgrep  -fl  oclock

 

 

 

 

 

 

 

 

 

커맨드(Command)로 프로그램을 종료시키는 방법 : kill 또는 pkill 명령 이용

kill 다음에는 PID(숫자) 가 와야 하고
pkill 다음에는 프로그램 이름(문자)이 와야 한다.


#kill   oclock
---> X
#pkill  oclock
3개의 시계가 모두 종료된다.

 

 

 

 

 

 

 

 

 

백그라운드로 시계 3개 실행하기

#pgrep  -lf  oclock
1234  oclock
1235  oclock
1236  oclock


#kill  1234(자신의 가상머신 터미널에서 출력된 PID 사용하기)
디폴트로 15번 시그널 전달
종료됨 출력

#kill  -9  1235(두번째 시계 프로그램 번호)
9번 시그널 전달
죽었음 출력

#kill  -2  1236
인터럽트 시그널 전달
인터럽트 출력

 

 

 

 

 

 

 

시그널(Signal) : 리눅스 프로그램에 보내는 신호

시그널 종류
#kill  -l
1  헙시그널(프로세스 재시작)
2  인터럽트(단축키는 ctrl+c)
9  강제종료
15 자연스럽게 종료 (디폴트 시그널)


자격증 문제 : 280, 286

 

 

 

 

 

 

 

 

백그라운드로 시계 3 개 실행하기
#pkill  oclock
종료됨(디폴트로 15번 시그널 전달 됨)

백그라운드로 시계 3 개 실행하기
#pkill  -9  oclock
죽었음
(kill 과 pkill 이 사용하는 시그널은 동일하다)

 

 

 

 

 

 

 

 

 

▣실습
2 의 1000000 승 계산하기
bc : 계산기 프로그램 명령어
+ 덧셈
- 뺄셈
* 곱셈
/ 나눗셈
^ 자승
#bc
quit(계산기 종료)

#echo 2+3
#echo 2+3 | bc

#echo 2^3
---> 2 X 2 X 2 = 8
#echo 2^3 | bc

포그라운드로 실행된 상태에서 프로세스를 중지시킨후 
백그라운드로 다시 실행시키기

 

 

 

 

 

 

//////////////////////////////////////////////////////
#echo 2^1000000 | bc
ctrl + z 입력
#jobs
#bg %1 (jobs 에서 출력된 [] 안의 번호를 적는다.)
#jobs
//////////////////////////////////////////////////////

 

 

 

 

 

 


//////////////////////////////////////////////////////////////////////////
시그널 참조)
http://www.joinc.co.kr/modules/moniwiki/wiki.php/Site/system_programing/Signal/SignalHow


bc 에서 나누기 연산시 소수점 이하까지 구할 때)
#bc
scale=3
10/3
3.333
//////////////////////////////////////////////////////////////////////////

 

 

 

 

 


■nohup
부모 프로세스가 종료되어도 메모리에 남아있게 해 주는 명령어

//////////////////////////////////////////////////////////////////////////
#man  nohup

NOHUP(1L)                                                           NOHUP(1L)

이름
       nohup  -  Hangup에 무관하게 명령을 수행하고 tty아닌 곳에 출력을 하도록
       한다.

개요
       nohup 명령 [인수...]
       nohup {--help,--version}

설명
       이 맨페이지는 GNU 버전의 nohup 을 다룬다.  nohup 은 명령 에   대 하 여
       Hangup 신호를 무시한 채 수행하며 우선권을 5 만큼 증가시켜여러분이 로그
       아웃한 후에도 계속 백그라운드로 실행할 수 있도록 해준다. 
//////////////////////////////////////////////////////////////////////////

 

 

 

 

 

 

♠\(역슬래쉬) 사용하기
\ : 해석 금지의 의미
#\rm  파일명
---> 알리아스 해석을 하지 않으므로 질문없이 삭제 됨

#cd  aa\ bb
---> 공백이 들어간 폴더 이동

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

[패키지 관리]
♠학습목표
1. 리눅스에서 사용되는 프로그램 배포 방식을 이해한다.
2. rpm, yum 명령어 사용법을 익힌다.


<패키지 관리>
패키지(Package) : 프로그램 파일이 들어있는 상자 개념

프로그램 배포 단위  
레드햇 리눅스 : rpm 패키지
데비안 리눅스 : debian 패키지

rpm 패키지 이름 구성
mc-4.6.0-2.i386.rpm
--->패키지이름-릴리스버전-아키텍처

 

명령어형식 : rpm  옵션  패키지명

옵션
-qa   : 설치된 패키지 목록 확인 (q : query, a : all)
-e     : 삭제 (e : erase)
-ivh   : install
-Uvh  : Upgrade


설치 및 업그레이드시 옵션
v            : verbose, 설치과정 자세히 출력
h, --hash  : # 마크 표시, 보통 v 옵션과 같이 사용
nodeps    : 의존성을 검사하지 않음
force       : --oldpackage, --replacefiles, --replacepkgs 를 합한 옵션
test         : 실제 설치하지 않고 점검

 

 

 

 

 


rpm -qi    : 패키지 정보 (information)
rpm -qf    : 파일이 속한 패키지 출력(file)
rpm -ql    : 패키지 파일 목록(list, location)
rpm -qs    : 패키지 상태(status)
rpm -qc    : 패키지 설정 파일(configuration)

rpm 의 단점 : 의존성 문제(먼저 설치되어 있어야 하는 
패키지가 없는 경우 설치가 안 된다.)


[A 패키지]-------------------------------[B 패키지]
                  의존성(dependency)

 

 

 

 

 

 

 

yum :  인터넷 파일서버에서 패키지를 다운받아 설치해 준다.
         관련 패키지가 있을 경우 한꺼번에 설치해 준다.
         (의존성 문제 해결)
         인터넷이 되야 사용할 수 있다.


#cd  /etc/yum.repos.d
#ls
(yum 사용시 패키지 다운받는 서버 목록 이 저장되어 있다.)
#cat  CentOS-Base.repo


yum  (-y)  install     : 설치
yum  check-update  : 업데이트 가능한 목록
yum  update          : 업데이트
yum  remove         : 삭제
yum  info              : 정보 출력
yum  list               : 패키지 목록 출력
yum  grouplist       : 패키지 그룹 목록 출력
yum  groupinstall   : 패키지 그룹 설치
yum  search  단어   : 단어가 들어간 패키지 검색
yum  localinstall     :  CD 의 패키지를 설치할 때 사용


사용 예 : yum  -y  install  mc
(-y 를 생략하면 설치시 질문이 출력된다.)

 

 

 

 

 

 

♠rpm 사용하기
(Redhat Package Management)
 

#rpm  -qa
리눅스 CD 에 들어있는 프로그램 형태는 rpm 패키지로
rpm -qa 하게 되면 하드디스크에 설치된 rpm 패키지 목록이 
모두 출력된다.
q : query(물어보다)
a : all


#cd  /var/lib/rpm
(패키지 데이타베이스가 있는 디렉토리)
#ls

 

 

 

 

 


패키지(프로그램) 설치 유무 확인 방법 :
0)rpmquery  패키지명  패키지명  ...
1)rpm  -q  패키지명  패키지명  ...
2)rpm  -qa  |  grep  패키지명

#rpmquery  zip
#rpm  -q  zip
#rpm  -qa  |  grep  zip
zip-2.3-27
--->설치된 프로그램(패키지) 목록 중에서 zip 관련 패키지만 필터링

 

 

 

 

 

 

 

 


zip 패키지 삭제
#rpm -e zip (rpm -e zip-2.3-27 로 해도 동일하다.)
오류: Failed dependencies:
        zip >= 2.1 is needed by (installed) libgcj-3.4.6-8.i386
        zip >= 2.1 is needed by (installed) libgcj-devel-3.4.6-8.i386
---> 다른 패키지와 의존성이 있어서 삭제가 안 된다.

 

 

 

 

 

 

 

 

#rpm -e --nodeps zip
의존성 무시하고 삭제하기

#rpm  -q  zip
#rpm  -qa  |  grep  zip
zip 패키지는 삭제했으므로 나타나지 않는다.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

#gftp
---> X (리눅스 가상머신 터미널에서 실행하기)
gftp : 윈도우의 알FTP와 같은 FTP 클라이언트 프로그램


#yum -y install gftp
--->gftp(ftp 프로그램)를 인터넷에 있는 CentOS 서버에서
     다운받아 설치하는 명령어

다운이 안 될 경우 #netconfig 이용해서 DHCP 설정후
#service network restart 한 후 다시 해 본다.

 

 

 

 

 


[cent]
#gftp (---> putty 에서 실행하면 안 되고 리눅스 가상머신 터미널에서
              실행해야 한다.
       putty 터미널은 그래픽 프로그램을 사용할 수 없다.)


호스트   : 수업용 서버 아이피(172.16.7.252)
사용자   : 아이디(andylec)
비밀번호 : 암호입력
(위와같이 적고 엔터를 입력한다. 탭키를 누르면 
커서가 다음칸으로 이동된다.)

테스트 환경 :
[리눅스 가상머신]--------------------------[수업용 FTP 서버]

리눅스의 한글 코드와 win7 의 한글 코드가 틀려서
한글 폴더 이름은 나타나지 않는다.
(LANG 변수를 ko_KR.eucKR 로 설정하면 한글 폴더 이름이 출력된다.)
#export  LANG=ko_KR.eucKR
다시 리눅스 한글로 설정하려면
#export  LANG=ko_KR.UTF-8 
로 설정하면 된다.

 

 


수업용 FTP 서버 Linux1lab 디렉토리로 이동후
gftp-2.0.17-6.i386.rpm,
zip-2.3-27.i386.rpm 
파일을
cent 리눅스 /work 디렉토리에 다운받는다.
가운데 왼쪽 화살표 아이콘(◀) 클릭

접속종료는 호스트 왼쪽 녹색 컴퓨터 아이콘을 클릭하면 된다.
다운받은 후 gftp 종료하기(오른쪽 상단 X 클릭)

 

 

 

 

 

 


#cd  /work
#ls

#file zip-2.3-27.i386.rpm
zip-2.3-27.i386.rpm: RPM v3 bin i386 zip-2.3-27
#
--->RPM 패키지 파일이라는 의미

file : 대상 파일의 Type(종류)를 출력해 주는 명령어

 

 

 

 

 

 


#rpm  -qlp  zip-2.3-27.i386.rpm
설치안 된 패키지안의 파일목록 출력
p : 패키지를 뜻하며 설치전에는 p 옵션을 지정해야 한다.

 

 


#rpm  -ivh  --test  zip-2.3-27.i386.rpm
준비 중...              

########################################### [100%]
#
---> --test 옵션을 지정했으므로 실제로 설치되지 않는다.
---> rpm 파일이 있는 디렉토리, /work 에서 해야 함

 

 

 

 

 

 

 


#rpm -ivh  zip-2.3-27.i386.rpm 
(rpm  -Uvh  zip-2.3.27.i386.rpm 해도 설치된다.)
--->패키지(리눅스 프로그램) 설치하기

준비 중...              

########################################### [100%]
   1:zip                   

########################################### [100%]
#
rpm  -ivh  : 설치
rpm  -Uvh : 업그레이드(이전 버전이 있으면 업그레이드를 하고
                설치가 안 되어 있으면 프로그램이 설치 됨)

 

 

 

 

 

 

#rpm  -qa  |  grep  zip
zip 패키지가 설치되었으므로 출력된다.

#rpm  -qs  zip
패키지 상태 출력

//////////////////////////////////////////////////////////////////////////
#man  rpm
       -s     패키지 안에 든 화일의 상태를 보여준다.(-l은 포함) 각
              화일의 상태는 normal(정상), not installed(설치 되 지
              않음), replaced 다른 것으로 교체됨)의 값을 갖는다.
//////////////////////////////////////////////////////////////////////////

#rpm  -ql  zip
설치된 특정 패키지의 파일목록 출력
설치가 된 후에는 패키지 목록 출력시 -p 옵션이 필요없고
rpm 확장자를 지정하면 안 된다.

 

 

 

 

 

 

 

 

 

#rpm  -qi  zip
패키지 정보 확인


#zip
사용법 출력됨
#which zip
/usr/bin/zip
#

which : 명령어가 어느 디렉토리에 있는지 경로를 출력

 

 

 

 

 

 


#rpm  -qf  /usr/bin/zip (파일이 속한 패키지 찾기)
zip-2.3-27
#
---> zip 명령이 깨졌을 경우나 삭제된 경우 
zip-2.3-27 패키지를 다시 설치해 주면 된다.
리눅스 CD 에 zip 명령어가 개별적으로 존재하지 않는다.

 

 

 

 

 

 

 

 

♠yum  사용하기
(인터넷의 파일서버를 이용하는 방식)

[리눅스 서버] <----- yum -----> [인터넷의 CentOS 프로그램 서버]

 

 

 

 

#rpm  -qa  |  grep  mc
mc 패키지(프로그램)는 없음

#yum -y install mc (mc 패키지 설치하기)
-y 옵션을 생략하면 질문 나올 때 y 를 입력해 주어야 설치된다.

#rpm  -qa  |  grep  mc
mc  패키지 설치됨

#mc
mc 는 유틸리티 프로그램
종료는 exit 입력

 

 

 

 

 

 

 

#yum info mc
Setting up repositories
Reading repository metadata in from local files
Installed Packages
Name   : mc
Arch   : i386
Epoch  : 1
Version: 4.6.1
Release: 0.8.5
Size   : 4.2 M
Repo   : installed
Summary: User-friendly text console file manager and visual shell.

Description:
 Midnight Commander is a visual shell much like a file manager, only
with many more features. It is a text mode application, but it also
includes mouse support if you are running GPM. Midnight Commander's
best features are its ability to FTP, view tar and zip files, and to
poke into RPMs for specific files.
#

 

 

 

 


#yum  remove  mc
-y 옵션을 지정하지 않았으므로 질문이 출력된다.
(질문에 y 를 입력한다.)
rpm  -e  mc  로  삭제해도 된다.

yum 을 이용하면 의존성 있는 패키지까지 함께 삭제 된다.


#mc
---> X

 

 

 

 

 

 

♠GUI 를 이용한 패키지 관리
1. 메뉴표시줄-프로그램-시스템 설정-응용 프로그램 추가/삭제
   오류가 나는 경우에는 패키지 명령어(rpm, yum)를 이용해야 한다.


2. 메뉴표시줄-프로그램-파일 브라우저 실행
 1) /work 로 이동
 2) zip-2.3-27.i386.rpm 선택후 마우스 오른쪽 버튼 클릭
 3) 메뉴에서 "Install Packages 프로그램으로 열기" 선택
    이미 설치된 경우에는 "설치되어 있다"는 메시지 출력 됨
    또는 왼쪽마우스를 더블 클릭하면 설치된다.
 4) 터미널에서 #rpm -e gftp 한 후
    리눅스 탐색기에서 gftp-2.0.17-6.i386.rpm 설치 테스트 하기

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


<리눅스 프로그램 업그레이드>
☞리눅스 프로그램 업그레이드
rpm 버전은 yum 을 이용하여 업그레이드 할 수 있고
소스버전은 홈페이지에서 다운받아 컴파일 방식으로 
업그레이드 할 수 있다.

 

 

 

 

 

 

 


☞리눅스에서 사용하는 프로그램 형식
1. rpm 버전(hello.exe 상태)
2. 소스 버전(hello.c 상태)

 

[win7]

RPM 패키지 검색 사이트 : http://rpm.pbone.nethttp://www.rpmfind.net

위 사이트에 접속하고
[        ][search]
텍스트 박스에 단어를 입력하고 search 버튼을 누르면 패키지를 검색할 수 있다.


mc 프로그램 홈페이지
http://www.midnight-commander.org

 

 

 

 

 


☞rpm 프로그램(파일명 : mc-4.6.1a-0.9.i386.rpm)
[요리가 다 된 떡볶이]--->프로그램이 들어있는 상자


☞소스 프로그램(파일명 : apache-1.3.2.tar.gz)
[떡볶이 재료-떡,고추장,파 등..]--->프로그램이 들어있는 상자

 

 

 

 

 

 

 

 

 


☞소스 프로그램 설치방법(음식 요리법-레서피)

1) ./configure (환경설정)
---> gcc 같은 컴파일러의 유무, 라이브러리 위치 등 컴파일을 하기위한 
     정보들을 확인해서 Makefile 로 저장을 해 준다.

2) make (컴파일)
---> Makefile 이용해서 gcc 로 컴파일 해 준다.

3) make  install (설치디렉토리로 복사)
---> configure 시 prefix 옵션으로 지정해 준 디렉토리로 
파일들을 복사해 준다. prefix 를 지정하지 않으면 설정파일은 
/usr/local/etc 로 실행파일을 /usr/local/bin 등으로 파일들이 분산된다.
그러므로 prefix 옵션을 주는 것이 좋다.

 

 

 

 

 

<텍스트 ftp 프로그램 명령어>
ftp>help(도움말)
ftp>get(1개 파일 다운)
ftp>mget(여러개 파일 다운)
ftp>put(1개 파일 업로드)
ftp>mput(여러개 파일 업로드)
ftp>hash(자료전송시 # 마크 설정 on/off)
ftp>prompt(자료전송시 확인 질문 on/off)
ftp>ls(서버쪽 목록 출력)
ftp>!ls(자신의 컴퓨터 목록 출력)
!명령어 : 자신의 컴퓨터에서 명령이 실행됨
ftp>cd(서버쪽 디렉토리 이동)
ftp>lcd(자신의 컴퓨터 디렉토리 이동)
ftp>by(접속 종료) 또는 bye 또는 quit

 

 

 

 

 

 

 

 

 

 

 

☞ftp 명령어를 이용한 파일 전송
#cd  /work
#ftp  172.16.7.252
andylec  로그인

//////////////////////////////////////////////////////////////////////////
로그인 실패시에는 아래와 같이 하면 된다.
1)
ftp>by
#ftp  172.16.7.252

2)
ftp>close
ftp>open  172.16.7.252
다시 로그인
//////////////////////////////////////////////////////////////////////////

 

 

 

 

 

 

ftp>ls (파일 목록 확인)
ftp>cd  UPLOAD (서버쪽 디렉토리 이동)
ftp>pwd (현재 경로 확인)
ftp>ls
ftp>get  파일명
ftp>mget  mc*
질문에 y 나 엔터 입력
ftp 명령어를 실행한 디렉토리에 다운이 된다.
다운로드 : get(파일 1개 다운로드), mget(파일 여러 개 다운로드)
업로드 : put(파일 1개 업로드), mput(파일 여러 개 업로드)
ftp>by (접속 종료)
#ls

 

 

 

 

 

#tar  zxvf  mc-4.6.1.tar.gz
#ls
#cd  mc-4.6.1
#pwd
(/work/mc-4.6.1)
#ls
#ls  src (---> /work/mc-4.6.1/src 폴더의 내용을 확인하는 것)
확장자  .c  로 된 소스 파일

#./configure  --help
---> 컴파일 옵션 확인

Installation directories:
  --prefix=PREFIX         install architecture-independent files

in PREFIX
                          [/usr/local]
  --exec-prefix=EPREFIX   install architecture-dependent files in

EPREFIX
                          [PREFIX]

By default, `make install' will install all the files in
`/usr/local/bin', `/usr/local/lib' etc.  You can specify
an installation prefix other than `/usr/local' using `--prefix',
for instance `--prefix=$HOME'.

 --enable-charset         Support for charset selection and conversion [no]

 

 

 

 

 

 

 

 


#pwd
(/work/mc-4.6.1)

#./configure  --prefix=/work/mc  --enable-charset
--prefix 는 설치 디렉토리 지정 옵션
--enable-charset 은 한글 지원 설정
#make
#make  install

명령어 라인 한 줄에 입력하려면 && 연산자를 이용하면 된다.
#./configure  --prefix=/work/mc  --enable-charset  &&  make  &&  make  install

#cd  /work/mc
#ls
#/work/mc/bin/mc
#/work/mc/bin/mc  --help
  -a, --stickchars    Use stickchars to draw
#/work/mc/bin/mc  -a

 

A  ;  B  
---> A 명령이 실패해도 B 명령을 실행

A  &&  B
---> A 명령이 실패하면 B 명령을 실행 안 하고
      A  명령이 성공하면 B 명령을 실행



+ Recent posts