How to install Oracle in Ubuntu
This document is how to install Oracle 11g in Ubuntu.
First time, i install 18c XE version Oracle.
But I know that is not support to Ubuntu.
So, you must install 11g XE version oracle in Ubuntu.
This post is to bring korea blog, so you can translate if you want read.
서론
기존의 Redhat 계열의 리눅스 서버 운영체제를 Ubuntu 서버로 운영하기 위해서 여러가지 서비스를 새롭게 설치해야한다. 최근의 오픈소스 프로젝트로 만들어지는 패키지들은 특정 운영체제와 상관없이 대부분의 운영체제의 기본 패키지로 포함이 되어 있거나 새롭게 컴파일해서 설치할 수 있도록 배포하고 있다. Oracle은 오픈소스 프로젝트가 아니다. Oracle Express Edition으로 무료 소프트웨어를 배포하고 있지만 리눅스 환경에서 RPM 패키지 관리툴로 설치할 수 있도록 배포하고 있다. 기존의 Redhat 계열 리눅스 서버에서는 RPM으로 설치가 가능했지만 Ubuntu 서버로 변경하면서 Oracle XE를 설치하는 메뉴얼이 필요해 서 Oracle XE를 Ubuntu에 설치하는 방법에 대해서 소개한다. 설치하는 과정 중에 리눅스 커널 파라미터 설정과 공유메모리 설정 부분을 주의하지 않아 오류는 없지만 설치후 Oracle이 동작하지 않는 문제를 발견했었다. 이 문서에서 이와 같은 문제를 겪을 때 해결할 수 있는 방법을 소개한다.
Ubuntu
최근 국내에서 가장 있기는 리눅스 서버는 Ubuntu라고해도 과언이 아닐 것이라 생각이된다. Ubuntu는 Debian를 기반으로 만들어졌다.
그래서 안정적이고 편리하게 패키지를 관리할 수 있는 장점을 가지고 있다. 무엇보다도 현재 리눅스 커뮤니티 중에서 가장 엑티브하게 활동하는 곳이 Ubuntu이기 때문에 온라인 자료가 많은 것이 최고의 장점이다. Debian은 오픈 소스 프로젝트 가운데 하나로 37,500개의 패키지를 갖춘 저장소를 관리하기 때문에 패키지 사용이 편리하다. Redhat 계열이 yum으로 패키지를 관리할 수 있다면 Debian 계열은 apt-get로 패키지를 관리할 수 있다. Ubuntu는 Desktop 버전 위주로 개발을 진행해왔기 때문에 서버 패키지보다 업데이트 주기가 빠른 편이라 최신 라이브러리들을 사용할 수 있는 장점이 있다. 하지만 너무 빠른 업데이트 주기 때문에 안정성이 낮아질 수 있기 때문에 LTS(Long Term Support) 버전으로 만들어진 서버를 배포하고 있는데 5년동안 지속적인 관리를 보장 받을 수 있다. 현재 가장 안정화된 서버 버전은 12.04LTS이다.
Oralce Express Edition
Oracle XE(Express Edition)는 상용 Oracle의 무료로 사용할 수 있는 Oracle DBMS로 사용 Oracle의 대부분의 기능을 사용할 수 있기 때문에 개발자나 관리자들이 빠르게 개발을 하거나 실험을 위해서 사용할 수 있다. Oracle XE는 무료이지만 오픈소스 프로젝트는 아니다. 이러한 이유로 위에서 말한 오픈소스 패키지 저장소에서 패키지를 관리할 수 없고, Oracle 공식 사이트에서 Linux용 Oracle-XE를 다운 받을 수 있다. Oracle는 Oracle Linux 운영체제를 배포하고 있는데 Oracle Linux는 Redhat 계열이고 이것은 rpm이라는 패키지 관리툴로 패키지를 설치할 수 있다. Oracle은 Oracle XE Linux 버전을 rpm 파일 형태로 배포하고 있다. Oracle XE 10g 버전까지는 32bit를 지원했지만 Oracle은 더이상 Oracle XE 10g를 배포하고 있지 않고, Oracle XE 11g 부터 64bit만 배포하고 있다.
Ubuntu에 Oracle XE 설치
##Ubunut 64Bit 확인
Oracle XE는 11g 버전을 배포하면서 32bit 지원을 중단하고 64bit만 배포하고 있다. (32bit는 Windows용만 지원을 한다.) 다시 말해서 Oracle XE를 설치하기 위해서는 서버 운영체제가 64bit 운영체제야 한다. Ubuntu에서 현재 시스템이 64bit인지를 확인해보자.
1 | uname -i |
결과가 x86_64로 나오면 현재 설치된 운영체제는 64bit이다.
Oralce XE 다운로드
위에서 설명했듯 Oracle XE는 오픈소스가 아니기 때문에 오픈소스 패키지를 관리하는 저장소에서 패키지 관리툴로 설치할 수 없다. Oracle XE는 Oracle 공식 사이트에 RPM 파일 형태로 배포되고 있다. 가장 최신 Oracle XE를 다운 받는다. (Oracle XE를 다운로드하기 위해서는 Oracle 사이트 계정이 필요하다. Oracle 계정으로 로그인 후 다운로드를 할 수 있기 때문에 Curl이나 wget으로 서버에서 바로 다운받을 수 없고 PC에 다운 받아서 서버로 다운 받은 파일을 업로드해야 한다.)
Oracle XE 다운로드 에서 Linux용 64비트를 다운받는다. 현재 배포 버전은 Oracle Database Express Edition 11g Release 2 for Linux x64 이다.
Oracle XE 설치에 필요한 패키지
Ubuntu에서는 .rpm 파일을 사용해서 패키지를 설치할 수 없기 때문에 PRM 파일을 Debian 계열의 패키지 설칠를 위한 .deb 파일로 변경하여 패키지를 설치해야한다.
Ubuntu에 Oracle XE를 설치하기 위해서 필요한 패키지들이 있는데 다음과 같다.
- alien : RPM 패키지를 Debian 패키지로 변환하는 툴
- libaio1 : Linux 커널 AIOAsynchronous I/O 엑세스 라이브러리
- unixodbc : ODBC(Open Database Connectivity) 라이브러리
필요한 패키지를 apt-get 명령어를 이용하여 root 권한으로 설치한다.
1 | sudo apt-get install -y alien libaio1 unixodbc |
RPM 파일을 DEB 파일로 변환
다운받은 .rpm 파일을 Ubuntu에 설치하기 위해서 alien을 사용하여 .deb 파일로 변경한다.
1 | sudo alien --scripts -d oracle-xe-11.2.0-1.0.x86_64.rpm |
위 명령어를 실행하면 한참의 시간이 지난 이후 같은 경로에 oracle-xe_11.2.0-2_amd64.deb파일이 생성된다.
/sbin/chkconfig
Rethat 패키지들은 설치할 때 /sbin/chkconfg를 사용하는데 Ubuntu에는 없기 때문에 이와 동일한 환경을 만들어주기 위해서 아래 내용을 가지고 /bin/chkconfig 파일을 생성한다.
1 | sudo vi /sbin/chkconfig |
1 | #!/bin/bash |
파일 생성 이후 이 파일을 실행할 수 있도록 파일 권한을 755 변경한다.
1 | sudo chmod 755 /sbin/chkconfig |
Kernel 파라미터 설정
Oracle는 서버를 운영하는데 커널파라미터 설정이 필요한데 시스템 컨트롤 데몬에 시스템 파라미터 설정을 저장하여 등록한다. Oralce은 Linux 커널의 파라미터를 사용하여 운영되기 때문이다.
- fs.file-max : 오픈하는 파일의 수를 지정하는 커널 파리미터(각 오라클 인스턴스는
- 512*PROCESSES만큼 file descriptior를 가진다.)
- net.ipv4.iplocalport_range : 이 값은 TCP와 UDP의 트래픽을 위한 범위를 설정하는 커널 파라미터
- kernel.sem : 세마포를 지정하는 커널 파라미터
- kernel.shmmax : 공유 메모리 페이지를 지정하는 커널 파라미터
1 | sudo vi /etc/sysctl.d/60-oracle.conf |
1 | # Oracle 11g XE kernel parameters |
시스템컨트롤러 데몬에 커널파라미터를 설정하였으면 커널 파라미터를 로드한다.
1 | sudo service procps start |
Oracle XE가 사용할 파일 추가
Oracle XE는 /bin/awk를 사용하게 되는데 Ubuntu에는 /usr/bin/awk에 설치되어 있기 때문에 다음과 같이 심볼릭링크를 만들어준다.
1 | sudo ln -s /usr/bin/awk /bin/awk |
Oracle XE는 리스너가 사용할 lock 파일을 만들어준다.
1 | sudo mkdir /var/lock/subsys |
1 | sudo touch /var/lock/subsys/listener |
메모리 설정
Oracle XE를 설치하고 나서 특별한 에러 없이 Oracle 프로세스가 리스너만 시작되고 다른 프로세스가 실행되지 않는 문제를 만날 수 있다. Oralce XE를 설치할 때 정상적으로 설치가 되지 않거나 오류가 발생하게되면 $ORACL_HOME안의 log 디렉토리를 살펴보면 된다. 설치가 정상적으로 되지 않거나, 설치는 되었는데 에러 없이 Oracle이 정상적으로 시작이 되지 않을 경우 로그를 살펴보면ORA-000845:MEMORY_TARGET 에러가 발생하게 되는 경우가 있는데 메모리의 설정이 잘못되거나 사이즈가 부족해서 그런 경우이다. 이런 경우 메모리 설정을 위해서 다음 과정을 진행한다.
먼저 현재 설정되어 있는 shared memeory를 삭제한다.
1 | sudo rm -rf /dev/shm |
새롭게 SHM을 만들어서 마운트를 시킬 수 있게 다시 만든다.
1 | sudo mkdir /dev/shm |
1 | sudo mount -t tmpfs shmfs -o -size=4096m /dev/shm |
shm 설정을 데몬에 등록해서 로드하도록 하기 위해서 다음 내용을 /etc/rc2.d/S01shm_load파일로 등록한다.
1 | sudo vi /etc/rc2.d/S01shm_load |
1 | #!/bin/sh |
1 | sudo chmod 755 /etc/rc2.d/S01shm_load |
Oracle XE 패키지 설치
Oracle XE를 설치하기 위한 Ubuntu의 환경설정은 끝났다. 이제 Oracle XE를 설치하기 위해 .rpm을 .deb 파일로 변환한 패키지를 설치한다.
1 | sudo dpkg --install oracle-xe_11.2.0-2_amd64.deb |
정상적으로 설치가 되면 다음과 같이 Oracle XE가 설치되고 데몬을 자동으로 등록하게 된다.
1 | Selecting previously unselected package oracle-xe. |
설치가 모두 마친 이후 Oracle XE를 사용하기 위해 Oracle 최초 설정을 /etc/init.d/oracle-xe configure로 설정한다.
1 | sudo /etc/init.d/oracle-xe configure |
최초 설정 내용은 다음과 같이 서비스 포트설정과 패스워드 설정이다.
- Specify the HTTP port that will be used for Oracle Application Express [8080]:
- Specify a port that will be used for the database listener [1521]:
- Specify a password to be used for database accounts.
환경변수 설정
Oracle XE 설치가 모두 끝나면 Oracle에 관련된 환경 변수를 추가한다
1 | vi ~/.bashrc |
1 | export ORACLE_HOME=/u01/app/oracle/product/11.2.0/xe |
1 | source ~/.bashrc |
Ubuntu 서버 전체에 사용하는 변수에 등록하고 싶으면 /etc/environment 파일에 위 내용을 추가한다.
상태 확인
설치가 모두 끝나면 정상적으로 운영되고 있는지 다음과 같이 확인한다. Oracle의 네트워크 상태를 확인하기 위해서 리스너가 정상적으로 동작하고 있는지 확인한다.
1 | lsnrctl status |
만약 리스너가 정상적으로 동작하고 있으면 다음과 같은 결과를 출력할 것이다
1 | LSNRCTL for Linux: Version 11.2.0.2.0 - Production on 13-MAR-2015 13:54:41 |
설치한 Oracle에 로그인 해보자. SYS와 SYSTEM 계정의 초기 비밀번호는 설치할 때 입력한 비밀번호를 사용한다.
1 | sqlplus system |
정상적으로 로그인이 되면 다음과 같은 화면이 출력되면서 Oracle에 접속이 된다.
1 | SQL*Plus: Release 11.2.0.2.0 Production on Fri Mar 13 13:59:40 2015 |
Oracle XE 삭제
만약 Oracle XE를 설치하는 도중에 에러가 발생하여 재설치를 해야하는 경우나 완전히 삭제해야하는 경우는 다음과 같이 삭제한다.
Oracle XE 서비스를 정지한다
1
sudo service oracle-xe stop
Oracle XE 패키지를 삭제한다.
1
sudo dpkg --purge oracle-xe
Oracle 디렉토리를 삭제한다
1
sudo rm -rf /u01/app
Oracle XE 데몬을 삭제하고 갱신하다.
1
sudo rm /etc/default/oracle-xe
1 | sudo update-rc.d -f oracle-xe remove |
Ubuntu 설정 파일을 삭제한다.
1
sudo rm /sbin/chkconfig /etc/rc2.d/S01shm_load /etc/sysctl.d/60-oracle.conf
Oracle XE 리눅스 계정을 삭제한다.
1
sudo userdel -r oracle
1 | sudo delgroup dba |
결론
Oracle은 가장 많이 사용하고 있는 RDBMS이다. 프로젝트를 진행할 때 Oracle 기반의 어플리케이션을 개발하기 위해서는 Oracle 서버가 필요한데 개발용 서버에 Oracle을 가볍게 설치하고 운영하기 위해서 Oracle XE를 설치하여 운영할 수 있다. Oracle XE는 Redhat 계열에 설치할 수 있는 RPM 파일 형태로 배포하고 있다. 최근 Ubuntu 리눅스 서버가 패키지 관리의 편리성과 활발한 커뮤니티 활동으로 많은 인기를 얻고 있어 Ubuntu 리눅스를 도입하게 될 때 Oracle XE를 설치기 위해서는 .rpm 파일을 .deb 파일로 변경하여 설치하는 방법이 필요하다. 이때 Redhat 계열에 최적화되어 있는 환경을 Ubuntu에 맞게 rpm에 관련된 파일, 커널 파라미터, 그리고 공유 메모리에 관련되어 설정을 해야한다. 이에 관한 내용을 조사하고 설치시 발생한 문제를 해결했다. 설치 후 에러는 없지만 Oracle이 정상적으로 실행이 되지 않을 때 $ORACLE_HOME/log 디렉토리 안에 있는 로그 파일을 분석하면 이 문서에서 소개하는 내용의 문제로 실행이 되지 않는 경우를 발견했었다. Ubuntu에서 Oracle을 운영할 경우나 새롭게 설치해야하는 경우 이 문서를 참조하면 개발 환경을 구축하는데 도움이 될 수 있을것으로 기대된다.
From source : http://blog.saltfactory.net/install-oracle-xe-on-ubuntu/