♣
题目部分
在Oracle中,Oracle集群(RAC)的时间同步有哪几种方式?
♣
答案部分
从Oracle 11gR2 RAC开始,Oracle集群的时间同步可以采用操作系统的NTP(Network Time Protocol)服务,也可以使用Oracle自带的服务CTSS(Cluster Time Synchronization Service)。在Oracle 11gR2前,集群的时间是由NTP同步的,而在11gR2后,Oracle引入了CTSS组件。如果NTP没有启用,那么Oracle会自动启用自己的ctssd进程来同步集群时间。
当安装程序发现NTP协议处于非活动状态时,安装集群时间同步服务将以活动模式(ACTIVE Mode)自动进行安装并同步所有节点的时间。如果发现配置了NTP,那么以观察者模式(Observer Mode)启动集群时间同步服务CTSS。
在RAC中,集群的时间应该是保持同步的,否则可能导致很多问题,例如:依赖于时间的应用会造成数据的错误,各种日志打印的顺序紊乱,这将会影响问题的诊断,严重的可能会导致集群宕机或者重新启动集群时节点无法加入集群。
NTP和CTSS是可以共存的,且NTP的优先级要高于CTSS,也就是说,如果系统中同时有NTP和CTSS,那么集群的时间是由NTP同步的,而CTSS会处于观察者模式模式,只有当集群关闭所有的NTP服务,CTSS才会处于活动模式。在一个集群中,只要有一个节点的ntp处于活动状态,那么集群的所有节点的CTSS都会处于观察者模式。
需要注意的是,要让CTSS处于活动模式,则不仅要关闭NTP服务(/sbin/service ntpd stop),还要删除/etc/ntp.conf文件(mv /etc/ntp.conf /etc/ntp.conf.bak),否则不能启用CTSS。
可以执行如下命令来关闭NTP服务,启用CTSS同步:
1/sbin/service ntpd stop 2mv /etc/ntp.conf /etc/ntp.conf.bak 3service ntpd status 4chkconfig ntpd off
可以使用如下命令查看CTSS是否处于ACTIVE状态:
1ps -ef|grep ctss 2crsctl stat res -t -init 3crsctl check ctss
也可以查看CTSS进程的日志文件:
1$GRID_HOME/log/$HOSTNAME/ctssd/octssd.log
可以使用如下的命令来校验集群的时间:
1cluvfy comp clocksync -n all -verbose
可以执行如下命令来关闭CTSS服务,开启NTP:
1mv /etc/ntp.conf.bak /etc/ntp.conf 2service ntpd status 3/sbin/service ntpd start 4# chkconfig ntpd off 5ps -ef|grep ntp
可以使用如下的命令来重启CTSS进程:
1crsctl stop res ora.ctssd -init 2crsctl start res ora.ctssd -init
如果在生产系统中碰到集群时间不一致,而且差异比较大的时候,CTSS或NTP服务就不能自动来同步这些时间,则此时需要手动来同步集群的时间。在集群时间差异较大的时候,会在ASM和DB的alert日志中产生了类似如下的告警信息,并生成vktm的trace文件:
1Time drift detected. Please check VKTM trace file for more details.
通过阅读相关的trace文件也可以获取时间的同步信息。