OGG运维优化脚本(四)-信息修改类--长事务跳过
admin
2023-04-27 00:39:59
0

文件名: skiptrans.sh skip.sh

所在路径:$HOME/ggscript/ggtrandata

功能:该脚本用于重启抽取进程时跳过长事务,可自动识别1小时以上的长事务并批量跳过,skiptrans.sh通过edit脚本选择调用,skip.sh用于在其他脚本中调用用,例如allstop.shgoldengate进程停止脚本

Ps:目前该脚本目前仅适用于AIXLINUX系统 

skiptrans.sh

#!/bin/bash
#时间转换为秒的函数,参考某位大神的脚本
function date2seconds {
    echo "$*" | awk '{
        z=int((14-$2)/12); y=$1+4800-z; m=$2+12*z-3;
        j=int((153*m+2)/5)+$3+y*365+int(y/4)-int(y/100)+int(y/400)-2472633;
        j=j*86400+$4*3600+$5*60+$6
        print j
    }'
}

cd $HOME/ggscript/ggtrandata
echo $login
echo $dir

dir=$PWD 
echo $dir
cd $HOME/ggserver
#输入需要跳过长事务的进程名
echo "searching the Extract name......"
(echo info all;echo exit)|./ggsci|grep "EXTRACT" |awk 'BEGIN {FS=" +"} {print $3}'|grep  '^E'
read -p "Please enter the extract name:" extract

#获取2个线程的showtrans长事务
echo "loading the trans data.....please wait....."
(echo send $extract showtrans thread 1;echo exit)|./ggsci > $dir/thread1
echo "Thread 1 data load compete"
(echo send $extract showtrans thread 2;echo exit)|./ggsci > $dir/thread2
echo "Thread 2 data load compete"


cd $dir

#将长事务信息分割为时间与trans编号两部分
cat thread1|awk 'BEGIN{}{FS=" "} /^XID:/{print $2}'|sed  -e '/^$/d' > xid1
cat thread1|awk -F 'Time:           ' '{print $2}'|sed  -e '/^$/d' > time1
paste time1 xid1 > trandata
cat thread2|awk 'BEGIN{}{FS=" "} /^XID:/{print $2}'|sed  -e '/^$/d' > xid2
cat thread2|awk -F 'Time:           ' '{print $2}'|sed  -e '/^$/d' > time2
paste time2 xid2 > trandata2

cat trandata2 >> trandata



#通过函数转换时间,并排除掉一小时以内的长事务
sydate=`date +"%Y-%m-%d:%H:%M:%S"`
echo $HSYSTIME
date2seconds `echo $sydate | sed 's/-/ /g;s/:/ /g'` > secondssys
HSYSTIME=`cat secondssys`
echo $HSYSTIME
rm -f secondssys
#date2seconds `echo $sydate | sed 's/-/ /g;s/:/ /g'`


NUX=`sed -n '$=' trandata`

i=1
cat /dev/null > trains
while(($i<=$NUX));  do

str=`sed -n "${i}p"  trandata |awk '{print $1}'`
echo $str
date2seconds `echo $str | sed 's/-/ /g;s/:/ /g'` > secondssys
HGTI=`cat secondssys`
rm -f secondssys
echo $HGTI
echo $HSYSTIME
POOR=`expr $HSYSTIME - 3600`
echo $POOR
echo "--------------------"
if [ "$HGTI" -le "$POOR" ]
        then
                sed -n "${i}p"  trandata |awk '{print $2}' >> trains
fi

i=`expr $i + 1`

done
#将一小时以前的长事务组合成skiptrans指令,并通过obey指令批量执行
sed 's/^/send '$extract' skiptrans /' trains > trains1
sed 's/$/ force/' trains1 > skiptrains 

cd $HOME/ggserver

cat $HOME/ggscript/ggtrandata/skiptrains > dirdat/skiptrains

echo   OBEY dirdat/skiptrains |./ggsci


skip.sh

#!/bin/bash
echo $dir
cd $HOME/ggscript/ggtrandata
dir=$PWD
cd $HOME
if [ -f .profile ];then
        . .profile
fi

if [ -f .bash_profile ];then 
        . .bash_profile
fi

cd $dir

function date2seconds {
    echo "$*" | awk '{
        z=int((14-$2)/12); y=$1+4800-z; m=$2+12*z-3;
        j=int((153*m+2)/5)+$3+y*365+int(y/4)-int(y/100)+int(y/400)-2472633;
        j=j*86400+$4*3600+$5*60+$6
        print j
    }'
}


