IRC에서 사람들이랑 대화하던 중, 어느 분이 zfs가 뭐냐고 물어보셨다. 컴퓨터를 전공했거나 IT 분야에서 근무하시는 분이 아니었기에 조금 쉬운 설명이 필요했고 당연히 있을 거라고 생각했다. 그래서 금방 인터넷 페이지 링크 하나 드린다고 잠시만 기다리시라고 했는데 찾을 수가 없었다.

내가 찾아본 zfs의 설명을 잠시 보자.
1. ZFS는 간편한 관리성, 트랜젝션 기반의 구문, 완벽한 데이타 무결성 보장, 대용량의 확장성을 제공하는...
2. 기존의 볼륨과 그에 기반한 파티셔닝, 프로비져닝, 대역폭 낭비의 불편성등의 문제를 완전히 제거했...
2. ZFS는 CPU의 파이프라인 개념과 비슷한 I/O 파이프라인 엔진을 가지고 있...
4. 바로 정정이 가능하더라도 모든 데이타를 다시 읽어 들여서 잠재적인 오류를 찾아내게 된...

위의 설명으로 이해시키기엔 도저히 불가능했다. 솔직히 내가 봐도 무슨 말인지 잘 모르겠다. 그래서 리눅스/유닉스에는 관심은 좀 있는데 뭔지는 잘 모르는 그런 분들을 위해서 한 번 설명해보고자 한다. 내 블로그에는 zfs에 대한 찬양에 가까운 내용이 많다보니 이게 뭔지 짚고넘어가야할 것 같았다. 미리 말씀드리지만 사실 나도 잘은 모른다.

먼저 zfs는 Zettabyte File System의 약자이다. 앞의 제타바이트는 도대체 얼마나 클까.
순서는 KB (킬로바이트) - MB (메가바이트) - GB (기가바이트) - TB (테라바이트) - PB (페타바이트) - EB (엑사바이트) - ZB (제타바이트) 이다. 그래도 아직 실감이 안오실 거다.
1,000 기가는 1테라이다. 1,000테라는 1 페타이다. 1,000 페타는 1 엑사이고, 1,000 엑사는 1 제타이다.
이제 실감이 가실 거다. 이 정도 사이즈를 다룰 수 있는 파일시스템이다.

일단 zfs는 포맷이 필요없다. 하드디스크를 연결하고 명령어만 치면 즉시 사용이 가능하다. 요즘에야 파일시스템이 다들 좋아져서 1테라바이트 하드 포맷하는데 몇 분도 채 안걸리지만, zfs는 그나마 그 몇 분의 시간조차도 필요가 없다. 게다가 맘대로 여기저기 뗏다붙였다 할 수 있다.

zfs는 기존의 전통적인 유닉스의 파티션, 즉 /home, /var, /etc 등의 디렉토리별로 나눠서 파티션을 나누는 보통방법과 완전히 다른 새로운 개념의 파일시스템이다. 기존의 파일시스템은 파티션을 나누면 공간을 늘였다줄였다하는 것이 불가능하다. 따라서 운영체제를 설치하기 전에 /var나 /usr 등의 용량계획을 잘 세워서 파티션을 나눠야만 했다. 그렇게 나누는 것이 장애시 복구도 편하고 여러모로 이점이 있기 때문인데, 최근 개인유저들 사이에서는 그냥 / 와 swap 이렇게 달랑 2개만 나누는 것으로 굳어지기도 했다.

그런데 이 zfs는 디렉토리를 따로 나눠줄 필요가 없어졌다. 솔라리스 설치시 그냥 하나의 파티션만 존재하고 그 안에서 zfs가 알아서 관리하는 식인데, 디렉토리를 나눠서 따로 용량을 주는 것도 가능하다는 거다. 또한 RAID를 자체적으로 구현한다. 무슨 말인고 하니, 똑같은 하드디스크를 두 개를 붙여놓고 하나만 쓰되(A), 나머지 하나(B)는 언제나 A와 똑같은 하드디스크를 만들어라는 기능, 다시 말해 미러링이 가능하고 그외 나머지 RAID 의 대부분을 사용할 수 있다. 또한 더 이상 하드디스크에 에러가 나는 일이 없으며 실시간으로 파일시스템을 점검한다. 에러가 생기면 실시간으로 치유가 된다. 뭐 이건 별거 아닌 거 같으니까 다른 얘길 해보자.

내가 반해버린 zfs의 큰 기능은 바로 스냅샷이라는 증분백업이다. 다들 맥의 타임머신이 뭔지는 알면서 증분백업이 무슨 말인지 모르는 분들이 많다. 증분백업이란, 예를 들어서 현재 내 하드디스크에 총 60기가의 데이터가 있다고 가정하자. 처음으로 백업을 하면 일단은 60기가 데이터 모두 외장하드로 백업을 한다. 그리고 다음 날 2기가 정도의 영화파일을 새로 받았고 백업프로그램을 돌리면, 60+2=62기가를 백업하는 게 아니라, 변동된 2기가만 백업을 하는 거다. 이게 바로 증분백업이다.

그런데 zfs의 스냅샷은, 외장하드로 따로 옮기는 백업이 아니라 현재 하드디스크의 상태를 사진찍듯이 이미지를 뜬다. 이미지를 뜬다는 말이 참 설명하기 어려운데, 하드디스크의 데이터를 한 눈에 보이게 펼쳐놓고 위에서 아래로 내려다보면서 카메라로 사진(스냅샷)을 찍는다고 생각하자. 일단 운영체제 설치하고 첫 사진을 찍는다. 60기가짜리 파일이 찍힌 사진이 하나 생겼다. A 사진이라고 하자.
이제 이것저것 다운로드도 하고 프로그램도 설치한다. 3기가의 추가데이터가 생겼다. 이번에는 63기가짜리 데이터가 담긴 하드디스크의 사진을 찍는다. B 사진이라고 하자.
어느 날 갑자기 바이러스인지 뭔지 들어와서 컴퓨터를 완전 헤집고 다녀서 아무래도 더 이상 사용이 안될 것 같다. 그러면, 가장 최근의 사진인 B 사진을 하드디스크 위에 그대로 덮어주기만 하면 B 사진을 찍을 때 당시의 하드디스크로 되돌아간다.

이런 류의 프로그램은 사실 윈도우에도 있고 맥의 타임머신도 비슷한 역할을 한다. 그런데 이 zfs는 스냅샷을 찍는 과정이 불과 1초도 안걸린다. 복원은 다소 시간이 걸리지만 노턴 류의 프로그램 마냥 한두시간씩 기다리는 수준이 아니라 길어봐야 1분 정도다. 하드디스크 안에 몇기가의 데이터가 있는지는 전혀 상관이 없다. 1초에서 1분 이내다. 게다가 사진의 갯수는 무한대다.

사실 내가 솔라리스에 반한 이유는 이게 제일 크다고 볼 수 있겠다. 순간 백업과 순간 복원. 그리고 백업시점 무한대. 그런데 단순히 이게 다는 아니다.
보통 PHP-MySQL 작업을 하다보면 실수로 디비를 덮어써버린다거나 디비를 날려먹는 일이 종종 있다. 특히 큰 서버거나 서비스 중인 서버에서 그랬으면 정말 대형사고다. 그런데 zfs를 이용해서 수시로 스냅샷을 찍어버리면 별로 걱정을 안해도 된다는 거다. 게다가 스냅샷 갯수도 무한대이니 대략 3개월치를 계속 스냅샷을 찍어대면 무려 3개월 동안의 어떠한 상황으로도 돌아갈 수 있다는 거다. 더 응용해보자면 홈디렉토리의 각 사용자별로 스냅샷을 찍어주면, 예를 들어 어떤 한 사용자의 요청으로 인해 시스템 전체가 옛날로 되돌릴 수는 없으니 사용자별로 스냅샷을 찍어주면 해당사용자만 과거로 돌아갈 수 있어서 환상적인 서버운영이 가능하단 거다. 물론 이 경우는 사용자가 많으면 스냅샷 관리하기가 어렵다. 

더 응용해보자.
솔라리스에는 Zone이라고 하는 가상화 솔루션이있다. 이게 뭐냐면, 다들 vmware가 뭔지 아실 거다. 컴퓨터를 가상으로 만들어주는 프로그램인데, vmware처럼 윈도우에서 마우스 클릭해가면서 하는 프로그램만 있는 게 아니라, 솔라리스처럼 깜깜한 화면에 글씨만 주르륵 타이핑하는 그런 컴퓨터에도 가상화 프로그램이 있다.
대부분 솔라리스를 운영하는 서버는, 해커/크래커의 공격에 대비해 웹서버는 가상으로 만들어서 운영한다. 그래서 크래커가 웹서버를 쑥대밭을 만들고 가더라도 가상서버만 날려버리면 본체는 아무런 걱정이 없다. 그런데 문제는, 이 가상서버를 다시 설치해야하고 그 안에 있던 데이터까지 날려먹으니까 골치아프지. 그래서 이 가상서버들도 스냅샷을 찍어대면 크래커가 와서 가상서버 다 박살내도 1초만에 복구시켜버리면 되는 거다. 완전 크래킹 의지를 상실하게 만들어버리는 거다. 이게 바로 zfs의 진정한 사용이 아닌가 싶다.

서버급 규모에서는 단순히 스냅샷 말고도 여러가지 데이터 처리/보관에 대한 기능이 많다. 그런데 아무래도 집에서만 쓰다보니 그런 걸 해볼 일도 없거니와 별 필요도 없다. 그럼에도 불구하고 스냅샷/롤백 이거만으로도 정말 뿅~가게 만드는 환상적인 파일시스템인 것이다.

