The replication source volume script (RepSrc.pre) and the replication destination volume script (RepDst.pre) are prepared for a pre-processing script, and it is stored in the following directory. Customize these scripts according to the processing requirements.
/etc/opt/FJSVswsrp/sh
/etc/opt/FJSVswsrp/logicalNodeName/sh
Replication Source Volume Pre-processing Sample Script (RepSrc.pre)
1: #!/bin/sh 2: 3: # AdvancedCopy Manager 4: # All Rights Reserved, Copyright FUJITSU LIMITED, 2002-2009 5: 6: # 7: # Pre-processing of Replication(Source) processing 8: # 9: # Argument: $1 Device name of Source disk 10: # $2 Mount point of Source disk 11: # 12: # Error number 13: # 2: Argument error 14: # 10: umount error 15: 16: # Argument check 17: case $# in 18: 2) 19: ;; 20: *) 21: exit 2 22: ;; 23: esac 24: 25: device=$1 26: mount_point=$2 27: 28: # Determination postprocessing file name 29: if [ "`echo $device | /usr/bin/grep "/dev/dsk/"`" != "" ] 30: then 31: # /dev/dsk/c?t?d?s? -> c?t?d?s? 32: dev="`echo $device | /usr/bin/sed "s/\/dev\/dsk\///"`" 33: elif [ "`echo $device | /usr/bin/grep "/dev/FJSV"`" != "" ] 34: then 35: # /dev/FJSVmphd/dsk/mplb?s? -> mplb?s? 36: # /dev/FJSVmphd/dsk/mphd?s? -> mphd?s? 37: dev="`echo $device | /usr/bin/cut -d/ -f5`" 38: elif [ "`echo $device | /usr/bin/grep "/dev/sfdsk/"`" != "" ] 39: then 40: if [ "`echo $device | /usr/bin/grep ":"`" != "" ] 41: then 42: # /dev/sfdsk/class/dsk/volume:c?t?d? -> class_volume_c?t?d? 43: dev="`echo $device | /usr/bin/sed "s/\/dev\/sfdsk\///"`" 44: dev="`echo $dev | /usr/bin/sed "s/\/dsk\//_/"`" 45: dev="`echo $dev | /usr/bin/sed "s/:/_/"`" 46: device="`echo $device | /usr/bin/cut -d: -f1`" 47: else 48: # /dev/sfdsk/class/dsk/volume -> _gds_class_volume 49: dev="_gds_`echo $device | /usr/bin/sed "s/\/dev\/sfdsk\///"`" 50: dev="`echo $dev | /usr/bin/sed "s/\/dsk\//_/"`" 51: fi 52: elif [ "`echo $device | /usr/bin/grep "/dev/vx/dsk/"`" != "" ] 53: then 54: # /dev/vx/dsk/volume -> _vx_rootdg_volume 55: # /dev/vx/dsk/disk-group/volume -> _vx_disk-group_volume 56: dev=_vx_"`echo $device | /usr/bin/awk -F\/ '{ if (NF == 6) { print $5"_"$6 } else print "rootdg_"$5 }'`" 57: elif [ "`echo $device | /usr/bin/grep "/dev/vx/dmp/"`" != "" ] 58: then 59: # /dev/vx/dmp/device -> _vx_pv_device 60: dev=_vx_pv_"`echo $device | /usr/bin/cut -d/ -f5`" 61: else 62: exit 0 63: fi 64: post_file="/etc/opt/FJSVswsrp/"$SWSTGNODE"/data/DEFAULT/"$dev".spre" 65: fstype_file="/etc/opt/FJSVswsrp/"$SWSTGNODE"/data/DEFAULT/"$dev".sfstype" 66: 67: err_log_path="/var/opt/FJSVswsrp/"$SWSTGNODE"/log" 68: 69: if [ "$mount_point" != "" ] 70: # When device was mounted 71: # 72: then 73: 74: # When device cannot be unmounted 75: # 76: # if [ "$device" = "/dev/dsk/cXtXdXsX" -o "$device" = "/dev/dsk/cYtYdYsY" ] 77: # then 78: # /usr/sbin/lockfs -w $mount_point > /dev/null 2>&1 79: # echo "lockfs,$mount_point" > $post_file 80: # 81: # When device can be unmounted 82: # 83: # else 84: # 85: /usr/bin/df -ln $mount_point | /usr/bin/cut -f2 -d: | /usr/bin/cut -f2 -d' ' > $fstype_file 86: 87: /usr/sbin/umount $mount_point 2>/dev/null 88: 89: if [ $? != 0 ] 90: then 91: retry_count=3 92: sleep_time=1 93: result_flag=1 94: 95: while [ $retry_count -gt 0 ] 96: do 97: /usr/sbin/umount $mount_point > $err_log_path/$dev.umount 2>&1 98: if [ $? != 0 ] 99: then 100: retry_count=`expr $retry_count - 1` 101: /usr/bin/sleep $sleep_time 102: else 103: /usr/bin/rm -f $err_log_path/$dev.umount 104: result_flag=0 105: break 106: fi 107: done 108: 109: if [ $result_flag != 0 ] 110: then 111: /usr/sbin/fuser -cu $mount_point> $err_log_path/$dev.fuser 2>&1 112: /usr/bin/ps -ef > $err_log_path/$dev.ps 2>&1 113: exit 10 114: fi 115: fi 116: 117: echo "mount,$mount_point" > $post_file 118: 119: # fi 120: 121: # When device was not mounted 122: # 123: else 124: echo "none" > $post_file 125: fi 126: 127: exit 0
Replication Destination Volume Pre-processing Sample Script (RepDst.pre)
1: #!/bin/sh 2: 3: # AdvancedCopy Manager 4: # All Rights Reserved, Copyright FUJITSU LIMITED, 2002-2006 5: 6: # 7: # Pre-processing of Replication(Destination) processing 8: # 9: # Argument: $1 Device name of Destination disk 10: # $2 Mount point of Destination disk 11: # 12: # Error number 13: # 2: Argument error(system error) 14: # 10: umount error 15: 16: # Argument check 17: case $# in 18: 2) 19: ;; 20: *) 21: exit 2 22: ;; 23: esac 24: 25: device=$1 26: mount_point=$2 27: 28: # Determination postprocessing file name 29: if [ "`echo $device | /usr/bin/grep "/dev/dsk/"`" != "" ] 30: then 31: # /dev/dsk/c?t?d?s? -> c?t?d?s? 32: dev="`echo $device | /usr/bin/sed "s/\/dev\/dsk\///"`" 33: elif [ "`echo $device | /usr/bin/grep "/dev/FJSV"`" != "" ] 34: then 35: # /dev/FJSVmphd/dsk/mplb?s? -> mplb?s? 36: # /dev/FJSVmphd/dsk/mphd?s? -> mphd?s? 37: dev="`echo $device | /usr/bin/cut -d/ -f5`" 38: elif [ "`echo $device | /usr/bin/grep "/dev/sfdsk/"`" != "" ] 39: then 40: if [ "`echo $device | /usr/bin/grep ":"`" != "" ] 41: then 42: # /dev/sfdsk/class/dsk/volume:c?t?d? -> class_volume_c?t?d? 43: dev="`echo $device | /usr/bin/sed "s/\/dev\/sfdsk\///"`" 44: dev="`echo $dev | /usr/bin/sed "s/\/dsk\//_/"`" 45: dev="`echo $dev | /usr/bin/sed "s/:/_/"`" 46: device="`echo $device | /usr/bin/cut -d: -f1`" 47: else 48: # /dev/sfdsk/class/dsk/volume -> _gds_class_volume 49: dev="_gds_`echo $device | /usr/bin/sed "s/\/dev\/sfdsk\///"`" 50: dev="`echo $dev | /usr/bin/sed "s/\/dsk\//_/"`" 51: post_file="/etc/opt/FJSVswsrp/"$SWSTGNODE"/data/DEFAULT/"$dev".dpre" 52: fi 53: elif [ "`echo $device | /usr/bin/grep "/dev/vx/dsk/"`" != "" ] 54: then 55: # /dev/vx/dsk/volume -> _vx_rootdg_volume 56: # /dev/vx/dsk/disk-group/volume -> _vx_disk-group_volume 57: dev=_vx_"`echo $device | /usr/bin/awk -F\/ '{ if (NF == 6) { print $5"_"$6 } else print "rootdg_"$5 }'`" 58: elif [ "`echo $device | /usr/bin/grep "/dev/vx/dmp/"`" != "" ] 59: then 60: # /dev/vx/dmp/device -> _vx_pv_device 61: dev=_vx_pv_"`echo $device | /usr/bin/cut -d/ -f5`" 62: else 63: exit 0 64: fi 65: post_file="/etc/opt/FJSVswsrp/"$SWSTGNODE"/data/DEFAULT/"$dev".dpre" 66: 67: err_log_path="/var/opt/FJSVswsrp/"$SWSTGNODE"/log" 68: 69: if [ "$mount_point" != "" ] 70: # When device was mounted 71: # 72: then 73: 74: /usr/sbin/umount $mount_point 2>/dev/null 75: 76: if [ $? != 0 ] 77: then 78: retry_count=3 79: sleep_time=1 80: result_flag=1 81: 82: while [ $retry_count -gt 0 ] 83: do 84: /usr/sbin/umount $mount_point > $err_log_path/$dev.umount 2>&1 85: if [ $? != 0 ] 86: then 87: retry_count=`expr $retry_count - 1` 88: /usr/bin/sleep $sleep_time 89: else 90: /usr/bin/rm -f $err_log_path/$dev.umount 91: result_flag=0 92: break 93: fi 94: done 95: 96: if [ $result_flag != 0 ] 97: then 98: /usr/sbin/fuser -cu $mount_point> $err_log_path/$dev.fuser 2>&1 99: /usr/bin/ps -ef > $err_log_path/$dev.ps 2>&1 100: exit 10 101: fi 102: fi 103: 104: echo "mount,$mount_point" > $post_file 105: 106: # When device was not mounted 107: # 108: else 109: echo "none" > $post_file 110: fi 111: 112: exit 0