AIX系统学习之-CRS安装后校验
系统环境:
操作系统:AIX 5.3.8
Oracle: Oracle 10gR2
案例分析:
在构建RAC时,安装完CRS需要做安装后的校验,在执行校验工具cluvfy时出现以下错误:
[root@aix230:/u01/soft/disk1/cluvfy]#crs_stat -t
Name Type Target State Host ------------------------------------------------------------ ora.aix229.gsd application ONLINE ONLINE aix229 ora.aix229.ons application ONLINE ONLINE aix229 ora.aix229.vip application ONLINE ONLINE aix229 ora.aix230.gsd application ONLINE ONLINE aix230 ora.aix230.ons application ONLINE ONLINE aix230 ora.aix230.vip application ONLINE ONLINE aix230
[root@aix230:/u01/soft/disk1]#ls -l
total 56
drwxr-xr-x 7 oracle dba 512 Oct 16 18:42 cluvfy drwxr-xr-x 4 oracle dba 512 Oct 16 13:35 install drwxr-xr-x 2 oracle dba 512 Oct 16 13:35 response drwxr-xr-x 3 oracle dba 512 Oct 16 13:35 rootpre -rwxr-xr-x 1 oracle dba 2602 Aug 20 2005 runInstaller drwxr-xr-x 9 oracle dba 3072 Oct 16 13:35 stage drwxr-xr-x 2 oracle dba 512 Oct 16 13:35 upgrade
[root@aix230:/u01/soft/disk1/cluvfy]#/u01/soft/disk1/cluvfy/runcluvfy.sh -h
The unzip of archive file /u01/soft/disk1/cluvfy/jrepack.zip Failed
查看目录权限:
[root@aix230:/u01/soft/disk1/cluvfy]#ls -ld /u01 drwxr-sr-x 6 oracle dba 512 Oct 16 13:43 /u01 [root@aix230:/u01/soft/disk1/cluvfy]#ls -l total 118384 drwxrwxr-x 3 oracle dba 2048 Oct 16 18:42 bin drwxr-xr-x 5 root system 512 Jul 16 2005 cv -rwxr-xr-x 1 oracle dba 21378978 Aug 20 2005 cvupack.zip drwxrwxr-x 2 root system 512 Aug 16 2005 jlib -rwxrwxrwx 1 oracle dba 39203424 Aug 20 2005 jrepack.zip drwxrwxr-x 10 oracle dba 3072 Oct 16 18:42 lib drwxrwxr-x 2 root system 512 Jul 19 2005 lib32 -rwxr-xr-x 1 oracle dba 3107 Aug 20 2005 runcluvfy.sh
修改可执行脚本权限:
[root@aix230:/u01/soft/disk1/cluvfy]#chmod 777 runcluvfy.sh
仍然失败,看来不是权限的问题:
[root@aix230:/u01/soft/disk1/cluvfy]#./runcluvfy.sh
The unzip of archive file ./jrepack.zip Failed
查看可执行脚本的内容,发现秘密
[root@aix230:/u01/soft/disk1/cluvfy]#cat runcluvfy.sh
#!/bin/sh # # This script sets up the environment for invocation of cluster verification # tool (cluvfy), unpacks the archive (cluvfy.zip) for the verification # framework software, executes the requested verification command, and cleans # up the space occupied by the unpacked verification software. # # Usage: cluvfy.sh <cluvfy command options> TMPDIR=/tmp ECHO=/bin/echo RM=/bin/rm MKDIR=/bin/mkdir case `/bin/uname` in Linux) UNZIP=/usr/bin/unzip DIRNAME=/usr/bin/dirname ;; HP-UX) UNZIP=/usr/bin/unzip DIRNAME=/bin/dirname ;; SunOS) UNZIP=/usr/bin/unzip DIRNAME=/bin/dirname ;; AIX) DIRNAME=/bin/dirname UNZIP=/usr/bin/unzip if [ -f $UNZIP ] then UNZIP=/usr/bin/unzip else UNZIP=/usr/local/bin/unzip fi ;; OSF1) UNZIP=/usr/bin/unzip DIRNAME=/usr/bin/dirname ;; *) $ECHO "ERROR: UnkNown Operating system" exit -1; ;; esac EXEC_DIR=`$DIRNAME $0` CVUZIP_FILE=$EXEC_DIR/cvupack.zip JREZIP_FILE=$EXEC_DIR/jrepack.zip # Setup CV_HOME environment variable for cluvfy # This variable points to the home for cluster verification software. # If not set by the caller of this script, it points (by default) # to temporary directory if [ "X$CV_HOME" = "X" ] then CV_HOME=$TMPDIR/$$ else CV_HOME=$CV_HOME/$$ fi $RM -rf $CV_HOME $MKDIR -p $CV_HOME export CV_HOME # Setup CV_JDKHOME environment variable for cluvfy # This variable points to the java package required by cluster verification # framework # If this varible isn't set by the caller of this script, the jrepack.zip # archive is unpacked in $CV_HOME/jre directory and this directory is set in # CV_JDKHOME if [ "X$CV_JDKHOME" = "X" ] then if [ ! -f $JREZIP_FILE ]; then $ECHO "\"$JREZIP_FILE\" does not exist." $ECHO "ERROR. Either CV_JDKHOME environment variable should be set" $ECHO " or $JREZIP_FILE should exist." exit 1 else $UNZIP -o $JREZIP_FILE -d $CV_HOME/jre >/dev/null 2>&1 EXEC_STATUS=$? if [ $EXEC_STATUS != "0" ]; then $ECHO The unzip of archive file $JREZIP_FILE Failed exit 1 fi CV_JDKHOME=$CV_HOME/jre export CV_JDKHOME fi fi # Setup CV_DESTLOC environment variable for cluvfy # This variable points to a directory on each (remote as well as local) node # that is writable. The cluster verifcation tool will copy the required # software bits (on need basis) to this directory. # If not set by the caller of this script, it points (by default) # to temporary directory if [ "X$CV_DESTLOC" = "X" ] then CV_DESTLOC=$TMPDIR fi export CV_DESTLOC # Unpack the cluster verification software archive on its home $UNZIP -o $CVUZIP_FILE -d $CV_HOME >/dev/null 2>&1 EXEC_STATUS=$? if [ $EXEC_STATUS != "0" ]; then $ECHO The unzip of archive file $CVUZIP_FILE Failed exit 1 fi # Execute the requested cluster verification command ${CV_HOME}/bin/cluvfy "$@" EXEC_STATUS=$? # Cleanup the home for cluster verification software $RM -rf $CV_HOME # Return the status of executed cluster verification command exit $EXEC_STATUS
从以上内容:
AIX) DIRNAME=/bin/dirname UNZIP=/usr/bin/unzip
可以看到,在执行脚本时需要执行“unzip”,执行路径为“/usr/bin/unzip"
查看本机unzip可执行文件位置:
[root@aix230:/u01/soft/disk1/cluvfy]#which unzip
/u01/crs_1/bin/unzip
竟然不在"/usr/bin"下
拷贝unzip到"/usr/bin"下
[root@aix230:/u01/soft/disk1/cluvfy]#cp /u01/crs_1/bin/unzip /usr/bin [root@aix230:/u01/soft/disk1/cluvfy]#which unzip /usr/bin/unzip
然后执行:
[root@aix230:/u01/soft/disk1/cluvfy]#/u01/soft/disk1/cluvfy/runcluvfy.sh -h
USAGE: cluvfy [ -help ] cluvfy stage { -list | -help } cluvfy stage {-pre|-post} <stage-name> <stage-specific options> [-verbose] cluvfy comp { -list | -help } cluvfy comp <component-name> <component-specific options> [-verbose]
@至此,问题得以解决!!!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。