Handbook:IA64/Blocks/Disks/ko

From Gentoo Wiki
Jump to: navigation, search
This page is a translated version of the page Handbook:IA64/Blocks/Disks and the translation is 100% complete.


공간 분할

이론적으로는 리눅스 시스템을 전체 디스크에 넣을 수 있지만, 실제론 거의 불가능합니다. 대신 전체 블록 장치를 작게 나누어 더욱 관리하기 쉬운 블록 장치를 만들 수 있습니다. IA64 시스템에서는 파티션이라고 부릅니다.

아이태니엄 시스템에서는 EFI, 확장 펌웨어 인터페이스를 부팅 과정에 사용합니다. EFI에서 인식하는 파티션 테이블 형식은 GPT 또는 GUID 파티션 테이블입니다. GPT를 인식할 수 있는 공간 분할 프로그램은 parted이기 때문에 계속 진행하는 과정에서는 이 도구를 사용하겠습니다. 게다가 EFI는 FAT 파일 시스템만 읽을 수 있어 EFI 부트 파티션에 사용할 형식이 되겠으며 커널은 elilo로 설치하겠습니다.

고급 저장장치

IA64 설치 CD에서는 LVM2를 지원합니다. LVM2에서는 파티션 설정을 통해 유연성을 제공합니다. 설치 과정을 진행하는 동안 일반 파티션을 중점적으로 다루겠지만, 마찬가지로 LVM2를 지원한다는 사실을 알아두시는 것도 유익합니다.

분할 배치 설계

분할 영역을 얼마나 많이, 크게 할까요?

분할 영역의 수는 환경에 따라 다릅니다. 예를 들어, 사용자가 많을 경우 보안성을 개선하고 백업을 쉽게 하기 위해 /home/을 나누는 것이 좋습니다. 젠투를 메일 서버로 설치한다면, /var/에 모든 메일을 저장하므로 /var/를 나누어야 합니다. 파일 시스템의 탁월한 선택은 성능을 극대화합니다. 게임 서버는 게임 서버를 설치할 /opt/를 따로 나눕니다. 이유는 /home/과 비슷합니다: 보안과 백업이죠. 대부분의 상황에서 /usr/는 거대한 상태고 남아있습니다. 주요 프로그램을 저장할 뿐만 아니라, (보통 /usr/portage에 기본으로 들어가는) 젠투 이빌드 저장소는 거의 650MB를 차지합니다. 이 디스크 공간은 보통 이빌드 저장소내에 저장하는 packages/distfiles/ 디렉터리는 제외하고 추산합니다.

관리자 취향에 달려있습니다. 분할 영역 또는 볼륨을 나누면 다음과 같은 장점이 있습니다:

  • 각 분할 영역 또는 볼륨에 대해 최상의 동작을 수행하는 파일 시스템을 선택합니다.
  • 제 기능을 상실한 도구가 분할 영역 또는 볼륨에 계속 파일을 기록할 경우, 남아 있는 공간이 없어져 전체 시스템이 동작하지 않습니다.
  • 필요한 경우, (이 장점은 여러 개의 분할 영역보다는 여러 대의 디스크에서 더 돋보이지만) 동시에 여러 분할 영역을 검사할 수 있어, 파일 시스템 검사 시간을 줄일 수 있습니다.
  • 일부 분할 영역 또는 볼륨을 읽기 전용, nosuid(setuid 무시), noexec(실행 비트 무시) 등으로 마운트하여 보안성을 개선할 수 있습니다.

그러나, 마찬가지로 다중 분할 영역에는 단점도 존재합니다. 제대로 설정하지 않으면 어떤 분할 영역에는 공간이 상당히 남지만, 다른 분할 영역은 그렇지 않을 수 있습니다. 다른 골칫거리는 분할 영역이 나뉘어져 있는 상황입니다. /usr/ 또는 /var/와 같은 중요한 마운트 지점은 특히 그렇습니다. 다른 부팅 스크립트를 시작하기 전에 분할 영역을 마운트하려면 관리자가 종종 initramfs로 부팅해야합니다. 항상 있는 경우는 아니기 때문에 결과가 다양하게 나타납니다.