솔라리스. 어쩌면 너에게 반한 게 아니라 zfs에 반한 걸지도 모르겠다.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
요즘 하루도 빼놓지 않고 오픈솔라리스 커뮤니티(http://opensolaris.org/jive/forum.jspa?forumID=13)를 들락날락 거린다. 일단 2010.06 버전이 언제 나오는지가 궁금하기도 하거니와 향후 오픈솔라리스의 진로가 어떻게 될 것인지 무척이나 궁금하기 때문이다.

그게 뭐가 그리 궁금하냐면, 내 생각에 취업을 위해서라면 IBM의 AIX 내지는 솔라리스를 다룰 줄 알아야할 것 같은데, 둘 중 뭘 해야할지 아직 결정을 못내렸기 때문이다. 둘 다 하면 되지 않느냐 라고 생각이 들곤 하는데, 일단은 한 우물만 파는 것이 좋다고 생각하기 때문이다. 게다가 AIX는 서버도 따로 구매를 해야하기 때문에, 일단 Intel 시스템에 쉽게 설치되는 솔라리스와는 추가적인 비용이 들어간다. 그런데 왜 리눅스가 아니라 유닉스일까...
일단 내 생각이긴 한데, 리눅스는 엄청나게 많은 사람들이 공부하고 있고 굳이 전산전공이 아니더라도 컴퓨터에 조금이라도 관심이 있는 사람들은 다 한 번씩 깔아서 써봤을 정도이기 때문에, 어차피 리눅스는 기본으로 적당한 수준에서 다룰 줄 아는 정도라면 남들과 조금은 차별화된 기술이 있어야하지 않을까 하는 게 내 생각이다.

한국에서 일하는 아는 동생 말로는 AIX는 IBM 관련업체에서 일할 거 아니면 비추라고 하는데, 미국에서 IBM의 입지는 초강력 IT기업이기 때문에 그 파워를 무시할 수가 없는 수준이다. 일단 시장점유율은 뭐가 더 우세하다고 할 수 없는 수준이지만 일단 확실한 점은, IBM은 오픈소스 진영의 강력한 후원자로서 AIX 말고도 서버업체에서는 최고의 위치에 있는 회사지만 그렇다고 HP나 Sun에서 리눅스 서버를 안하는 건 아니라는 거다. 그래서 결론은, 뭘 해야할지 여전히 모르겠단 거다.

일단은 솔라리스에 더 땡기고 있다. AIX는 아직 안써봐서 모르겠지만 리눅스가 아닌 Unix는 뭘 해도 불편할 거라는 건 안봐도 알 것 같다. 솔직히 오픈솔라리스를 노트북에 설치해서 쓸 때만 해도, 깔려있는 걸 쓸 때는 불편한 걸 모르지만, 뭔가를 새로 설치하려고 하는데 만약 솔라리스에 그런 패키지가 없으면 아주 답답하다. 소스 컴파일로 설치하면 되겠지만 소스 컴파일이 잘 안된다. 대부분의 오픈소스 쪽은 gcc로 컴파일을 해야하는데, 그 과정에서 없는 라이브러리들이 무쟈게 많다. 이것도 이래 불편한데, AIX는 더 불편하겠지.

일단은, 솔라리스는 내가 이전 포스팅(http://jswlinux.tistory.com/tag/오픈솔라리스)에도 몇 번이나 강조했지만, zfs와 zone 이것만으로도 이미 결론은 났다고 볼 정도다. 그래서 솔라리스에 좀 더 땡기는 거다. 그런데 이노무 솔라리스가 오라클 땜시 결론이 안나니...

현재 우리 집에서 쓰는 컴퓨터를 비롯해서 일하는 가게에서 쓰는 서버&PC까지, 리눅스는 단 한 대도 없다. 미안하다 리눅스. 집에서 쓰는 컴은 아이맥 20"이고, 서버는 오픈솔라리스 2009.06. 일하는 가게 역시 내 전용 컴은 아이맥 24", 서버는 오픈솔라리스 2009.06이다. 최근 두 달 사이 실수로 엄청난 데이터를 날려먹으면서 맥의 타임머신 같은 증분백업툴이 필요한데 리눅스에는 그런 게 없는 것 같고, 그렇다고 3개월 4개월씩 하드 전체를 백업하기엔 용량이 무쟈게 딸린다.

며칠 전, 토렌트에서 뭘 좀 다운받아야할 일이 생겨서 오픈솔라리스 패키지를 뒤져보니까 그나마 좀 익숙한 rtorrent가 없다. BitTorrent가 있긴 한데 사용법이 좀 생소한 건 둘째치고서라도, 맥의 uTorrent에서 정상적으로 받아지는 파일이 BitTorrent에서 안받아지는 이상한 현상이 생기는 거다. 그래서 테스트를 좀 해보고자 rTorrent의 소스를 다운받아서 컴파일을 하려고 하는데 이게 또 컴파일이 안되는 거다. 내가 아는 지식을 총 동원해서 라이브러리 패스 지정해주고 별짓 다 해봤는데 일단 컴파일이 안된다. 뿐만 아니라 숙제할 때 가끔 필요한 콘솔형 계산기인 Mathomatic 역시 컴파일이 안된다. 역시 솔라리스가 기업에서 쓸 서버로서는 정말 좋지만 (회사에서 토렌트로 다운받을 일은 없을테니) 나처럼 개인이 집에서 가정용 서버로 쓰기에는 무척이나 불편하다는 사실을 깨닫게 됐다. 순간 마음이 흔들려서 그냥 원래 쓰던 리눅스로 다시 밀어버릴까도 생각해봤지만, 다시 밀어버리면 솔라리스 공부하는데 지장이 생길 것 같기도 하고 기왕 마음 먹은 거, 작심삼일은 가야하지 않나 싶어 일단 어떻게든 써보기로 했다.

그 와중에 Nexenta라는 또 다른 오픈솔라리스의 배포판을 알게됐다. 사용기나 설치후기 내지는 뭔가 정보가 있을까 싶어서 한국 사이트를 구글링 해봤는데 전혀 없다. 전~~~혀 없다. 아예 없다. 한 개도 없다. 대체 IT 강국 대한민국은 리눅스 아니면 아예 관심조차 없는 것인가.

따라서, 본 포스팅이 한국 최초의 Nexenta 사용후기가 아닐까 싶다 (말만 거창하다). 설치과정은 http://www.nexenta.org/projects/site/wiki/GettingStarted 에서 보고 따라하면 되겠다. 설치는 리눅스 설치를 안해봤더라도 상당히 쉬운 편이다. 지역시간대 설정하고 root 비번, 일반사용자 비번 정해주고 dhcp와 ip6만 Yes/No 결정만 하면 그게 끝이다. 참고로 저 사이트의 스샷과는 달리 Nexenta의 최신버전은 X-Windows가 포함되어있지 않다.

Nexenta에 대해 간략히 소개해본다.
1. 오픈솔라리스 기반
2. ZFS deduplication 지원 (deduplication을 뭐라고 해석해야할지 모르겠다)
3. Crossbow (네트워크 레이어 가상화 기능) 지원
4. 13,000 여개의 패키지
5. 우분투 8.04 저장소 기반의 패키지 구성
6. 최신 dpkg, apt, gcc, binutils, coreutils, perl, python, ruby, qt libs, gtk libs 등 포함
7. 아파치, PHP, MySQL, PostgreSQL, exim4 등의 서버 어플리케이션을 위한 Service Management Facility 지원
8. 데비안과 100% 똑같은 환경, 쉬운 업그레이드, 쉬운 설치.
9. Vim, Screen 기본 포함
10. apt-clone 포함 
(zfs와 통합된 새로운 툴로서, apt-get dist-upgrade나 기타 패키지 업데이트시 새로운 BE를 만들고 이에 대해 스냅샷을 찍는 유틸리티. 즉 업데이트 이후 뭔가 잘못되면 다시 되돌아갈 수 있다.)

그야말로 대부분의 리눅스 유저들이 딱 찾는 OS가 아닐까 싶다. 솔라리스만의 강력함, 그리고 익숙한 데비안 환경. 우분투와 거의 비슷한 수의 패키지는 그야말로 내가 원하던 배포판이었던 것이다. 외국쪽 인터넷 신문기사를 좀 뒤져보니까, 넥센타 출시 이후 몇몇 상용유닉스 업체에서 조금 긴장모드에 돌입했다고 한다. 그만큼 솔라리스와 데비안의 결합은 강력하다는 것이다. 일단 vmware에 설치를 했고 사용을 좀 해봤다.

먼저, Stable 버전인 NCP2를 설치해봤는데 이게 apt-get dist-upgrade하니까 작동이 안되는 거다. 그래서 좀 알아보니까 NCP2 버전에는 저게 좀 문제란다. 그래서 NCP3 Unstable 버전을 깔아서 쓰란다. 그래서 NCP3 Unstable 버전을 설치했다.

설치는 위에 설명한대로 몇 가지 엔터만 눌러주니까 완료됐다. 오픈솔라리스와의 구성에서 조금 차이가 있다면, zfs list하면 다소 적절히 용도에 맞게 나눠져있는 것이 넥센타에는 전혀 나뉘어져있지 않다. 달랑 통짜 하나만 되어있다. 나중에 홈디렉토리 정도는 따로 나눠줘야할 것 같다.
그외 dpkg, apt-get 등은 데비안과 완전 같았다.

디렉토리 구조는 오픈솔라리스의 구조를 따르지만 설정파일의 형태, 예를 들면 아파치 서버 설정파일이나 bashrc 등은 데비안과 완전히 같았다. 따라서 아파치 모듈의 경우, /etc/apache2/mods-enable/ 안에 링크만 걸어줌으로서 모듈을 키고 끄는 것이 가능했다. 다만 특이한 점은, 넥센타에 대해서 간략히 알아보기 부분의 7번 사항, SMF의 지원으로 인해 /etc/init.d/apache2 와 svcadm에서 enable 시키는 것이 둘다 똑같이 작동되는 재밌는 현상이 발견됐다. 따라서 일관성을 유지하기 위해서는 관리자가 어느 하나를 선택해서 사용해야할 것 같다. 그외 mysql을 설치할 때는 우분투처럼 설치 중간에 MySQL root의 패스워드를 입력하라는 화면도 나왔었다. 한 가지 아쉬운 점도 있는데 pfexec 명령어가 안먹힌다는 거다. /etc/user_attr파일에 분명 roles=root를 줬는데도 안되는 거다. 보니까 sudoer에 일반계정이 하나 등록되어있는 걸 보니 데비안처럼 sudo를 쓰라는 거 같은데 개인적으로 pfexec 기능이 무척 신선해서 그게 좋았었다.

다만 X-Windows 데스크탑 지원에 있어서는 아쉬운 것이 많았는데, 일단 ubuntu-desktop이라는 패키지가 없어서 우분투 데스크탑의 그놈 환경을 구성하려면 패키지를 일일히 알아보고 설치해야한다는 단점이 있었고, 또한 단순히 apt-get install xorg gdm 으로 설치시에는 마우스가 전혀 작동하질 않았는데다 로그인을 하더라도 데스크탑 매니져 역시 아무 것도 로딩되질 않았다.
이에 대해서 넥센타 포럼은 데스크탑 환경의 넥센타는 StormOS라는 것을 사용하길 권장하고 있다.

일단 mathomatic이라는 계산기는 소스를 다운받아서 컴파일을 해봤지만 되진 않았다. 왜 안되는지는 내가 프로그래머는 아니니까 아무리 웹서핑하고 연구해봐도 도저히 모르겠다. 다만 apt-get으로 설치할 수 있는 패키지의 수가 데비안/우분투와 거의 비슷한 수준이니까 아마 없는 건 없겠지만서도 그 많은 패키지 중에서 내가 필요한 몇 개가 없는 것도 조금 아쉽긴 하다.
다만, 그럼에도 불구하고, apt-get으로 쉽게 설치할 수 있는 13,000여개나 되는 엄청난 양의 패키지 지원과 우분투 식의 쉬운 설정파일은 아무래도 지금 설치해놓은 오픈솔라리스를 뒤엎고 넥센타로 갈아타야겠다는 생각을 하게 만들어버린다.

다만 외국포럼 쪽에서의 사용후기나 경험담을 보면, 오픈솔라리스로 중대형 서버를 구축해서 테스팅을 해보면 안정성 있고 신뢰감이 있게 돌아가는데 넥센타는 중형급 이상의 서버에서는 조금 불안정하다고 한다. 즉, 나처럼 집에서 가정용으로 쓰기엔 적합하다는 거다. 일단 넥센타가 나온지 그리 오래되지 않았으니 (첫버전 2008년 6월) 안정성을 갖추면 솔라리스와 리눅스 시장 둘 다 잡을 수 있을만큼 충분한 가능성이 있지 않을까 싶다.

오늘이나 내일 갈아탄다. ㅎㅎ


결론:
갈아타봤다. 그런데 못쓰겠다. ㅎㅎ
먼저 기본적인 세팅은 문제가 없는데, 웹서버를 위한 zone을 설치하고 zone 안에서 APM을 설치하는데 무슨 에러가 그리 많이 나는지, 설치도 안될 뿐더러 이상한 에러도 많다. 못쓰겠다.
문득 젠투-솔라리스 패키지가 생각났는데, 차라리 그게 나을 거 같다.
그걸 해보고 다시 소감문을 올려드린다.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
리눅스를 접한지도 벌써 14년이라는 세월이 흘렀다. 내 블로그에 누차 설명했지만 슬랙웨어 2.2를 처음으로 리눅스를 접했는데 어떻게 보면 운명이라고 할 수 있을 정도로 내 PC에 설치가 잘됐었다. 그때당시는 설치조차도 어려울 정도였고 심지어는 하드웨어 때문에 X-Windows를 못띄우는 사람이 한 둘이 아니었다. 다시 말하면, X-Windows까지 띄워서 쓰는 사람이 별로 없었단 거다. 그런데 내 PC는 운좋게 아무런 삽질도 하지 않고 모든 것이 일사천리로 진행됐었다. 그때 처음으로 용산에서 나한테 컴퓨터를 팔아준 아저씨가 고마웠다 (95년도쯤이었는데, 무려 220만원이나 주고 샀다).

다들 그렇겠지만, 나도 역시 처음에 리눅스를 설치하고는 명령어 몇 개 쳐보다 "내가 이걸로 뭘 할 수 있을까"하는 생각에 바로 지워버리곤 했다. 그걸 몇 번이나 되풀이했다. 그도 그럴 것이 사실 나는 프로그래밍을 할 줄 몰랐고 그 쪽에는 관심도 없었기 때문이다. 게다가 그 때 당시의 리눅스는 X-Windows 띄워도 할 게 없었다. 그야말로 텅빈 화면에 터미널 하나 띄워져있는 정도의 수준이었던 거다. 그러다가 우연히 천리안 리눅스 동호회에 가입을 했고, 질문/답변 게시판에서 내가 설치하면서 겪었던 경험을 토대로 답변을 몇 번 해주다보니 꽤 유명한 사람이 되어있었던 거다 (나만의 착각일까). 그래서 천리안 리눅스 동호회에서 한 2-3년간 운영진을 했고 어린 나이임에도 그때 당시 많은 분들이 리눅스를 거의 모르던 시절에 공개세미나도 참여했었다. 그때당시 쓰였던 교재의 서두를 집필했는데, 이게 아직도 KLDP에 보관되어있다 (http://wiki.kldp.org/KoreanDoc/Begin-KLDP). 그때는 "선이"라는 닉네임을 썼는데 이게 나중에 "서니"라는 닉네임으로 바뀐 거다. 그런데 그때 교재를 편집하던 분이 내 실명이 진짜 "선이"인줄 알고 그렇게 넣어버렸다. ㅎㅎㅎ

매번 리눅스 관련 블로그를 포스팅할 때마다 이놈의 과거얘기는 맨날 하는 것 같다.
리눅스 동호회 활동을 하면서부터 M$타도 리눅스 찬양을 외치는 맹신도, 요즘말로 리눅스 빠돌이가 되었다. 무조건 윈도그(Windog)는 나쁜 운영체제고 리눅스만이 우리의 구세주며 이 시대를 바로잡을 수 있는 운영체제라고 굳게 믿어가며 리눅스에 매진했었다. 마치 마르크스 주의에서 말하는 선동세력에서 열정만 있고 지식은 없는, 가장 무모하고 선동 초기에 가장 유용한 계급으로 분류되는 그런 회원 중 하나였다고 생각된다. 그때 쌓은 리눅스 내공이 지금까지 이어져오는 걸 보면, 그때 참 많이 하긴 많이 했었다.

군대를 갔다왔고 제대하고 나니까 리눅스의 붐이 일고있었던 시기였다. 지금은 없어진 한컴리눅스 사에서 나온 리눅스를 필두로 수많은 국내 배포판들이 국내 리눅스 시장에서 선전하고 있었고, 내가 천리안 리눅스 동호회에서 활동할 시절 그러니까 대한민국 리눅스 1세대들은 이미 쟁쟁한 기업 혹은 직접 서버 시장에 뛰어들어 사업을 하고있었던 거다. 성공한 분들도 몇 있고, 연락이 안되는 분들도 몇 있다. 연락이 안되는 분들은 좋은데 취직해서 일하느라 바쁜 걸로 생각하고 있다.
암튼, 그때까지도 리눅스가 최고였고 사실상 나의 리눅스 내공은 군 제대 후부터 새마을금고 입사 전까지 쌓은 것이 최고로 많고 가장 값진 때였다. 그때 젠투, LFS 등등 고난도의 배포판들을 두루 섭렵했고 내가 꼬셔서 젠투를 쓰게 한 Badung이라는 닉네임을 쓰는 유저는 내 덕분에 젠투를 쓰게됐다고 얘기한다.

하루는 절친한 친구한테 리눅스를 권했다. 그 친구 성격이라면 M$에 노예가 된 우리의 처지를 깨닫고 자유를 위해 OS를 스스로 고쳐나가는 매트릭스의 네오와 같은 친구일거라 생각했기 때문이었다. 그런데 결론은 정 반대였다.
그때당시 잘나가던 한컴리눅스 3.0인가를 설치해줬는데 하는 말이, "이게 뭐야. 화면도 안예쁘고, 그래픽도 별로고, MSN 메신저도 잘 안되잖아" 였다. 그래서 그 친구는 리눅스 화면을 본지 2분만에 지워버렸다. 그러면서 리눅스가 결코 M$를 따라잡는 일은 없을 것 같다라는 얘길 했다. 그에 발끈한 나는, 그래. 10년만 두고보자. 하고 말했지만, 그 친구는 10년이 지나도 여전할 것 같다고 얘길 했다. 그리고 여전하다.

새마을금고에 취직한 이후 젠투를 유지보수하는데에 들일 시간이 거의 없었던 나는, 리눅스를 접한 이래 처음으로 내 컴퓨터에서 리눅스를 지워버렸다. 그리고 3년 여의 직장생활을 했다. 그 와중에서도 나는 오픈소스를 쓰고자 내가 일하는 지점의 직원들 PC에 오픈오피스를 정식으로 도입하고자 새마을금고 연합회 전산정보부와 접촉을 했다. 허가를 받았고 우리 지점만 쓰게됐다. 그리고 유학을 왔다.

미국에 와서 꽤 많은 수의 Macintosh를 봤다. 많이 쓴다. 태어나서 맥이라는 물건은 처음 봤다. 관심도 없었거니와 응용프로그램이 얼마 없는 리눅스와 같은 소수만이 쓰는 OS라고 생각했다. 알아봤더니 Unix 기반이란다. 그게 너무나도 갖고싶었다. 이젠 사고싶어서 돌아가실 지경이 됐다. 그래서 20인치짜리 아이맥으로 한 대 구입을 했다. 써보고 대략 1주일만에 이런 평가를 내렸다.

"내가 리눅스를 쓰면서 간절히 원했던 모든 것이 구현되어있는 운영체제다."

유닉스 기반, 아름다운 화면, 누구나 사용하기 쉬운 인터페이스, 윈도우만큼은 아니지만 꽤 많은 양의 정식출시된 게임들. 리눅스는 점점 잊어갔다. 맥이 Unix 기반이기 때문에 아파치, MySQL 등등 리눅스에서 운영할 수 있는 서버 모두 운영이 가능했고 심지어는 GNU 툴과 gcc 등의 개발환경까지 모두 갖췄기 때문에 일단 터미널을 열면 리눅스를 쓰는 것과 거의 같은 느낌을 줬다. 게다가 BSD Port까지 있어서 굳이 수고스럽게 컴파일 방법을 찾지 않아도 됐었다. 더군다나 수많은 양의 무료 소프트웨어들이 널리고 널렸다 (대부분의 비-Mac유저들은 모르는 사실이다).

맥은 정말 최고였다. 지금껏 리눅스 밖에 모르던 리눅스와 함께한 내 인생에서 리눅스는 잊고 오로지 맥만이 진리가 됐다. 앞으로 구입하는 모든 PC는 맥만 구입하노라 하고 결심했을 정도였다. 다만 와이프가 맥을 싫어해서 (즐겨보는 TV 웹사이트가 맥에서는 잘 안나온다) 소니 바이오 한 대를 구입했지만 이 노트북마저도 해킨토시를 깔아볼려고 별짓을 다했다. 결국은 포기하고 해킨토시의 최강자라고 불리우는 델미니9을 사서 해킨을 깔아쓰고있다.

한 가지 웃기는 건, 내가 맥을 쓰는 와중에 한국 우분투 포럼에서 많은 활동을 하게됐다는 점이다. 구형 노트북이 한 대 생겼는데, 여기에 뭘 설치할까 하고 알아보다가 우분투를 쓰게됐고 IRC에서 채팅하는 걸 즐기는 나로서는 IRC에 매일 채팅을 함으로서 사람들과 친해지게 됐다. 그러면서 우분투 포럼에서 조금 활동을 하게됐는데, 우분투 포럼에서 맥 얘기만 해댔다. 어쨌든, 활동을 조금 하게됨으로써 IRC 우분투 채널 방장이 됐고 몇몇 소소한 활동을 하고있다.

이쯤에서 솔라리스가 등장한다. Mac과 역시 마찬가지로 이전에는 본적도 없고 관심도 없었다. 단순히 상용유닉스라는 것만 알았고, 리눅스와 달라서 쓰기 불편하다는 정도의 인식이 있었다. 그런데 어느날 문득 오픈솔라리스 2009.06 버전을 설치해서 쓰게됐는데, 이게 너무나도 환상적인 운영체제인 거다. 맥을 접했을 때는 워낙 들뜬 마음에 사전조사를 엄청나게 많이 했고 맥을 구입하기도 전부터 모든 기능을 다 알아버린 상태여서 감동이 크진 않았는데, 전혀 기대없이 그냥 한 번 깔아본 솔라리스는 지금 내 인생을 바꾸는 중이다.

나는 금융업에 종사한 사람이어서 사실 컴퓨터에 대해서는 잘 모른다는 말을 내세운다. 그도 그럴 것이 내가 프로그래밍을 배운 것도 아니요, 전산학을 전공한 것도 아니기 때문에 뭔가를 깊이있게 아는 것이 없었고 아무 것도 모르면서 마구 떠들어대기가 뭐하기 때문에 IT에 대해서 얘기할 때는 무척이나 조심스럽다. 이런 내가 대체 솔라리스에 대해서 뭘 알기에 환상적이라고 할까.

내가 솔라리스에 반한 건 딱 두 가지다. zfs, zone. DTrace는 아직 못써봤다. 이건 공부를 좀 해봐야할 것 같다.
zfs. 아마도 전세계 OS만드는 회사/사람들이 가장 군침흘리는 FileSystem이 아닐까 싶다. 최고다. 정말 궁극의 FS이고, 앞으로도 zfs 이상의 개념을 갖는 FS가 나올까 싶다. 그래봐야 내가 해본 건 zfs의 기능 중 극히 일부인 스냅샷, 롤백 정도만 해봤지만 불과 그것만으로도 이거 정말 환상적이라는 생각이 들게 만들 정도다. 애플이 zfs를 맥OSX에 도입하려고 하다 중간에 없어졌는데 (법적인 이유 때문에) 정말 한탄스러운 일일 정도다. zfs, 최고다.

zone. 정말 유용하고 강력하다. 다른 상용 유닉스에도 비슷한 기술이 있는데 사실 상용유닉스는 접하기가 어려우니까 결국 가상화기술은 솔라리스의 zone을 처음 만져본 거다. Zone은 커널 수준에서 가상화기능을 제공하는데, 요즘 가상서버로 호스팅을 하는 게 유행인 추세다. 이것에 대한 설명은 웹서핑을 통해 알아보시고, 현재 나는 집에서 운영 중인 서버를 오픈솔라리스로 설치하고 webserver라는 가상zone을 만들어서 서버로 운영하고 있다. 그래서 이 가상zone이 해킹/크래킹 혹은 오류로 인해 망가지더라도 내 솔라리스 서버 자체는 아무 이상이 없는 거다.

제목에 써있는, 말할 수 없는 비밀을 말하기 위해 여지껏 설명해왔다.
지인에게 얻은 AMD Athlon 64 데탑에 오픈솔라리스를 설치해서 쓰다보니 회사에서 내가 쓰는 컴퓨터에 설치된 우분투 9.10과 자꾸만 비교되는 거다. 물론 데스크탑의 멀티미디어 측면에서 봤을 땐 리눅스를 따라갈 유닉스는 맥OSX을 제외하고 없다는 건 진리다. 그런데 회사에서 업무적으로 사용하는 PC에서 문서작성&웹서핑 정도의 OS로는 오픈솔라리스도 크게 문제가 없단 사실이다.

그런데 자꾸만 비교가 되는 부분은, 우분투 데탑을 쓰면서 안정된 느낌을 받지 못한다는 점이다. 뭐랄까... 어떤 어플을 하나 실행하면 조금 쓰다가 죽는 일이 생긴다거나, 어떤 어플이 제대로 작동하지 않는다거나... 다시 말해 리눅스에 대해 신뢰가 가지 않는 증상이 내 마음 속에 나타나기 시작한 거다. 이 증상은 우분투 10.04 LTS가 나오면서 더 심해졌다. 큰 기대를 가지는 Long-Term Support 버전인 10.04는 문제가 좀 있었다. 자세한 설명은 하지않겠다. 해결할 수 있는 문제였지만 결국 이것으로 인해 안정적이지 못하고 결국 리눅스라는 OS에 대한 신뢰가 점차 흔들리기 시작했다. 우분투 10.04의 문제점과는 상관없이, 하루는 내가 실수로 1주일간 엄청난 시간을 투자해서 만든 게 있었다. 모르고 지워버렸는데 이때 zfs만큼 간절한 게 없었다. 내 잘못이지만 나는 이 우분투를 갈아엎고 오픈솔라리스를 데스크탑으로 써야겠다는 생각을 했다. 행동까지 실천에 옮겼는데, 그 PC는 오픈솔라리스가 설치되지 않아서 (커널에서 진행이 더 이상 안된다) 어쩔 수 없이 우분투를 쓰고있따. 

물론 내가 이런 소리하는 게 웃기는 건 안다. 전세계 수많은 서버가 리눅스로 돌아가는데... 리눅스 자체를 신뢰할 수 없다는 게 아니다. 오픈솔라리스를 써오면서 최고의 유닉스 OS라고 생각했던 리눅스에 대한 생각이 오픈솔라리스로 옮겨가고 있는 거라고 생각한다.

이제는 서버를 운영한다면 솔라리스로 할 거다. 이미 집에서 그렇게 하고있고, 일하는 가게에서도 우분투 9.10 뒤엎고 오픈솔라리스 설치했다. 모든 것이 정상적으로 돌아가고 있으며, 12시간마다 한 번씩 zfs 스냅샷을 찍고, 웹서버와 ssh 서버는 가상 zone을 만들어서 운영하고 있다. 아... 모든 것이 perfect하다.

이제는 리눅스 유저들에게 리눅스를 추천하고싶지 않다. 이게 내가 말할 수 없는 비밀이다. 아이러니컬하게도 나는 한국 우분투 포럼의 발전을 위해 도와주고 있지만, 데스크탑이 아니라면 우분투를 추천하고싶지 않다. 오히려 오픈솔라리스를 쓰라고 추천하고싶다. 그런데 내가 이토록 빠져든 오픈솔라리스가 3개월 이내에 망할 것인지 아닐 것인지 운명의 기로에 서있다. 솔직히 말해서 개인적으로 너무나도 슬프다. 뒤늦게 이렇게 뛰어난 유닉스를 알게됐고 이제 자격증까지 공부하고 싶을 정도로 반해버렸는데...

맺음말을 어떻게 써야할지 모르겠다.
맥, 사랑한다. 솔라리스, 정말 반해버렸다. 리눅스, 미안하다...
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
한 4일 써봤나 싶다. 여전히 뭐가 뭔지 모르겠고, 뭔가 잘못되면 재설치해야하나 하는 생각이 든다.
그런데 재밌다!

한 3-4년 전에는 솔라리스가 왠지 다른 세상의 OS인듯 화면도 익숙치 않았고 뭐가 뭔지도 모르겠고, 자료도 없고 해서 쓰기 힘들었는데, 이번에 깔아보니 GNOME은 리눅스나 별반 다를 게 없을 정도로 세련됐고 Compiz까지도 잘 동작했을 정도니 잘 모르는 사람이 보면 리눅스라고 착각할 정도로 잘 만들었단 생각이 들었다.

패키지 매니저라는 게 있어서, 마치 우분투처럼 필요한 패키지를 (비록 많지는 않지만) 쉽게 찾아서 설치할 수 있었고 그외의 메뉴들은 정말 리눅스랑 똑같았다. 노트북에 설치했음에도 불구하고 대부분의 하드웨어가 작동했고 성능도 매우 좋았다.

내 노트북은 Sony Vaio Notebook VGN-NS190J 이고, Intel Core 2 Duo 2.0GHz, 4기가 램, 인텔 센트리노 무선랜, Marvell Yukon LAN, 인텔 내장사운드 정도 되겠다. 여기서 사운드는 드라이버가 설치됐음에도 불구하고 소리가 나오질 않았는데, 어차피 솔라리스에서 음악들을 일은 없으니 개의치 않았다. 다만 Marvell의 Yukon 기가비트 이더넷 랜카드가 잡히지 않았는데, 이건 해당 홈페이지가서 드라이버를 다운로드했고 아주 쉽게 설치가 됐다. 이건 설치노트에 기록한다.

말로만 듣던 zfs는 정말 강력했다. 이걸 보면서 왜 애플이 Snow Leopard에 zfs를 채용하려다 말았는지에 대한 기사를 찾아보게 됐었을 정도였다. 애플이 zfs 도입했었으면, 안그래도 느린 타임머신이 지금보다 훨씬 더 빨라졌을 거다. 다만, 사용법과 개념이 익숙치 않아서 스냅샷을 찍었는데 제대로 안찍혀서 복구가 안되는 문제를 경험했고 하드디스크 전체가 아니라 일부분씩 따로따로 스냅샷을 찍는다는 것도 알았다. 마찬가지로 상세한 자료가 없어서 Sun 홈페이지에 있는 ZFS Administration 가이드에 많이 의존했고 그걸 통해서 대충 감을 익혔다. 그런데 zfs가 2006년도에 나온 파일시스템이라는 점을 감안하면 정말 강력하고, 아마도 정말 최후의 파일시스템이 되지 않을까 싶다. 
웹서핑을 하다보니 Java Web Console이라는 웹브라우저를 통한 ZFS 관리를 할 수 있는 툴을 발견했는데, 이게 솔라리스 10에는 있고 오픈솔라리스에는 없는 거다. 난 분명히 둘이 서로 완벽히 똑같고 오히려 오픈솔라리스에 더 최신기술이 들어가있다고 들었는데 Java Web Console이 오픈솔라리스에는 없는 것이었다. 왜 없는지에 대해서도 한참 구글링을 했다. 한국 사이트에는 있을리가 만무했고, 오히려 zfs 파일시스템의 사용법조차도 자세히 나온 곳이 없었다. 이것도 한참을 헤맸고, 왜 없는지에 대해서는 못찾았다. 다만 설치는 어찌어찌해서 정상적으로 가동은 시켜냈다.

Zone은, 역시 처음에 개념과 사용법에 익숙치 않아서 자료를 한참 찾아댔다. 이것은 Solaris Technet의 김석님께서 쓰신 솔라리스 컨테이너 비교분석 자료에서 조금 도움을 얻었다. 열심히 쓰신 문서가, 마치 자기가 만든 자료인양 사용하는 학원강사들이 있다는 걸 알았는데 그래서 아마도 한글자료 찾기가 어려웠나 싶다. 이 자리를 빌어 자료만들어주시는 분들께 감사드린다. 아무튼, zone으로 웹서버 전용 존을 하나 만들어봤는데, 이것도 무척 재밌고 강력하다는 생각이 들었다. 솔라리스 쓰는 분들이 흔히 하는 말들이 "아름다운 OS", "아름다운 파일시스템" 등등 아름답다는 표현을 붙이는데, 쓰다보면 정말 강력하다는 느낌이 든다. 그리고 이 강력함이 아름다운 것으로 승화되는 것 같다. 마치 스타크래프트의 프로토스가 저그로 오염된 행성을 파괴하는 것을 보고 아름답다는 표현되어있는데 (스타크래프트 게임 패키지 내 스토리북) 그게 그런 의미인가보다. 강력하면 아름다워진다.

Mac OS X 이후 특정 Unix에 이렇게 매료된 게 처음인 것 같다. 게다가 우분투와 비슷한 수준의 세련된 GNOME은, 아마도 리눅서들이 오픈솔라리스로 넘어가게될만큼 친숙한 환경이었다.
오픈솔라리스를 쓰다보니 대체 솔라리스와 오픈솔라리스와의 차이는 뭘까하고 구글링을 해봤는데, 이것조차도 답을 구하기가 어려웠다. 질문을 하는 사람도 없고 대답을 해주는 사람도 없었다. 결국은 unix.com이라는 유명한 유닉서 사이트에서 답을 구했는데, 오픈솔라리스는 Sun Microsystems에서 정식으로 지원해주는 "솔라리스의 소스코드를 바탕으로하는 오픈소스 프로젝트"라는 점이고, 솔라리스는 "솔라리스"라는 브랜드 이름을 갖고있으며 테스트되었고, 검증되었고, Sun으로부터 유지/보수가 이루어지고, 차기버젼의 솔라리스는 항상 오픈솔라리스의 소스코드로부터 나온다는 점이다. 즉, 레드햇과 페도라 정도의 관계로 이해하면 되겠다. 내가 참고한 원문은 http://www.unix.com/whats-your-mind/24870-sun-solaris-open-solaris.html 에서 확인할 수 있다.

솔라리스. 반해버렸다.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
1주일 동안 삽질해가면서 make.conf랑 커널 옵션 찾아내고 별짓 쌩쑈를 다 해서 젠투를 설치했건만, 설치한지 불과 2주도 안되서 젠투를 밀어버렸다. 왜 그랬을까.
내 나이 30대에 전산이라고는 쥐뿔도 모르는 은행원 출신인데다 회계랑 재무 전공하러 미국까지 와놓구선, 4년제 편입할 때쯤 되서 전공을 컴퓨터로 바꿔버렸다. 왜 그랬을까.

내 블로그의 다른 글에서도 여러차례 적어놨지만, 나는 유닉스 계열의 OS를 정말 좋아한다. 리눅스, MacOS X 등등이 너무 좋다. 그래서 컴퓨터라고는 개뿔도 모를 것 같은 전직 은행원 출신이 리눅스 커널설정 고친다고 /usr/src/linux/.config 들여다보고 있는 장면은 좀 예상 밖일 거다. 근데 이게 내가 고등학교 2학년 때부터 해오던 짓이었다.

슬랙웨어 2.2부터 시작해서 별의별 배포판을 다 구경해본 -절대 사용이 아니다. 구경만 해봤다- 바로서는 째끔 차이는 있겠지만 어차피 거기서 거기다. 다만 데비안/우분투 쓰다가 CentOS 구경해보니까 이거는 갭이 좀 컸다. 레드햇 계열 쓰다가 데비안 계열로 넘어오는 건 할만한데, 데비안 계열 쓰다가 레드햇 계열로는 못넘어간다는 말이 실감이 가더라.

이런 나한테도 정말로 적응이 안되는 게 있었다면, 리눅스는 여차여차해서 대충 알겠는데, FreeBSD랑 유닉스는 도통 모르겠던 거다. 표준 명령어 ls, cp, ln 같은거 말고는 당최 뭘 어떻게 쓰는지도 모르겠고, 그노무 슬라이스라는 건 대체 파티션이란 얘긴지 디렉토리를 보기좋게 잘라놓은 건지 모르겠단 말이었다. 게다가 쉘은 왜 그모양인지 백스페이스키도 안먹지, 탭키의 자동완성도 안먹지, vi 열면 방향키도 안먹지.

늦은 나이에 전공을 전산으로 바꾼 사건은 나에게는 아주 의미가 크다.
어차피 회계전공해도 한국에서 그 나이에 취업될리는 만무하고, 그렇다고 미국에서 취업이 잘되는 직업도 아니고.
아, 물론 취업이 잘되는 분야는 맞다. 그런데 너무 인기가 좋아서 경쟁이 치열하다보니 요즘은 만나는 사람들마다 전공 물어보면 전부 다 회계한단다. 처음에는 "오~ 같은거 공부하는 사람이네" 했었는데, 이제는 "또 회계야..." 이런 생각 든다. 다 경쟁자인 셈이다.
미국 내에서도 경쟁이 치열해서 취업하기 힘들 뿐더러, 워낙 사람이 많다보니 취업이 되도 월급 쥐꼬리만큼 나오는거 (한국보다도 월급이 더 적다) 차라리 취업 잘되고 돈 많이 버는 걸로 하자는 결론을 냈다. 어차피 한국으로 돌아가더라도, 한국은 전공에 상관없이 취업이 가능한 나라잖아. 미국은 거의 불가능하지만...
그와 동시에, 한국으로 돌아가지 않겠다라는 다짐이기도 했다. 그래서 Computer Science로 전공을 바꿨다. 다행히 Community College에서 수학을 꽤 높은 반까지 해놔서 다행이었다.

그러다보니, 늦은 나이에 전공도 바꿨고 취업도 되야하고 이런저런 별 생각 다 하니까 이게 아무 죄없는 젠투한테 시선이 가더라. 과연 내가 이거 공부해서 취업하는데 도움이 될까. 과연 젠투로 서버를 돌리는 곳이 있을까. 그런데 젠투를 계속 써보고 싶기는 한데... 우선 재미가 있으니...
그러다 문득 하와이 대학교 myuh 시스템이 생각났다. 하와이 대학교랑 HPU는 내부 시스템이 대부분 솔라리스다. 이걸 공부하면 취업하는데 도움이 되겠지. 하와이 섬나라 애들 할 줄 아는게 대부분 윈도우니까.

설치하면서 문제가 생기는 것들을 구글링하니까, 한국에는 한글로 나와있는 자료들이 별로 많지않다. 대부분 vmware를 이용한 설치 및 기타 등등 설치에 대한 내용이 대부분이었고, 몇몇 유닉스 관련 사이트에서도 솔라리스 강좌를 보면 대부분 유닉스란 무엇인가부터 시작해서 ls니 cp니 하는 아주 기초적인 유닉스 사용법부터 시작하는 문서들 뿐이었다. 즉, 나처럼 리눅스를 째끔 쓸 줄 아는 사람들이 사용 중 닥치는 문제라던가 하는 점에 있어서는 해결하기가 매우 난감했다.

결국은, 대부분 외국 사이트에서 해결했고 그나마도 관련자료가 별로 많지 않았다.
따라서 오픈솔라리스를 쓰면서 생긴 문제점과 해결책을 적는 노트를 티스토리에 하나 포스팅해서, 계속 업데이트하는 식으로 쓸까한다.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
3편까지 해서 모두 잘 따라오셨다면 이제 X를 설치할 차례다. 필자의 경우, X를 쓰지않고 콘솔에서 모든 걸 다 해결하기 위하여 프레임버퍼, 부트스플래쉬 등등 여러가지 유틸리티를 깔아봤긴 했지만 일단은 한글을 읽고쓰는 것이 불가능하다는 큰 단점 때문에 일단 X를 빌드하긴 했다.

또다른 X 빌드의 이유 중 하나는, 인터넷 공유기의 암호가 WPA로 되어있는데 WPA 접속을 가능하게끔 해주는 패키지의 속성에 반드시 X를 빌드해야만 했다. USE="-X"를 넣고해도 소용이 없었다. 그래서 무선랜도 가능해야했고 혹시나 모를 비상을 위해서 X와 KDE로 빌드를 시작했다.

사실, X-Windows 설치에 비하면 지금까지 해왔던건 아무 것도 아니다. 그래픽카드마다 드라이버 잡아줘야하고 xorg.conf 파일 세팅해줘야하고 엄청난 컴파일 시간을 보내야하고... 그나마 96년도부터 리눅스를 써온 필자로서는 xorg.conf 파일의 설정이 그리 어렵게 느껴지진 않았지만, 처음 해보시는 분들은 아마 크게 당황하실 거다. 게다가 필자가 처음 젠투를 설치했었던 대략 2004년도 당시의 컴퓨터로는 젠투 기본시스템+X+GNOME+Firefox까지 빌드하는데 무려 일주일씩 걸렸었다. 그런데 그 짓을 무려 7번이나 했다.

아마 X를 빌드하다보면 2-3개 패키지 정도는 에러내면서 설치를 멈출거다. 그 정도는 사실 에러메시지 보면서 해결해내야한다. 필자 역시 프로그래머는 아니지만 에러메시지 보고 대략 추측으로 때려서 해결한 문제가 대부분이다. 또한, 젠투에서 패키지 빌드하는 도중에 뱉어내는 에러들은 대부분 USE 플래그에서 일어난다. 일부 문제의 경우는 ACCEPT_KEYWORDS에서 생기는 경우도 있지만 대부분은 USE에서 난다.
단순한 에러의 예를 들자면
메시지: Configure: error: --zip not found in $PATH
이러한 메시지가, 길고 긴 emerge 에러메시지 중간에 위치하는데, 이런걸 들여다보면 해결이 보이지 않는가?
emerge zip 하면 해결이 되는 거다.

조금 더 해보자.
phpmyadmin을 빌드하다 에러를 냈다. phpmyadmin이, 뭔가를 컴파일해서 만들어내는 패키지가 아님에도 불구하고 에러를 냈다. 처음에는 이해가 되질 않았다. 사실 지금도 이해는 안가긴 하고 사이트가서 직접 파일들 다운받아다 압축만 풀면 해결되는 문제니까 그럴 수 있었지만 그냥 해결을 하고싶었다.
에러메시지가 길긴 하지만 올려본다.

뭐 솔직히 나도 무슨 말인지는 모른다. 나도 프로그래머가 아니니까.
다만 눈길이 가는 부분이 있다면
 * dev-lang/php-5.2.11-r1 needs to be re-installed with all of the following
 * USE flags enabled:
 * 
 * crypt ctype pcre session unicode
 * 
 * as well as any of the following USE flags enabled:
 * 
 * mysql or mysqli if using dev-lang/php-5
이 부분이다.
해석을 해보면, "아래의 USE Flags를 활성화시켜서 php를 재설치해야합니다, crypt, ctype pcre session unicode"
"또한 만약 php5를 사용 중이라면 다음 패키지도 USE 플래그를 활성화시켜야합니다. mysql 또는 mysqli"

간단하다. USE="crpt, ctype pcre session unicode" emerge -avq php mysql 했다.
그리고나서 emerge phpmyadmin 했다. 설치가 잘 됐다.

X 설치를 준비하자. 일단 사운드 데몬을 설치한다.
# emerge alsa-utils
# alsaconf 사운드카드를 잡아주는 유틸리티이다.
# rc-update add alsasound boot 아마도 boot에 등록하는 첫 데몬이 아닐까 싶다.
# gpasswd -a USERNAME audio USERNAME에 각자의 로긴아이디를 넣는다. 사운드를 이용하게해준다
# emerge madplay mpg123 gstreamer 콘솔에서 사용할 수 있는 mp3 플레이어를 설치한다.
# env-update;source /etc/prpofile
# mpg123 test.mp3 MP3 파일 하나를 가져다 테스트 해본다.
# emerge pmount 일반유저로서 USB 저장장치 등을 마운트/마운트해제 할 수 있게 해주는 툴이다.

다음  avahi를 설치해야하는데, 사실 이거없이 X 이용하는데는 지장이 없겠지만 필자 생각으로는 이걸 먼저 해야할 것 같다. 그래야 후에 문제가 생기지 않을 것 같다. 다만 avahi에 걸려있는 의존적인 패키지들이 많기 때문에 이거 빌드하는데 시간이 꽤 걸릴 거다.
# emerge avahi

다 됐으면 X를 빌드하자. X는 데스크탑 매니져를 빌드하면 당연히 의존관계에 있기 때문에 같이 딸려오니, 데스크탑 매니져를 설치하자. 필자는 KDE를 설치했으므로, KDE를 기준으로 설명한다. 혹시모르니까 X가 빌드되어있는지 확인해보자.
# emerge -pv xorg-server

노트북 쓰신다면 마우스패드 (시냅틱) 드라이버를 설치해야한다. 이거 안하면 정말 피곤하다. 마우스가 지멋대로 움직이는데, 아마 노트북을 집어던지실지도 모른다.
# emerge -avq xserver-xorg-input-synaptics

-pv는 뭐뭐 설치될지 패키지 리스트만 물어보고 끝나지만 -av를 붙여주면 리스트를 보여주고 설치할 건지 아닐건지를 물어본다. 필자는 명령어를 두 번 타이핑할 일이 없는 -av가 개인적으로 더 편하다.
 일단 USE 플래그 먼저 점검을 해야하는데 KDE를 설치할 때 -gtk를 하지말자. 한글입력기를 설치해야하는데, ibus, scim-qtimm 등이 작동이 잘 안된다. 적어도 필자의 시스템에서는 그랬다. 둘다 전혀 작동이 되질않았고 결국은 국산 nabi를 이용해서 해결을 봤다. 근데 nabi는 gtk 어플이기 때문에 -gtk를 넣으면 안된다.
먼저 어떤 패키지들이 어떤 속성을 갖고있는지 체크를 해보자.
# emerge -pv kdebase-meta

kdebase-meta라는 패키지는, 패키지 이름이 아니라 KDE의 기본패키지들의 목록을 갖고있는 패키지다. 따라서 kdebase-meta로 -pv를 날려주면 KDE의 기본시스템에 어떤 패키지들이 설치되는지를 보여준다. 내용을 보시고 만약 본인이 (-)를 해준 옵션이 있다면 USE를 수정해주자. 그런 다음 빌드를 시작하자.
# emerge -q kdebase-meta

-q 옵션은 빌드하면서 나타내는 컴파일러 메시지를 화면에 뿌려주지 않는다. 조용히 빌드해주고 에러가 났을시만 메시지를 뿌려준다. 전기세라도 좀 아낄겸 Alt+F2로 다른 콘솔로 넘어가 setterm -blank 3을 해주자. 키보드 입력이 없을시 3분 후에 모니터를 꺼준다.

X까지 같이 빌드하기 때문에 꽤 오래 걸릴거다. 밤에 시작해서 아침에 자고일어나면 끝나있을 거다. 이제 나머지 KDE패키지들을 빌드한다. 역시 -pv를 줘서 USE플래그를 확인한다. 그리고 빌드를 시작한다.
# emerge -pv kde-meta
# emerge -q kde-meta

한 가지 덧붙이자면, meta라는 패키지 자체가 뭔가 있는 패키지가 아니라 관련패키지의 목록을 갖고있는 패키지이기 때문에 컴파일하다 중간에 에러내면서 멈추면, 다시 수정하고 emerge kde-meta를 했다간 이미 컴파일이 끝난 패키지도 다시 다 하는 것을 볼 수 있다. 이것은, emerge가 해당 패키지가 빌드가 됐는지 안되는지에 대한 여부를 판별하지 않기 때문이고 또한, 해당목록에 존재하는 패키지를 다시 설치하려고 하기 때문에다. 말로 설명하기가 어려운데, 해보시면 이해가 가실 거다. 그나마 다행인 것은 kdebase-meta는 패키지가 몇 개 안된다.

kde-meta는 아주 많다. 끝나고나면 패키지를 꼭 적용해주고 xorg.conf를 설정해야한다.
# env-update; source /etc/profile
# Xorg -configure

이제 ls /root를 하면 못보던 파일 하나가 있을 거다. Xorg가 자동으로 설정을 잡아서 내놓은 파일인데 이것을 테스트삼아서 X를 띄워보고, 잘 뜨면 이 파일을 그대로 쓰면 되겠다. 혹시 모르니까, 다른 컴으로부터 루트로 ssh에 접속해있자. 이거 실행하고나면 키보드가 안먹을 수도 있다. 다운된 건 아니다. 키보드가 응답을 안하는데, 이유는 잘 모르겠다. 필자의 시스템에만 한정된 현상일 수도 있다.
# X -config /root/xorg.con.new

하고나면 뭔가 뜨긴 뜬거 같은데 보이지는 않고, 다시말해 까만화면을 백라이트가 비추고있는 듯한 화면이 뜰거다. 이제 Ctrl+Alt+Back Space를 눌러서 X를 종료하고 xorg.conf 파일을 만들어준다.
키보드와 마우스의 기본적인 움직임 정책파일을 세팅해줘야한다.
# cp /usr/share/hal/fdi/policy/10osvendor/10-input-policy.fdi /etc/hal/fdi/policy
# cp /usr/share/hal/fdi/policy/10osvendor/10-x11-input.fdi /etc/hal/fdi/policy

/etc/hal/fdi/policy/10-x11-input.fdi 파일을 편집에서 라인 한 줄을 추가시킨다.
<match key="info.capabilities" contains="input.keys">
      <merge key="input.x11_driver" type="string">keyboard</merge>
      <merge key="input.xkb.options" type="string">terminate:ctrl_alt_bksp</merge>
      <match key="/org/freedesktop/Hal/devices/computer:system.kernel.name"
             string="Linux">
        <merge key="input.x11_driver" type="string">evdev<merge>
      </match>
</match>

이제 kdm을 띄운다. kdm은 root에서만 띄울 수 있다.
# cp /root/xorg.conf.new /etc/X11/xorg.conf
# kdm

X의 설치가 끝났다. 솔직히 중간중간 에러나서 컴파일이 중단된 게 많았는데, 이걸 하나씩 잡아가면서 스크린샷을 찍지 못했던 게 개인적으로 아쉬웠다. 콘솔에서도 스크린샷을 찍을 수 있는 유틸이 있다는 걸 알았다면 더 좋았을텐데 무척 아쉽다.

한글입력기 nabi를 설치하고 로케일을 세팅해줘야한다. 이것은 구글링하시면 수도없이 쏟아져나온다. 다만 한가지 다른 점은 우리는 KDE를 빌드했으므로 GTK_IM_MODULE=nabi 말고도 QT_IM_MODULE=nabi를 추가시켜줘야한다는 점이다.

그외 설치했던 툴로는, fbgrab (콘솔에서 스크린샷을 찍는 툴), links2 (콘솔용 그래픽 웹브라우저) 정도가 있다.
되도록이면 X를 띄우지 않기 위해서 콘솔용 툴들을 구글링을 통해서 많이 접했고 대부분을 설치해서 써봤다. 정말 X 없이도 그런대로 쓸만했었다. 물론 데탑용 컴퓨터로서는 최고의 매킨토시가 있었으니 그런대로 쓸만했었겠지. 참고로 부트스플래시 사용할 때, Grub에 vga=792 옵션 있으면 커널 부팅메시지가 전부 보여서 별로 예쁘지가 않았다. 부트스플래시 사용할거면 차라리 vga 옵션은 꺼주는 게 낫다. 어차피 부트스플래시를 이용한 고해상도 콘솔을 쓸거니까.

젠투용 각종 테마들은 http://gentoo-art.org/ 에서 구할 수 있다.

젠투 설치기를 여기서 끝마치기로 한다.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
이제부터는 시간 오래 걸리고 지루한 것만 남았다.

부트스트랩 과정을 지켜보신 분은 아시겠지만 중간에 gcc를 컴파일하는 과정이 있다. 사실 그거 앉아서 지켜보는 사람이 별로 없을텐데 본인은 아주 이상한 성격이라서 컴파일하는거 아무 뜻도 모르면서 그냥 계속 지켜본다. 일단 부트스트랩이 끝났다는 의미는, 시스템을 설치할 준비가 됐다는 얘기다.

먼저, 컴파일러의 작동을 캐싱해주는 C Cache를 설치하자. 앞서도 잠깐 설명했지만, C 컴파일러가 실행하는 단순/반복 작업에 해당하는 것들을 캐싱을 해서, 다음번 컴파일할 때 더 빨리 컴파일해줄 수 있도록하는 프로그램이다. 아마도, 여러번 컴파일할 일이 있을까 라고 생각하실 분이 계실텐데, 있다. 분명히 생긴다. 그러니까 캐쉬 설치한다고 손해보는 것도 아니니까 그냥 설치하자.  참고로, 컴파일할 때 화면에 나오는 메시지들을 보고싶지 않으면 -q 옵션을 붙이시면 된다.  그러면 패키지당 딱 2줄만 표시한다.
# emerge -q ccache

C Cache에 대한 make.conf 설정은 앞편에서 했으니 링크만 좀 잡아주도록 하자. C Cache가 유저별로 캐싱디렉토리를 저장하게 되어있는데, 어차피 이 글을 보는 분들은 개인적인 컴퓨터에 젠투를 설치하실 분이니 그냥 캐싱을 한 디렉터리에 하도록 하자.

# rm -rf ~/.cache
# ln -s /var/tmp/ccache $HOME/.ccache

이것으로 C Cache의 설정이 완료됐다. 뭔가 하나 컴파일이 끝난 뒤 ccache -s 를 하면 캐시된 상황을 보여줄거다. 뭔가 숫자가 조금이라도 올라가는 것 같으면 작동하고 있는거다.

이제 부트스트랩 과정에서 설치된 패키지들을 적용시키자.
# env-update
# source /etc/profile

사실, env-update를 꼭 해야할만한 패키지들은, 설치가 끝나면 알아서 해주긴 하는데 그래도 혹시 모르니까 하자. 젠투 쓰다보면 저 위의 명령어는 손에 붙는다. 습관적으로 때리게 된다. 
이제 perl을 빌드할 차례다. perl에 의존적인 패키지들을 위해 아래의 명령어를 쳐준다.
# emerge --nodeps -q gdbm libperl perl

내가 설치 중 참고한 http://xprogrammer.tistory.com/40 문서에 의하면, 위의 패키지를 먼저 설치해주지 않으면 나중에 두고두고 후회할 일이 생긴다는데, 나는 저 메시지보고 바로 설치를 해버려서 무슨 후회할 일이 생기는지는 잘 모르겠다. 실험정신이 투철한 분이 계시면 그냥 건너뛰어보셔도 되겠다. --nodeps는 의존성 관계 무시하고 설치하라는 옵션이다.

설치가 끝난 뒤 패키지를 적용한다.
# env-update
# source /etc/profile

이제 시스템을 설치한다. 듀얼코어/코어2듀어 사용자라고 해도 꽤 걸린다. 특히 글쓴이가 만들어놓은 make.conf 파일을 그대로 쓰시과 eselect의 프로파일에서 GNOME이나 KDE를 선택하셨다면 300개가 넘는 패키지를 컴파일하려고 할거다.  일단, 베이스만 빨리 빌드하시고 싶으시면 다시 프로파일을 1번으로 바꾸시면 된다.  그러면 약 180개 정도의 패키지를 빌드한다.
# emerge -eq system

-e 옵션은 해당 패키지와 의존성 관계된 모든 패키지를 다시 컴파일하는 옵션이다. 보통의 경우는 아마 쓸 일이 없을텐데 CFLAGS를 바꿨다거나 gcc 버젼이 아주 크게 업데이트 됐을 때 이외에는 아마 안쓸거다.
위의 시스템 빌드가 끝나고 나면 아래의 명령어를 입력해서 제대로 설치가 됐는지 확인한다.
# emerge -epv system

뭔가 주르륵 나오는데, 일단 딴건 다 무시하고, 맨 앞에 [ebuild R]이라고 적혀있는지만 확인하자.
만약 [ebuild N] 이라고 적혀있으면, 해당 패키지는 설치가 안됐다는 얘기다. 그런데 여기서 설치안된 패키지 빌드한답시고 -e 붙였다간 시스템 전체를 싸그리 다시 다 컴파일할 거다 (위에 설명한대로). 그러니 설치가 안된건 그냥 개별적으로만 하자. emerge package_name 하시면 되겠다.

시스템을 적용시키자.
# env-update; source /etc/profile

아까 위에서 emerge -epv system 해서 확인하실 때 util-linux, shadow, psmisc, module-init-tools, procps, man, pciutils 설치됐는지 같이 확인하자. 없으면 설치하자.
만약 pciutils 설치하자 에러나면 다음과 같이 한다.
# USE="-zlib" emerge -q pciutils

위의 USE="-zlib" 라는 의미는, pciutils를 설치할 때만 일시적으로 zlib 플래그를 제거하고 설치하겠다는 것을 의미한다. 종종 쓰게될 거다. 특히 GNOME이나 KDE 설치할 때는 플래그들이 많을수록 복잡해지기 때문에 USE 플래그 때문에 설치가 안되는 일이 많이 생긴다. 그 정도는 에러메시지 보고 고칠 정도는 되야된다.
컴퓨터 이름을 정해야한다.
# nano /etc/conf.d/hostname

아마 샘플이 들어있을텐데 형식은 이렇다.
HOSTNAME="computer_name"
저장한다. nano의 저장 후 종료키는 Ctrl+x다. 아마 vi가 설치되어있을테니 원하시는 것으로 하시면 된다.
이제 컴퓨터 도메인 이름을 세팅해야한다.
# vi /etc/hosts

형식은 대강 다음과 같이 하시면 된다.
127.0.0.1     computer_name.computer_domain computer_name localhost

이제 랜카드를 잡아줘야한다. 이거 보시는 분들은 모두 집에서 공유기 쓰실테니 dhcp로 ip를 잡아줘야할거다.
# emerge -q dhcpcd
# rc-update add dhcpcd default

위의 rc-update는 매우 유용하고 편리한 명령어인데, 부팅시 시작하는 프로그램들(서버데몬)을 등록/제거해주는 명령어다. rc-update add 하면 등록, delete 제거이다. 뒤의 default는  시작프로그램을 의미하고 boot라고 하면 부팅할 때 윈도우로 치자면 드라이버 로딩하는 것 같은 개념인데 대부분의 데스크탑유저가 boot에 등록할 일은 거의 없을 거다. 어쨌든, 위와 같이 해주고 세팅을 해줘야한다.
# vi /etc/conf.d/net

랜카드가 eth0 이신 분들은 아래와 같이 넣는다.
config_eth0="dhcp"

끝이다. 매우 쉽지 않은가. 이제 0부팅하면서 랜카드가 자동으로 활성화되도록 한다.
# cd /etc/init.d
# ln -s net.lo net.eth0 
# rc-update add net.eth0 default

초반 제일 중요하다고 볼 수 있는 ssh를 설치하자.
# emerge ssh
# rc-update add sshd default

다음 ssh를 사용하려면 일반사용자를 등록하고 패스워드를 정하자.
일단 root 패스워드부터 만들자.

# passwd
# adduser USERNAME -m -d /home/USERNAME -G users,wheel,audio -s /bin/bash
# passwd USERNAME

그 이외 몇가지 필수적인 시스템 툴을 설치하자.
# emerge -q syslog-ng vixie-cron hotplug gentoolkit dbus hald rdate grub

설치가 되는 중간에, Alt+2 키를 눌러 다음 콘솔로 넘어가서 몇가지 작업을 해주자.

# chroot /mnt/gentoo /bin/bash
# env-update (chroot 하고난 다음에는 반드시 해야한다)
# source /etc/profile

먼저 시스템의 시간을 설정하자.
# ln -sf /usr/share/zoneinfo/Pacific/Honolulu /etc/localtime

글쓴이는 지상낙원 하와이에 살아서 호놀룰루로 시간을 맞췄다. 한국 사시는 분들은 Asia/Seoul 하시면 되고, 그외 해외 사시는 분들은 ls /usr/share/zoneinfo 하셔서 해당지역을 /etc/localtime으로 링크해주시면 된다.

이제 fstab 파일을 수정해야한다. 이거 잘못 수정하는 것이 커널패닉의 원인이기 때문에 잘해야한다. 어렵지는 않은데, 파티션에 대한 개념이 안잡혀있으면 어려울 거다.
# vi /etc/fstab

처음 열면
/dev/BOOT     /boot     어쩌구저쩌구
/dev/ROOT     /         어쩌구저쩌구
라고 되어있는데 여기서 BOOT, ROOT이거를 꼭 편집해야한다. 이번 젠투설치하면서 구글링을 수도없이 많이 했는데 이거 그대로 놓고 커널패닉 난다고 질문하는 분 여럿 봤다.
먼저 필자의 fstab이다.

/dev/sda3               /               ext3            noatime         1 1
/dev/sda4               none            swap            sw              0 0
/dev/cdrom              /mnt/cdrom      auto            noauto,ro       0 0
shm                     /dev/shm        tmpfs           nodev,nosuid,noexec    0 0
proc                    /proc           proc            default         0 0

첫번째 부분은 디바이스명이고 두번째 부분은 마운트 포인트, 세번째는 파일시스템 종류, 네번째는 옵션, 마지막은 덤프와 패스 옵션이다.
세번째꺼까지는 아마 필자나 여러분이나 비슷비슷할 거다. 만약 /boot 파티션을 따로 넣어주신 분이라면,
/dev/BOOT              /boot           ext2            noauto,noatime  1 2
정도로 넣어주시면 되겠다. 어디까지나 fstab 예제에서 갖고왔다.
참고로 덤프/패스에서 패스 부분은, 1을 넣으면 마운트 일정횟수 도달시 fsck를 실행해서 파일시스템을 체크하고, 0을 넣으면 검사하지 않는다.

그 다음 1번 콘솔에서 걸어놓은 패키지들의 빌드가 끝났으면 패키지를 등록하고 몇몇을 부팅시 자동으로 실행되게 등록한다.

# env-update;source /etc/profile
# rc-update add syslog-ng default
# rc-update add vixie-cron default
# rc-update add hotplug default
# rc-update add dbus default
# rc-update add rdate default

타임서버와 시간을 맞춘다.
#vi /etc/conf.d/rdate

RDATE_SERVER="gentoo.pool.ntp.org" 대충 이런 식으로 디폴트값이 되어있을텐데 따옴표 안에
"time.bora.net"을 넣자. 참고로, 아까 위에 타임존 링크를 거신 분이라면 해외에 사시는 분들도 보라넷으로 시간동기가 가능하다.
이제 시간을 맞춰주자.
# /etc/init.d/rdate start

아마 한동안은 부팅시 /etc/init.d 혹은 conf.d 등의 시간이 안맞다던가 뭐 파일이 미래에 수정됐다느니하는 메시지를 보실 수도 있다. 근데 rdate를 부팅시 자동으로 뜨게 등록했으니 조금만 쓰다보면 안나올거다.
이제 grub을 설정하자.
mtab을 만들어준다.
# grep -v rootfs /proc/mounts > /etc/mtab

Grub을 설치한다.
# grub-install --no-floppy /dev/sda

여기서 시간 좀 걸릴 수 있다.
# grub --no-floppy /dev/sda

Grub 프롬프트가 나오면 아래와 같이 입력한다.
grub> root (hd0,0)      # 첫번째 파티션이면 0,0이고 두번째 파티션이면 0,1 그리고 세번째 파티션이면 0,2이다.
grub> setup (hd0)      # 첫번째 하드디스크면 hd0이다. 두번째는 당연히 1이다.
grub> quit

이제 Grub이 설치됐다. 설정을 해보자.
# vi /boot/grub/grub.conf

default 0     # 첫번째 메뉴를 기본값으로 한다.
timeout 3    # 부팅메뉴시 자동으로 부팅되도록하는 시간이다. 초단위로 정한다.
splashimage=(hd0,2)/boot/grub/splash.xpm.gz # Grub 메뉴에서 배경그림을 나오게끔 하는 옵션이다. 넣고 싶으신 분은 /boot/grub/에 해당파일이 있는지 확인하고 파일명이 맞는지까지 보자. hd0,2는 첫번째 하드의 3번째 파티션이라는 의미이다. 

title Gentoo Linux
root (hd0,2)
kernel 
initrd
savedefault

title Windows 7
rootnoverify (hd0,1)
makeactive
chainloader +1

이 정도로 간단하게 하시면 되겠다. 리눅스 부팅부분에 kernel 하고 다음 부분을 적어줘야하는데 이건 커널컴파일이 끝나고 적도록 하자. 

이제 마지막 과정이라고 할 수 있는 커널을 컴파일할 차례다. 초보분이시라면 가장 겁나는 부분이 아닐까 싶다. 이런 분들을 위해서 젠투는 알아서 컴파일해주는 도구를 마련해줬다.
일단은 커널 소스부터 받아오자.
# emerge -q gentoo-sources

여기서 커널을 직접 세팅해서 컴파일할 줄 아시는 분들은 (굳이 이 매뉴얼 자체가 필요없으신 분들이겠지만) 바로 /usr/src/linux로 가셔서 진행하시면 되겠고, 모르시는 분들은 커널컴파일 도구로 커널을 설치하자. 직접 컴파일하실 분들에게 참고로 말씀드리자면 genkernel로 커널을 컴파일하는 것과 직접 하는 것은 /boot/grub/grub.conf 파일의 내용이 다름을 유의하자.
# emerge -q genkernel
# genkernel

시간이 꽤 오래 걸린다. 대부분의 컴퓨터에서 부팅할 수 있는 범용적인 커널을 만들기 위해 대부분의 기능들을 모듈로 컴파일해버리기 때문에 꽤 오래 걸린다. 끝나고나면 ls /boot 해서 커널이 설치됐는지 확인하자.
확인이 됐으면 이제 남은 /boot/grub/grub.conf 파일을 수정할 차례다.
커널의 정확한 이름을 적어놓고 grub 파일을 편집한다.
# vi /boot/grub/grub.conf

kernel 다음에다 아래과 같이 입력한다.
kernel /boot/kernel-genkernel-x86-2.6.30-gentoo-r6 root=/dev/ram0 init=/linuxrc \
             ramdisk=8192 real_root=/dev/sda3
initrd /boot/initramfs-genkernel-x86-2.6.30-gentoo-r6

genkernel로 커널을 설치한 분이 아니시라면 아래와 같이 간단하게만 해도 된다. 또간 initrd는 빼도 된다.
/boot/vmlinuz-2.6.31-gentoo-r6 root=/dev/sda3 ro

저장하자.
이제 모든 설치가 다 끝나고 최소한의 리눅스 시스템이 완성됐다. 마지막으로, 설치된 모든 패키지들의 의존성 관계를 검사하자.
# revdep-rebuild
# env-update; source /etc/profile

그외 설치는 다음편에서 계속한다.


블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
대망의 make.conf  파일 편집이다. 사실 이것을 지금하지 않아도 부트스트랩을 하는데는 문제가 없지만, CFLAGS 때문에 그냥 미리 다 세팅해놓고 시작했다.

사실 젠투의 최적화는 여전히 말이 많은 부분이고 논쟁의 여지가 있는 부분이다. 따라서, make.conf의 CFLAGS는 별로 의미없는 옵션일지도 모르겠지만 1편에서도 적었듯이 내가 만족스럽다는데 누가 뭐라고 하겠는가. 이 글을 읽는 분이라면, 누가 이래든 저래든 젠투설치 하실 분이라고 생각한다. 젠투 최적화의 허와 실에 대해서 알고싶으신 분은 http://kldp.org/node/81215 글을 읽어보시면 되겠다. 아마 매우 도움이 될 거다.

먼저 필자의 make.conf 파일을 올려서 설명해드린다. 내 블로그를 좀 읽어보신 분은 보셨겠지만 나는 전산학도도, 전산업계에 근무했던 사람이 아니다. 어디까지나 금융권에서 예금이랑 대출상담하면서 직장생활했었고 단지 리눅스는 취미로 했을 뿐이다 (2014년 9월 개정하는 현재는 전산업계에 근무하고 있다).

1편에서 얘기하면 까먹으실까봐 지금 얘기한다.
글쓴이의 시스템은 인텔 제온 E5-2643, 램64기가, nVidia 쿼드로 K4000 정도다.

/etc/make.conf 파일은 대략 3개의 섹션으로 나뉜다고 볼 수 있다(라고 생각한다). 
첫번째 섹션은 전체적인 환경을 설정하는 섹션, 두번째는 USE Flag, 세번째는 미러링서버 지정이다.
USE Flag도 전체적인 환경을 설정한다고 볼 수 있지만 USE Flag 자체만으로도 상당히 어렵기 때문에 굳이 나눴다.

CHOST="x86_64-pc-linux-gnu" 
64비트로 빌드할 것을 정한다. 32비트로 원하시면 CHOST="i686-pc-linux-gnu"로 하시면 된다.
보다 자세한 사항은 http://en.gentoo-wiki.com/wiki/Safe_Cflags/Intel 여기를 참고하시면 된다.

CFLAGS="-march=corei7-avx -msse -msse2 -msse3 -mmmx -O2 -pipe -fomit-frame-pointer"
먼저 이 부분에 대한 자세한 사항은 여기를 클릭하시라.
내가 프로그래머가 아니니 설명이 틀릴 수도 있다는 점을 이해부탁드린다.
코어2듀오일 경우 mtune=core2 -march=core2 옵션을 붙이시면 된다.
mssse3 msse3은, 사실 gcc 홈페이지에도 어떻게 붙이면 어떻게 된다는 정확한 설명이 없는데,
cat /proc/cpuinfo 하시면 나오는 부분이니 없으면 빼시고, 있으면 넣으시면 되겠다. 필자는 저렇게 넣고
이상없이 잘 됐다. mssse3이 msse3보다 나중에 나온 명령어인데, mssse3이 msse3까지 포함하는건지 아닌지
설명이 없어서 그냥 넣어버렸다.
-O3은 최적화의 레벨을 정하는 건데, 보통 가장 권장되는 옵션은 -O2이다. -O3가 가장 높은 레벨인데 사실 -O9
까지 있지만 O3 이상은 다 똑같단다. 그리고 O3로 컴파일했다고 해서 얻는 이득보다는 손해가 더 많고 O3로 해봐야
더 느려질 수 있다.
-pipe와 -fomit-frame-pointer는 권장되는 옵션이다. 그래서 보통 다들 꼭 넣는다. 나도 뭔지는 모른다.
설명을 하자면, fomit-frame-pointer는, 쓰이지않는 포인터를 생략해버린다는 옵션인데 그게 무슨 말인지는
잘 모르겠다.
보통 가장 일반적인, 즉 누구에게나 전부 이상없이 빌드할 수 있는 옵션 플래그를 불러보자면, 아마도
CHOST="i686-pc-linux-gnu"
CFLAGS="-march=native-O2 -pipe"
정도이리라 싶다.

CXXFLAGS="${CFLAGS}"
대충 감이 오실 거다. 위에꺼랑 똑같이 하겠다는 거다.

MAKE_OPTS="-j17 -l32"
j값은 자기 컴퓨터가 가진 CPU 코어 갯수에 +1을 하면 된다.  총 작업수를 의미한다.
l값은 CPU 코어 갯수에 2를 곱한다.  코어가 16개 (물리 8 + 하이퍼쓰레딩 8 = 16)라면 숫자는 32가 된다.

VIDEO_CARDS="intel i965"
그래픽카드를 지정하는 것인데, 위의 예제는 인텔통합칩셋을 쓰시는 분을 위한 예제이다.

ALSA_CARDS="hda-intel"
역시 인텔통합칩셋에서 사용하는 사운드카드의 드라이버명이다. 참고로 GM45 칩셋이다. 그외 칩셋들은 "ALSA_CARDS"로 구글링하시면 나올거다. 대충 눈치껏 보고 넣으면 된다.

ACCEPT_KEYWORDS="amd64"
64비트로 빌드시 amd64를 넣고, 32비트일시 x86을 넣으시면 된다. 참고로 인텔 코어2듀오더 amd64라고 한다. 틸드(~)를 넣으면 소프트웨어를 최상위 불안정 버전까지 써보겠다는 의미가 된다.  참고로, 빌드 중 에러가 간간히 난다.

LINGUAS="en ko"
언어를 세팅해준다. 본인은 미국에 살고있기 때문에 컴퓨터에 통째로 한글만 나오면 좀 이상하다. 그리고 여기 사람들이 내 노트북의 모니터를 들여다볼 때 영어가 아니면 좀 불편해하는 감이 없지않아 있다. 그래서 일단 영어를 가장 먼저 했고 다음에 한국어를 넣었다. 사실 이게 순서가 상관은 없을 것 같은데, 그래도 혹시 몰라서 이렇게 했다.

FEATURES="ccache"
반복되는 컴파일의 캐쉬기능을 넣는 옵션이다. 다만, 이 옵션은 ccache라는 패키지를 빌드해야만 하는데, 그 전까지는 적용되지 않는다. 부트스트랩할 때부터 넣어놔도, 알아서 무시하고 빌드한다. 난 귀찮아서 미리 넣었다.

CCACHE_SIZE="2G"
위의 ccache의 캐쉬사이즈다. 캐쉬는 하드에 저장된다.

CCACHE_DIR="/var/tmp/ccache"
ccache의 경로를 지정한다. 이건 바꾸지 말자.

INPUT_DEVICES="evdev mouse keyboard synaptics"
입력장치를 나열한다. 노트북을 쓰신다면 시냅틱 마우스패드 입력기를 넣는다.

다음은 USE Flags다. 전부 다 설명할 수 없으니 USE flags의 설명이 나온 웹사이트 링크를 드린다.
엔하위키의 설명을 한 번 보시길 추천해드린다.

USE 플래그는, 시스템 전역 세팅을 위한 것인데 쉽게 설명드리자면, 만약 ffmpeg를 플래그에 넣었다면 X와 GNOME 혹은 KDE를 빌드할 때 동영상 관련 프로그램을 컴파일시 ffmpeg를 포함시켜서 빌드를 하게 된다.

아래는 필자의 세팅이다. 필자는 GNOME을 안쓰고 KDE를 쓰기로 했다. 남들 다 쓰는 GNOME을 안쓰는 이유는, 남들이 다 쓰는 걸 쓰고싶지 않아서다. 그래서 젠투를 쓰고 맥을 쓰는 이유지. 그외에도 쿠분투의 KDE를 보고 리눅스가 이렇게 발전했는가를 몸소 체험했다. 너무 예뻤다. 마지막으로, 미국에서 잘나가는 핸드폰 중 하나인 블랙베리의 프로그램들이 QT기반이란다.
GNOME으로 컴파일 하시고 싶으면 -qt4 -kde 하시고 gtk gnome 넣으시면 되겠다.  굳이 -qt4 -kde를 하진 않아도 된다.  kde나 qt를 사용하는 프로그램을 절대로 빌드하고싶지 않다면 -를 쓰면 된다.
필자는 abc 순서대로 적어놨다. 한줄로 길게 늘어뜨리면 편집할 때 귀찮다.

USE="-3dnow -3dfx  
a52 aac acpi apm alsa apache2 avahi aqua autoipd
berkdb bluetooth 
cjk curl cups crypt 
dga directfb drl dts  dvd dvdr dbus 
fbcon fbcondecor ffmpeg firefox flac 
gcj gd gif gpm gzip  
hal 
imagemagick imap innodb ipod -ipv6 iconv 
java javascript jpeg jpeg2k 
kde 
ldap 
-mozila mp3 mp4 mpeg msn -matrox mysql mysqli mhash mng 
ncurses networkmanager nls 
ogg opengl 
pcmcia pdf perl php png pnp -postgres python plasma 
qt4 quicktime 
readline ruby 
samba subversion ssl -slp svga szip sql svg smp 
tcl threads tk truetype tiff tcpd 
unicode usb 
vhosts vorbis -voodoo3 vim-syntax 
wifi win32codecs webkit 
X Xaw3d x264 xml xmlrpc xvid xcomposite 
zeroconf zlib"

나머지 미러설정인데, 이건 1편에서의 mirrorselect 명령을 실행했으면 설정되어있는 부분이다.


이제 대략의 설치할 준비는 다 끝났다. 사실 설치준비가 별 거 없다.
네트워크 설정 -> 파티션 준비/포맷 -> make.conf 파일 설정
이게 다다. 다만 우분투처럼 마우스 클릭만으로 끝나는 설치가 아니다보니 어렵게 느껴질 뿐인 것이고, 또한 다른 글에서 언급했듯 파티션이라던가 하는 아주 기본적인 내용에 대한 기초가 없어서 어렵게 느껴지는 것이다.

이제 루트디렉토리를 / 에서 /mnt/gentoo로 바꿔서 부트스트랩을 시작한다.
# chroot /mnt/gentoo /bin/bash

환경설정을 읽어와야한다.
# env-update; source /etc/profile

젠투 Portage의 트리를 받아와야한다. 이게 뭐하는 거냐면, 우분투/데비안 유저들이 apt-get install xchat2 라고 입력하면, 의존성 관계되는 패키지를 자동으로 계산해서 필요한 파일들을 모조리 받아와서 설치하는 시스템인데 젠투의 emerge도 그런 역할을 한다. 다만, Portage는 -BSD의 Port는- 프로그램들의 버전, 의존성관계, 컴파일하는 방법 등이 기술된 파일/디렉토리를 받아와서 오프라인이더라도 패키지의 검색이 가능하게끔 되어있다. 그래서 주기적으로 이 트리를 갱신해줘야한다. 
# emerge-webrsync

예전에는 rsync 프로토콜을 이용해서 한 5분쯤 걸리는 거 같은게 엄청나게 많은 것들을 보여줬는데, emerge-webrsync는 그냥 대충 간단한 메시지 정도만 보여준다.

이제 프로파일을 선택해야한다.  프로파일이란, 이 시스템이 최종적으로 어떤 상태로 갈 것인지를 정해서 시스템이 해당 목표로 빌드되도록 할 수 있다.  프로파일의 목록을 보자.
# eselect profile list
[1]  default/linux/amd64/13.0 *
[2]  default/linux/amd64/13.0/selinux
[3]  default/linux/amd64/13.0/desktop
[4]  default/linux/amd64/13.0/desktop/gnome
[5]  default/linux/amd64/13.0/desktop/gnome/systemd
[6]  default/linux/amd64/13.0/desktop/kde
[7]  default/linux/amd64/13.0/desktop/kde/systemd
[8]  default/linux/amd64/13.0/developer
[9]  default/linux/amd64/13.0/no-multilib
[10] default/linux/amd64/13.0/x32
[11] hardened/linux/amd64
[12] hardened/linux/amd64/selinux
[13] hardened/linux/amd64/no-multilib
[14] hardened/linux/amd64/no-multilib/selinux
[15] default/linux/uclibc/amd64
[16] hardened/linux/uclibc/amd64
지금은 아무런 프로파일도 선택되어있지 않으므로 1번에 * 표시가 되어있을 거다.  만약 그놈 데스크탑으로 빌드를 하고싶다면 4번이나 5번을 하면 된다.  참고로 systemd는 현재 날짜 기준으로 문제가 많으므로, 4번을 선택하면 된다.

#eselect profile set 4
#eselect profile list

4번에 * 표시가 되어있는 것을 볼 수 있다.

이것만 끝나면 신발끈(Boot Strap)을 묶자. 신발끈을 묶는 과정은 젠투의 패키지 시스템인 Portage와 필수패키지에 해당하는 gcc 등의, 시스템을 빌드할 수 있는 최소한의 패키지 8개로 구성되어있다.
# cd /usr/portage
# scripts/bootstrap.sh

필자의 시스템에서는 대략 1시간 가량 걸렸다. 여기까지가 Stage 1에 해당한다.
신발끈이 안묶어진다고 해서 포기하거나 우울해지지 말자. 사실 신발끈 안묶어지는 발이 많다고 한다. 근데, 사실 신발끈 못묶는다고 해서 그 사람이 나사가 하나 빠졌다던가 소위 말하는 병신은 아니지않나. 안되는 사람도 많으니, 안되는 거 붙잡고 삽질하지 말고 과감하게 Stage 3으로 넘어가시라. 그리고나서 시스템 전체를 다시 통째로 컴파일하면 Stage 1부터 한거랑 똑같이 된다.

참고로, 젠투 설치한다고 컴퓨터 끄지도 못하고 계시는 분들이 많아서 말씀드린다만 설치하다가 밖에 오랫동안 나가봐야할 일이 있으면 끄셔도 된다. 방법을 알려드린다.

먼저 chroot에서 빠져나가야한다.
# exit

다음 설치하다만 파티션들을 언마운트 해야한다.
# umount /mnt/gentoo/proc
# umount /mnt/gentoo

스왑파티션을 off 해준다.
# swapoff /dev/sda4

이제 종료한다.
# halt
또는
# poweroff

그런다음, 나중에 다시 설치할 때는 젠투설치씨디로 부팅을 한뒤, 아래와 같이 한다.
# mount /dev/sda3 /mnt/gentoo
# mount -t proc none /mnt/gentoo/proc
# mount --rbind /sys /mnt/gentoo/sys
# mount --rbind /dev /mnt/gentoo/dev
# swapon /dev/sda4
# chroot /mnt/gentoo /bin/bash
# env-update; source /etc/profile (이거 빼먹으면 안된다)

다음 나머지를 이어서 하시면 되겠다.
Stage 2부터는 다음편에 한다.


블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
남자라면 Stage 1부터라고 말씀하시는데, 뭐 사실 그런 것보다는 원래 젠투를 설치하고 사용하고자하는 목적이 리눅스에 대해서 더 깊이 알려고 하는 것이라고 생각하기 때문에 Stage 1부터 시작한다고 생각한다. Stage 3부터 시작하실 분들은 다른 인터넷 상의 매뉴얼을 참고하시거나 Arch Linux라는 것을 쓰시길 권한다.
 
당연한 얘기지만, 이 설치기는 리눅스를 조금 쓰실 줄 아는 분들 중에서, 막연히 젠투설치가 겁나는 분들을 위해서 작성했다.

먼저, 파티션은 이미 준비가 끝난 상태라고 가정하면서 시작한다.
젠투설치는 인터넷이 되야만 설치가 가능하기 때문에 먼저 랜카드부터 잡아준다.
# net-setup eth0

젠투의 특이한 점은, ssh를 통한 네트워크 설치가 가능하다는 점이다.
# /etc/init.d/sshd start
# passwd

리눅스를 설치할 파티션을 포맷한다. 나는 저널링이 가능한 ext3로 포맷을 했다.
# mkfs.ext4 /dev/sda3

스왑파티션을 쓸 수 있게 만들어준다.
# mkswap /dev/sda4
# swapon /dev/sda4

이제 젠투를 설치할 파티션을 마운트 해보자.
# mount /dev/sda3 /mnt/gentoo

이제 다운받은 stage3 파일을 /mnt/gentoo에다 복사한다. stage1부터 시작할 건데, stage3 파일 밖에 없다.
이건 젠투측에서 stage 1이랑 2를 없애기 위해서 그렇게 하긴 한건데, 사실 stage1부터 시작이 가능하다.
다운받은 파일의 압축을 풀자. http://distfiles.gentoo.org/releases/ 여기 가면 스테이지 파일이 있으니까,
wget으로 받으셔도 된다.
# tar xfj stage3.bz2

Proc와 몇몇 특수 파일시스템을 마운트 한다
# mount -t proc none /mnt/gentoo/proc
# mount --rbind /sys /mnt/gentoo/sys
# mount --rbind /dev /mnt/gentoo/dev

인터넷이 되야하므로 /etc/resolv.conf 파일을 복사한다.
# cp /etc/resolv.conf /mnt/gentoo/etc/

미러를 선택하자.  빠른 미러를 선택하자.
# mirrorselect -s3 -b10 -D -c 'South Korea' -o >> /mnt/gentoo/etc/portage/make.conf

이제 대망의 make.conf 파일을 수정할 차례다. 이게 젠투의 핵심이자, 이것 때문에 젠투를 수십번도 더 설치하게 만드는 장본인이다. 본인은 최적화를 통한 가볍고 빠른 리눅스 설치가 목적이며, 최적화 그거 별로 차이 없네마네 하고 주장하시는 분들의 의견과는 무관하게 내가 하고싶은대로 한다. 최적화라는 것이, 자기 만족이지 않나.
인텔칩셋을 쓰시는 분들은 http://wiki.gentoo.org/wiki/Safe_CFLAGS 여기서 안전한 C Flags를 보시면된다. 
본 파일의 수정은 다음 편부터 한다.


블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,
작년쯤에 젠투를 오래된 노트북에 설치하다가  맛이 가는 바람에 결국은 설치하지 못했었다. 그때 나름대로 장황한 글을 적었었는데 그 마음은 여전히 변함이 없다. 
실은 며칠 전에, 한 4일 간에 걸쳐서 젠투를 설치했었는데 무선랜이 죽어라 안잡히는 것이었다. (인텔 센트리노 5100AGN) irc.hanric.org #gentoo의 badung님의 도움을 받아서 빨리 세팅했지만, 무선랜은 죽어라 안잡혔다. 짜증나서 지워버리고 쿠분투를 깔았는데, 세상에... 너무 예쁜 것이었다.
쓰기 편하고 예쁘긴 한데, 뭔가 좀 낯설긴 했지만 뭐 원래 그런 것이니 써보기로 하자고 마음 먹고서 시작했다. 하루이틀 지나다가, 갑자기 런레벨에 뭔가를 (사실 뭐라고 표현해야할지 잘 모르겠다) 추가해야할 일이 생겨서 나도 모르게 rc-update add xxxxx default를 쳤는데, 당연히 명령어가 없다고 나왔다. 이걸 어떻게 추가해야할까하고 웹서핑을 좀 하다가, 문득 이런 생각이 들었다.
"아~ 젠투가 편하긴 편하구나..." 하는 생각이 드는게 아닌가...

솔직히 말해서 젠투설치는 정말로 쉽다. 우분투나 쿠분투, 기타 등등의 배포판과 비교하면, 그래 좀 어렵긴 하지만 매뉴얼보면서 그대로 따라하면 안될 게 전혀 없다. 나도 2003년도 젠투 처음 쓸 때는 아무 것도 모르고 시작했고 그때 당시도 그냥 매뉴얼 보면서 그대로 했을 뿐이다. 명령어를 치면서 이걸 왜 하는지도 모르고 했던 것이다. 즉, 나도 이 글을 읽는 누군가와 똑같았던 것이었다. 그래서 이것에 대해서 한참을 쓰긴 했다.
(http://jswlinux.tistory.com/entry/젠투리눅스-설치)

같은 유닉스인 맥을 쓰면서도 여전히 리눅스를 갈망하는 것은, 나도 어쩔 수 없는 Linuxer라는 사실을 말해주는 것 같다. 와이프가 자기 노트북을 나한테 양보해주기로 했다. 기종은 Sony Vaio VGN-NS190J.
하드웨어는, 인텔 코어2듀어 2.0GHz에 램4기가, 인텔 GM45 내장 그래픽에 블루레이 드라이브 정도. 게임하기에는 좀 부족하지만, 리눅스를 설치해서 쓰기에는 과분한 사양이다.

먼저 Acronis Disk Suite라는 프로그램으로 윈도우가 설치된 하드를 쪼갰다. 250기가 하드 중에서 리눅스한테는 70기가 정도를 줬다. 젠투리눅스 사이트에 가서 10.0 버젼을 다운받고 씨디로 구웠다.
현재 내 하드디스크 상황은

/dev/sda1 - Sony Recovery partition
/dev/sda2 - Windows 7

위와 같이 나눠져있는 상태이며, /dev/sda2에서 70기가 정도를 잘라낸 뒤,

/dev/sda3 EXT3 Linux partition
/dev/sda4 Linux Swap

정도로 나눌 것이다.

준비물은 젠투설치씨디, Stage 1 파일이 전부다. Stage 1파일은 wget으로 받아오면 되긴한데, 나처럼 깔고지우고 반복을 엄청나게 하시는 분은 따로 갖고계시길 바란다. 그외 젠투를 설치할 컴퓨터의 정확한 하드웨어 스펙.
그거야, 리눅스 쓰시는 분들에게는 기본적인 소양이라고 생각하겠다.

설치는 http://xprogrammer.tistory.com/ 블로그를 약간 참고했으며, 그외 forums.gentoo.org와 www.gentoo.org의 문서들, 그리고 en.gentoo-wiki.com 문서들 위주로 참고했다. 그 이외의 문서들은 사실 거의 도움이 되지 않았다. 결국 젠투사이트에 있는 것들이 진리라는 사실이 입증된거다.

서두 끝.
블로그 이미지

jswlinux

Seowon Jung의 잡동사니 보관소

,