19c grid 설치 Standalone server (Oracle Restart)
이전 포스팅에서 virtual box 에 오라클리눅스 설치를 완료했다.
[virtualbox] 오라클리눅스 설치 oracle-linux 8.4
ASM 은 RAC 에서는 필수이지만 single node DB 에서는 파일시스템에 설치할수도 있다.
싱글노드에서 ASM 을 설치하려면 grid 를 먼저 설치해야한다.
오라클에서 제공하는 설치관련 가이드 문서는 아래 링크에서 확인가능하다.
https://docs.oracle.com/en/database/oracle/oracle-database/19/cwlin/index.html
1-1) hostname 변경
@root
hostname
hostnamectl set-hostname asmtest
vi /etc/hosts
10.0.2.15 asmtest
1-2) SELINUX
vi /etc/selinux/config
SELINUX=disabled
( 중간의 SELINUX=enforcing 를 변경해준다)
- 방화벽
systemctl stop firewalld
reboot
1-3)설치준비
- YUM, RPM
@root
yum install -y oracle-database-preinstall-19c
cd /home/oracle
** 아래 파일들은 미리 준비가 필요하다.
rpm -ivh oracleasm-support-2.1.12-1.el8.x86_64.rpm
rpm -ivh oracleasmlib-2.0.17-1.el8.x86_64.rpm
- OS USER
groupadd asmadmin
groupadd asmdba
groupadd asmoper
usermod -g oinstall -G dba,oper,backupdba,dgdba,kmdba,racdba,asmdba,asmoper oracle
- DIRECTORY
mkdir -p /app/grid
chown -R oracle:oinstall /app
chmod -R 775 /app
@oracle
mv LINUX.X64_193000_grid_home.zip /app/grid
cd /app/grid
unzip LINUX.X64_193000_grid_home.zip
- PROFILE
root, oracle 계정의 .bash_profile
편의상 grid 계정 분리하지 않고 oracle 한 계정으로 간다.
alias 부분은 각자 취향에 맞게 편집하자
===== oracle bash profile =====
export TMP=/tmp
export TMPDIR=$TMP
export ORACLE_HOSTNAME=asmtest
export ORACLE_UNQNAME=orcl
export ORACLE_BASE=/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/19.0.0/db_1
export GRID_HOME=/app/grid
export ORA_INVENTORY=/oraInventory
export ORACLE_SID=orcl
export PATH=/usr/sbin:/usr/local/bin:$PATH
export PATH=$ORACLE_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export CLASSPATH=$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
export CV_ASSUME_DISTID=RHEL7.6
export LANG=C
export LC_ALL=C
alias grid_env='export ORACLE_HOME=$GRID_HOME;export ORACLE_SID=+ASM;export PATH=$GRID_HOME/bin:$PATH'
alias db_env='export ORACLE_HOME=$ORACLE_BASE/product/19.0.0/db_1;export ORACLE_SID=orcl'
alias ss='sqlplus / as sysdba'
alias oh='cd $ORACLE_HOME'
alias gh='cd $GRID_HOME'
===== oracle bash profile =====
===== root bash profile =====
export ORACLE_BASE=/app/oracle
export GRID_HOME=/app/grid
export ORACLE_HOME=$ORACLE_BASE/product/19c/db_1
export PATH=$PATH:$GRID_HOME/bin
===== root bash profile =====
- ASM CONFIG
[root@asmtest oracle]# oracleasm configure -i
Configuring the Oracle ASM library driver.
This will configure the on-boot properties of the Oracle ASM library
driver. The following questions will determine whether the driver is
loaded on boot and what permissions it will have. The current values
will be shown in brackets ('[]'). Hitting <ENTER> without typing an
answer will keep that current value. Ctrl-C will abort.
Default user to own the driver interface []: oracle
Default group to own the driver interface []: asmadmin
Start Oracle ASM library driver on boot (y/n) [n]: y
Scan for Oracle ASM disks on boot (y/n) [y]: y
Writing Oracle ASM library driver configuration: done
[root@asmtest oracle]#
[root@asmtest oracle]# oracleasm init
Creating /dev/oracleasm mount point: /dev/oracleasm
Loading module "oracleasm": oracleasm
Configuring "oracleasm" to use device physical block size
Mounting ASMlib driver filesystem: /dev/oracleasm
[root@asmtest oracle]# oracleasm status
Checking if ASM is loaded: yes
Checking if /dev/oracleasm is mounted: yes
[root@asmtest oracle]# oracleasm configure
ORACLEASM_ENABLED=true
ORACLEASM_UID=oracle
ORACLEASM_GID=asmadmin
ORACLEASM_SCANBOOT=true
ORACLEASM_SCANORDER=""
ORACLEASM_SCANEXCLUDE=""
ORACLEASM_SCAN_DIRECTORIES=""
ORACLEASM_USE_LOGICAL_BLOCK_SIZE="false"
[root@asmtest oracle]#
- FDISK
디스크 추가 전
[root@asmtest dev]# ls /dev/sd*
/dev/sda /dev/sda1 /dev/sda2
ASM 에서 사용할 디스크그룹을 아래와 같이 추가하자
- crs1,2,3 : asm 파일용, 대충 각 1G
- data : database 용, 최소 20G
- reco : recovery 영역, 대충 5G
VM관리자에서 설정 클릭
* 디스크는 online 상에선 추가가 안되고 vm 이 down 된 상태에서 가능하다. 처음부터 준비하면 좋다.
fdisk /dev/sdb
n(new) -> p(primary) -> 1 -> Enter(default) -> Enter(default) -> w(write)
fdisk /dev/sdc
fdisk /dev/sdd
fdisk /dev/sde
fdisk /dev/sdf
디스크 5개를 추가했으니 5개 반복해준다.
다했으면 추가된 디스크로 asmdisk 를 만들자.
oracleasm createdisk CRS1 /dev/sdb1
oracleasm createdisk CRS2 /dev/sdc1
oracleasm createdisk CRS3 /dev/sdd1
oracleasm createdisk DATA /dev/sde1
oracleasm createdisk RECO /dev/sdf1
oracleasm scandisks
oracleasm listdisks
- tmpfs
vi /etc/fstab => 아래 한줄 추가
tmpfs /dev/shm tmpfs size=8g 0 0
df -h
mount -o remount /dev/shm
df -h
cd /app/grid/cv/rpm/
rpm -ivh cvuqdisk-1.0.10-1.rpm
2) grid설치
grid_env => grid 환경으로 변경 alias (path, oracle_sid)
cd /app/grid
./gridSetup.sh
oracle restart 선택
change discovery path 클릭, asm disk 가 있는 경로를 써준다.
설치 도중 root 권한으로 진행이 필요한 부분을 자동으로 실행하기 위해 auto 선택
설치가 원활하려면 최소 메모리 8G 를 되야 한다. 아무리 작아도 4G 보다는 커야 하고 사전체크에서 걸리면 ignore
- DATA, RECO diskgroup 추가
CRS 디스크그룹만 생성하고 grid 설치가 끝났다. 추가로 DATA, RECO 디스크 그룹을 만들자.
[oracle@oraasm grid]$ asmca
하단의 create.. 클릭
디스크그룹 이름을 DATA 로 하고 disk 선택 하고 하단의 Ok.
동일하게 RECO 를 생성하자.
생성이 끝나고 아래 명령어로 확인
crsctl stat res -t
디스크그룹이 잘 생성이 되었다.
이제 여기에 데이터베이스를 생성이 가능한데, 그것은 다음글에서 알아보자.