디스크에서 GPT 레이블을 사용하지 않으면 SCSI와 SATA에서는 분할 영역 갯수가 15개로 제한되어있습니다.

스왑 공간이 무엇인가요?

완벽한 스왑 분할 영역 값은 없습니다. 스왑 영역의 존재 목적은 내부 메모리(RAM)가 용량 고갈에 처해있을 때 커널에서 디스크 공간을 제공하려는 것입니다. 스왑 영역은 커널에서 곧 접근하지 않을 메모리 페이지를 디스크(스왑 또는 페이지-아웃)에 옮기고 메모리를 확보할 수 있도록 합니다. 물론 메모리가 갑자기 필요할 때도 이 페이지를 메모리에 되돌려놓습니다만(페이지-인), 시간이 오래걸립니다(내부 메모리에 비해 디스크는 비교적 매우 느립니다).

시스템이 메모리를 집중적으로 사용하는 프로그램을 실행하려 하지 않거나 시스템에 충분한 메모리가 있을 경우 많은 스왑 영역이 필요하지 않을지도 모릅니다. 그러나 스왑 영역은 최대 절전모드 기능을 사용할 경우 전체 메모리 공간을 사용하기도 합니다. 시스템을 최대 절전모드로 진입하려 한다면, 더 큰 스왑 영역이 필요하며, 최소한, 종종 시스템에 대용량의 메모리를 설치합니다.


비 기본 예제 파티션 형태

(웹서버, 메일서버, 그놈이 들어있는)시범용 랩톱의 20GB 디스크에 대한 예제 파티션을 아래에 보여드리겠습니다.

root #df -h
Filesystem    Type    Size  Used Avail Use% Mounted on
/dev/sda5     ext4    509M  132M  351M  28% /
/dev/sda2     ext4    5.0G  3.0G  1.8G  63% /home
/dev/sda7     ext4    7.9G  6.2G  1.3G  83% /usr
/dev/sda8     ext4   1011M  483M  477M  51% /opt
/dev/sda9     ext4    2.0G  607M  1.3G  32% /var
/dev/sda1     ext2     51M   17M   31M  36% /boot
/dev/sda6     swap    516M   12M  504M   2% <not mounted>
(Unpartitioned space for future usage: 2 GB)

/usr/는 여기서 꽉 차있습니다(83% 사용)만, /usr/이 이만큼 사용량이 늘어나도록 의도하지 않았음에도 불구 모든 프로그램을 설치했을 때 입니다. /var/ 사용 용량을 초과하는데 대비해 수 기가바이트 용량의 디스크 공간을 할당했지만 포티지에서 기본적으로 이 파티션을 꾸러미 컴파일에 사용함을 기억하십시오. /var/를 1GB 정도의 타당한 공간으로 유지하려면, /etc/portage/make.conf 의 PORTAGE_TMPDIR 변수 값을 바꿔 리브레오피스 같은 상당히 큰 꾸러미를 컴파일하는데 필요한 충분한 용량을 지닌 파티션을 가리키도록 하십시오.

디스크 공간 분할에 parted 사용

다음 부분에서는 나머지 설치 과정에서 분명히 사용할 파티션 배치 예제를 만드는 방법을 설명합니다:

파티션 설명
/dev/sda1 EFI 부트 파티션
/dev/sda2 스왑 파티션
/dev/sda3 루트 파티션

개인 취향에 따라 파티션 배치를 바꾸십시오.

현재 파티션 배치 보기

parted는 GNU 파티션 편집기입니다. 디스크에서 parted를 실행하십시오(예제에서는 /dev/sda를 사용합니다):

root #parted /dev/sda

parted를 실행하면 프롬프트는 다음과 같이 나타납니다:

(parted)

현재 사용할 수 있는 명령은 다른 사용할 수 있는 명령이 무엇인지 알아보는 help입니다. 다른 명령은 디스크의 현재 파티션 설정을 표시합니다:

(parted)print
Disk geometry for /dev/sda: 0.000-34732.890 megabytes
Disk label type: gpt
Minor    Start       End     Filesystem  Name                  Flags
1          0.017    203.938  fat32                             boot
2        203.938   4243.468  linux-swap
3       4243.469  34724.281  ext4

