기본 콘텐츠로 건너뛰기

ProxySQL 에서 Unknown system variable 'query_cache_size' 오류

CentOS 5.1에서 cmake Source RPM으로 설치하기

레드햇에서 바이너리와 레드햇의 일부 프로그램을 공개하지 않겠다고 하여, 공개된 소스만 가지고 컴파일하여 RHEL과 비슷하게 만든 것이 CentOS이다. 또한 RHEL은 안정적인 버전만을 공급하다보니 화려한 최신 버전 패키지를 맛보기 힘들다. CentOS 역시 RHEL과 패키지 현황은 비슷하다.

그렇다... CentOS 5.1에 cmake가 없다. Fedora 8 extra던가? 아무튼 그곳에서 나온 패키지 쓰려고 했더니만 glibc를 업그래이드 하라고 해서 포기하고, rpmfind.net에서 최신 버전 Source RPM을 내려받았다. 일단 설치하고 바이너리 빌드하려고 했는데...
$ rpm -UVh cmake-2.4.8-xxxxx.src.rpm
$ cd /usr/src/redhat/SPECS
$ rpmbuild --target=i686 -bb cmake.spec
목표대상(target) 플랫폼으로 제작 중: i686
i686(을)를 제작하고 있습니다
오류: Failed build dependencies:
xmlrpc-c-devel is needed by cmake-2.4.8-xxxxx.i686


칫, 귀찮게 저런 패키지를 요구하다니! 역시나 rpmfind.net에서 xmlrpc-c 소스 RPM 패키지를 내려 받아 빌드했다.
$ rpm -Uvh xmlrpc-c-1.13.8-xxxxx.src.rpm
$ cd /usr/src/redhat/SPECS
$ rpmbuild --target=i686 -bb xmlrpc-c.spec
목표대상(target) 플랫폼으로 제작 중: i686
i686(을)를 제작하고 있습니다
오류: Failed build dependencies:
cmake is needed by xmlrpc-c-1.13.8-xxxxx.i686


뭐야!? 소스 컴파일마저 서로 의존성이 걸려 있는거야!? 나중에 xmlrpc-c쪽 빌드 시스템을 살짝 까봤는데 cmake를 써서 Makefile을 생성하기 때문에 cmake가 반드시 필요하다. 제길! 그럼 못 쓰는 것인가? 절대로 그렇지 않다!

CMake홈페이지에 가서 Linux용 바이너리를 묶어놓은 압축파일을 다운 받는다. 대충 root의 어디엔가 압축을 풀고 PATH를 맞춰주자.
$ pwd
/root
$ tar -xzf cmake-2.4.8-Linux-i386.tar.gz
$ export PATH=$PATH:~/cmake-2.4.8-Linux-i386


그리고 xmlrpc-c 빌드!! ... 하기 전에 'BuildRequire cmake'를 제거하여 cmake 설치 여부를 제거하고 빌드!!
$ rpmbuild --target=i686 -bb /usr/src/redhat/SPECS/xmlrpc-c.spec
blar blar...

오오~ 성공했어! xmlrpc-c, xmlrpc-c-devel 패키지를 설치하면 cmake 패키지를 빌드할 수 있다.
$ rpm -Uvh /usr/src/redhat/RPMS/i686/xmlrpc-c-devel* /usr/src/redhat/RPMS/i686/xmlrpc-c-1*
$ rpmbuild --target=i686 -bb /usr/src/redhat/SPECS/cmake.spec


마지막으로 예쁘게 포장한 cmake 패키지를 설치해주면 끝~*
$ rpm -Uvh /usr/src/redhat/RPMS/i686/cmake-2*


컴파일이 제일 쉬웠어요~* ㅡ▽-)/ 만세~*


덧글: 다 사용한 cmake-blarblar 디렉토리는 깨끗하게 날리자!

댓글

이 블로그의 인기 게시물

Bash Array, Map 정리

Bash에서 Array, Map에 대한 정리. (매번 찾기 귀찮) 찾아보진 않았지만, Bash에서 Array든 Map이든 동일하게 Map(C++에서 Unordered Map)으로 동작하는 것 같다. 왜냐하면, Array의 Index가 연속하지 않아도 동작한다. 그저 Key가 0 이상의 정수인 Map이랑 비슷하게 동작한다. 예) 1, 2, 3, 9, 10 Array # 생성 declare -a empty_array declare -a ar=(haha hoho baba "long string haha hoho") # 접근 echo "ar[0]=${ar[0]}" echo "all as array=${ar[@]}" # 큰따옴표 안에서 각 원소를 따로따로 전달한다. echo "all as one=${ar[*]}" # 큰따옴표 안에서 각 원소를 문자열 하나로 합쳐 전달한다. echo "indexes=${!ar[@]}" echo "indexes=${!ar[*]}" echo "length=${#ar[@]}" echo "length=${#ar[*]}" echo "last=${ar[-1]}" echo "last=${ar[@]: -1}" # 콜론 뒤에 빈 칸이 꼭 필요하다. 옛 방식 # 현재 상황 declare -p ar #(출력) declare -a ar=([0]="haha" [1]="hoho" [2]="baba" [3]="long string haha hoho") ar[100]=hello # 인덱스를 건너 뛰어도 동작한다. declare -p ar #(출력) declare -a ar=([0]="haha" [1]="hoho" [2]="baba" [3]=&

설치한 패키지에서 RPM 추출하기

오래된 패키지를 관리할 저장소가 없어졌고, 기존 패키지로 다른 서버를 세팅해야할 일이 생겼다면 RPM의 리패키지 기능을 이용해보자. $ rpm -e --repackage [PACKAGE_NAME] 위와 같이 리패키지하면, /var/spool/repackage/ 에 생성한 RPM파일이 있다. :-)