if [ $# -eq 0 ]; then
        echo "skip EXTRACT"
        exit 2
fi

extract=$1

if [ `echo $extract|grep ^E` ];then
         IType=EXTRACT

elif [ `echo $extract|grep ^P` ];then
	echo "only can operate the EXTRACT  process"
	exit 2
elif  [ `echo $extract|grep ^R` ];then
        echo "only can operate the extract process"
        exit 2
else
        echo "only can operate the EXTRACT  process"
        exit 2
fi

val=`echo $extract.PRM|tr A-Z a-z`

cd $HOME/ggserver/dirprm
if [ ! -e $val ]; then
        echo "the EXTRACT is not exist"
        exit 2
fi

cd $dir
echo $login

echo $dir
cd $HOME/ggserver



echo "loading the trans data.....please wait....."
(echo send $extract showtrans thread 1;echo exit)|./ggsci > $dir/thread1
echo "Thread 1 data load compete"
(echo send $extract showtrans thread 2;echo exit)|./ggsci > $dir/thread2
echo "Thread 2 data load compete"


cd $dir


cat thread1|awk 'BEGIN{}{FS=" "} /^XID:/{print $2}'|sed  -e '/^$/d' > xid1
cat thread1|awk -F 'Time:           ' '{print $2}'|sed  -e '/^$/d' > time1
paste time1 xid1 > trandata
cat thread2|awk 'BEGIN{}{FS=" "} /^XID:/{print $2}'|sed  -e '/^$/d' > xid2
cat thread2|awk -F 'Time:           ' '{print $2}'|sed  -e '/^$/d' > time2
paste time2 xid2 > trandata2

cat trandata2 >> trandata

sydate=`date +"%Y-%m-%d:%H:%M:%S"`
echo $HSYSTIME
date2seconds `echo $sydate | sed 's/-/ /g;s/:/ /g'` > secondssys
HSYSTIME=`cat secondssys`
echo $HSYSTIME
rm -f secondssys
#date2seconds `echo $sydate | sed 's/-/ /g;s/:/ /g'`


NUX=`sed -n '$=' trandata`

i=1
cat /dev/null > trains
while(($i<=$NUX));  do

str=`sed -n "${i}p"  trandata |awk '{print $1}'`
echo $str
date2seconds `echo $str | sed 's/-/ /g;s/:/ /g'` > secondssys
HGTI=`cat secondssys`
rm -f secondssys
echo $HGTI
echo $HSYSTIME
POOR=`expr $HSYSTIME - 3600`
echo $POOR
echo "--------------------"
if [ "$HGTI" -le "$POOR" ]
        then
                sed -n "${i}p"  trandata |awk '{print $2}' >> trains
fi

i=`expr $i + 1`

done

sed 's/^/send '$extract' skiptrans /' trains > trains1
sed 's/$/ force/' trains1 > skiptrains 

cd $HOME/ggserver

cat $HOME/ggscript/ggtrandata/skiptrains > dirdat/skiptrains

echo   OBEY dirdat/skiptrains |./ggsci


相关内容

热门资讯

美媒:中美元首会晤或讨论AI护... 据凤凰卫视援引美国媒体报道,美方希望借中美领导人会晤的机会,开启有关人工智能安全与管控的对话,并推动...
卫生间水管布置图尺寸高度 卫生间的水管布置可能比较复杂一些,因为卫生间的管道比较多。比如有热水器的通水管道,有座便器的冲水管道...
电脑尺寸在哪里看 电脑尺寸在哪里看1、可以选择手工测量法来测量电脑尺寸,这时测量一下屏幕对角线,因为显示面积都会小于显...
电脑机箱尺寸标准 常规的机箱一般是立体式,或桌面式,再就是横式。电脑机箱尺寸,目前市面上根据不同的规格有不同的方案。 ...
斯塔默发声:不会辞职 【环球时报驻英国特约记者 纪双城 环球时报特约记者 甄翔 于文】执政党工党在英国地方选举中遭遇“历史...
抽油烟机管道有异味怎么办 抽油烟机是厨房中不可或缺的设备,它能有效地排出油烟,保证室内空气的清新。但是,长时间使用后,抽油烟机...
抽油烟机管道有油垢怎么办 抽油烟机管道是我们家庭生活中必不可少的设备,但长时间的使用会导致管道内部积累大量的油垢,如不及时清理...
沈伯洋与台北市长格局有落差,叶... 海峡导报综合报道 民进党将正式拍板征召民代沈伯洋出战台北市长,并发布采访通知,预计在13日下午举行台...
核查:上世纪已有多款汉坦疫苗上... 明查员 冯梦速览- 人类感染汉坦病毒已有数十年历史。朝鲜战争期间,联合国军就曾有过大规模感染。汉坦病...
如何从“一证在手”走向“一技傍... 教员在给学员讲解理论知识。 学员在进行无人机试飞训...