부분 설정은 위에서 추천한 방식과 매우 비슷합니다. 두번째 줄에 파티션 테이블 형식이 GPT로 되어 있는 점에 주목하십시오. 이 항목이 다르게 표시된다면 IA64 시스템에서 디스크로 부팅할 수 없습니다. 파티션을 만드는 방법을 설명하고자 우선 파티션을 싹 제거하고 다시 만들겠습니다.

모든 파티션 제거

참고
쓰기 명령을 내리기 전에 바뀐 내용 반영을 미루는 fdisk와 기타 파티션 프로그램과는 달리 parted 명령은 즉시 적용됩니다. 파티션을 추가하고 제거하면 되돌리는 방법은 없습니다.

올바른 파티션 형식을 사용하려고 모든 파티션을 제거하고 깨끗하게 시작하는 쉬운 방법은 mklabel 명령을 사용하여 새 파티션 테이블을 사용하는 것입니다. 명령의 결과로 빈 GPT 파티션 테이블을 만듭니다.

(parted) mklabelgpt
(parted) mklabelprint
Disk geometry for /dev/sda: 0.000-34732.890 megabytes
Disk label type: gpt
Minor    Start       End     Filesystem  Name                  Flags

이제 파티션 테이블을 비웠고 파티션을 만들 준비가 끝났습니다. 위에서 이야기한 대로 기본 파티션 형태를 사용하겠습니다. 물론 문자 그대로 따라오시지 말고 개인 취향에 따라 적절히 조절하세요.

EFI 부트 파티션 만들기

우선 작은 EFI 부트 파티션을 만드십시오. IA64 펌웨어에서 읽을 수 있게 FAT 파일 시스템으로 해야 합니다. 예제에서는 커널과 elilo 설정을 저장하기 딱 맞도록 32MB로 만듭니다. 각 IA64 커널은 5MB 안팎정도 차지하므로 이 설정은 공간을 늘릴 경우를 대비해 내버려두겠습니다.

(parted)mkpart primary fat32 0 32
(parted)print
Disk geometry for /dev/sda: 0.000-34732.890 megabytes
Disk label type: gpt
Minor    Start       End     Filesystem  Name                  Flags
1          0.017     32.000  fat32

스왑 파티션 만들기

이제 스왑 파티션을 만들겠습니다. 보통 스왑 파티션을 만들 크기는 시스템에 장착한 RAM 용량의 두배입니다. 최근 RAM 용량을 크게 잡은 시스템에서는 더이상 피료하지 않습니다. 대부분의 데스크톱 시스템에서는 512MB 스왑 파티션으로도 충분합니다. 서버에서는 서버에서 바라는 만큼 큰 용량을 고려하십시오.

(parted)mkpart primary linux-swap 32 544
(parted)print
Disk geometry for /dev/sda: 0.000-34732.890 megabytes
Disk label type: gpt
Minor    Start       End     Filesystem  Name                  Flags
1          0.017     32.000  fat32
2         32.000    544.000

루트 파티션 만들기

마지막으로 루트 파티션을 만들겠습니다. 우리가 계획한 설정에서는 나머지 디스크 용량을 잡아서 루트 파티션을 만듭니다. 기본적으로 ext4를 쓰지만 ext2, jfs, reiserfs, xfs 그 어느것이든 써도 됩니다. 실제 파일 시스템은 이 단계에서 만들지 않지만 파티션 테이블에 어떤 종류의 파일 시스템을 각 파티션에 실어놓을지 표시합니다. 따라서 의도대로 테이블의 내용을 일치하게 하는 것이 좋습니다.

(parted)mkpart primary ext4 544 34732.890
(parted)print
Disk geometry for /dev/sda: 0.000-34732.890 megabytes
Disk label type: gpt
Minor    Start       End     Filesystem  Name                  Flags
1          0.017     32.000  fat32
2         32.000    544.000
3        544.000  34732.874

parted 나가기

parted를 끝내려면 quit를 입력하십시오. parted가 모든 사항을 이미 저장했으므로 파티션 배치를 저장할 별도의 과정은 필요하지 않습니다. parted에서는 나중의 설치 과정에서 처리할 /etc/fstab 파일을 업데이트하라고 알려줍니다.

(parted)quit
Information: Don't forget to update /etc/fstab, if necessary.