다른 명령
RAC 정지 와 시작
- RAC START 순서도
- 클러스터 현재 상태 조회
# crsctl status res -t [-init]
Name | 설명 |
---|---|
Local Resources | |
ora.DATA.dg | Asm DataGroup Name |
ora.LISTENER.lsnr | 리스너 상태 |
ora.asm |
|
ora.ons |
|
Cluster Resources | |
ora.cssd |
|
ora.diskmon |
|
ora.dsoldb.db | |
ora.evmd |
|
- Oracle Clusterware Components 프로세스 리스트 와 서비스 구성표
Oracle Clusterware Component | Linux/UNIX Process | Windows Processes |
---|---|---|
CRS | crsd.bin (r) | crsd.exe |
CSS | ocssd.bin, cssdmonitor, cssdagent | cssdagent.exe, cssdmonitor.exe ocssd.exe |
CTSS | octssd.bin (r) | octssd.exe |
EVM | evmd.bin, evmlogger.bin | evmd.exe |
GIPC | gipcd.bin | |
GNS | gnsd (r) | gnsd.exe |
Grid Plug and Play | gpnpd.bin | gpnpd.exe |
LOGGER | ologgerd.bin (r) | ologgerd.exe |
Master Diskmon | diskmon.bin | |
mDNS | mdnsd.bin | mDNSResponder.exe |
Oracle agent | oraagent.bin (Oracle Clusterware 12c release 1 (12.1) and later releases | oraagent.exe |
Oracle High Availability Services | ohasd.bin (r) | ohasd.exe |
ONS | ons | ons.exe |
Oracle root agent | orarootagent (r) | orarootagent.exe |
SYSMON | osysmond.bin (r) | osysmond.exe |
RAC 정지
Cluster 전체 정지
- root 유저로 수행
- crsctl 명령어 이용
- RAC 전체 리소스 정지 : DB Instance, Listener ,asm 포함
- 각 노드(node)별로 각각 수행
- 명령어
# crsctl stop has -- single node 일때 # crsctl stop crs -- rac
DB Instance 만 정지
- 클러스터가 시작되어 있는 상태에서 DB Instance만 정지 할경우
- "srvctl" 명령어를 사용하여 DB Instance 정지 시킴 (shutdown immediate 와 동일함)
- root 유저나 oracle 유저로 수행
- 명령어
# srvctl stop database -d DBCAFE_DB
- 확인
# crsctl status res -t
Listener 만 정지
- 클러스터가 시작되어 있는 상태에서 Listener 만 정지
- "srvctl" 명령어 사용
- root 유저나 oracle 유저로 수행
- 명령어
# srvctl stop listener
- 확인
# crsctl status res -t
ASM 정지
srvctl stop asm -node crmnode1 -stopoption IMMEDIATE
RAC 시작
Cluster 전체 시작
- crsctl 명령어 이용 RAC 의 전체 리소스 시작
- DB Instance,Listener,asm 포함
- root 유저로 수행
- 각 노드(node)별로 각각 수행
* 명령어
# crsctl start has
- 클러스터를 시작하면 process 시작되는것을 확인
- 확인
# crsctl status res -t -init -- 또는 # crsctl status resource -t -init
- -> ora.crsd 가 가장 마지막에 시작되는 데몬이기 때문에 crsd 가 정상적으로 online 되면 모두 정상 기동 완료
DB Instance 만 시작
- 클러스터가 시작되어 있는 상태에서 DB Instance 만 기동 할경우
- "srvctl" 명령어를 사용하여 DB Instance 를 시작(startup 과 동일)
- root 유저나 oracle 유저로 수행
- 명령어
# srvctl start database -d DBCAFE_DB
- 확인 - DB Instance 시작후
# crsctl status res -t
Listener 만 시작
- 클러스터가 시작되어 있는 상태에서 Listener 만 정지
- "srvctl" 명령어 사용
- root 유저나 oracle 유저로 수행
- 명령어
# srvctl start listener
- 확인 - 리스너 시작후
# crsctl status res -t
RAC 상태 확인
클러스터 명령어로 상태 확인
- ora.gsd 의 state 가 "online" 이면 정상
- DB 의 상태가 "OPEN" 인지 확인
* 명령어
# crsctl status resource
process 확인
# ps -ef | grep d.bin
운영 DB 정지 후 시작 예시
DB 인스턴스 정지
* 1번 노드(서버1)
$ shutdown immediate
- 2번 노드(서버2)
$ shutdown immediate
클러스터 정지 (root 계정)
- 1번 노드
$ su - # crsctl stop crs # ps -ef| grep d.bin <-- process 확인
- 2번 노드
$ su - # crsctl stop crs # ps -ef| grep d.bin <-- process 확인
ASM은 클러스터가 정지되면 자동 정지
- ASM 은 클러스터가 정지되면 자동으로 stop 되고,클러스터가 시작 되면 자동으로 start 된다.
클러스터 시작 (root 계정)
- 1번 노드 / 2번 노드 각각 실행
$ su - # crsctl start crs # crsctl stat res -t (-init) # ps -ef| grep d.bin <-- process 확인
데이터베이스 시작 (DB 인스턴스 start)
- 1번 노드 / 2번 노드 각각 실행
SQL> startup
----
리스너 시작/종료
노드별 리스너 정지시
- 1번 ,2번 노드 각각 리스너 정지
srvctl stop listener -n DBCAFE_DB1 srvctl stop listener -n DBCAFE_DB2
- 1번 ,2번 노드 각각 리스너 시작
srvctl start listener -n DBCAFE_DB1 srvctl start listener -n DBCAFE_DB2
현재 VIP 확인
# su - grid $ srvctl config nodeapps -a $ ifconfig -a (--> eth0, eth1)
DB 상태 확인
srvctl status database
ASM 확인
ASM 로그인
$ ./oraenv ORACLE_SID = [+ASM] ? orcl
ASM 명령어 실행
$ asmcmd ASMCMD> lsdg (<--- DISK 그룹 정보, candidate 디스크에 대한 정보를 알수 있다) ASMCMD> du * ASMCMD> cd, rm, ls 등의 명령어 사용 가능 $ srvctl stop asm -n node01 $ srvctl stop asm -n node02 $ srvctl stop nodeapps -n node01 $ srvctl stop nodeapps -n node01