XUCSXST ;SFISC/HVB - CROSS-SITE SYSTATs for 486 SITES ;3/21/96 08:54 [ 04/02/2003 8:47 AM ]
;;7.3;TOOLKIT;**1001**;APR 1, 2003
;;7.3;TOOLKIT;**14**;Dec 15, 1995
A Q:'$$CHKF^XUCSUTL S U="^" S:'$D(DT) DT=$$HTFM^XLFDT($H,1)
S XUCSEND=0 D A3^XUCSUTL3 G XIT:XUCSEND
S %ZIS="MQ" D ^%ZIS I POP S POP=0 G XIT
I $D(IO("Q")) D G XIT
. S ZTSAVE("XUCS*")="",ZTRTN="DQ^XUCSXST",ZTDESC="MPM X-SITE SYSTEM STATS",ZTIO=ION
. S %DT="AEFRX",%DT("A")="Queue for what DATE/TIME? ",%DT("B")="NOW",%DT(0)="NOW" D ^%DT K %DT
. I +Y'<0 S ZTDTH=Y D ^%ZTLOAD,HOME^%ZIS
. K IO("Q")
U IO W:$E(IOST)="C" #
DQ ; Dequeue entry point
K ST S X=0 F S X=$O(^XUCS(8987.2,X)) Q:X]"@"!(X="") S NODE=^(X,0) D:$D(^XUCS(8987.2,X))>1
. S FMDT=XUCSBD F S FMDT=$O(^XUCS(8987.2,"C",FMDT)) Q:FMDT="" Q:$D(^(FMDT,X))
. Q:FMDT="" S Y=$O(^XUCS(8987.2,"C",FMDT,X,0))-1
. F S Y=$O(^XUCS(8987.2,X,1,Y)) Q:Y]"@"!(Y="") S FMDT=^(Y,0) Q:FMDT>(XUCSED+.24) D:FMDT>XUCSBD&($D(^(5))>1)
. . I $E($P(FMDT,".",2),1,2)<12,XUCSRT="P" Q
. . I $E($P(FMDT,".",2),1,2)>11,XUCSRT="A" Q
. . S $P(ST(NODE),"^",21)=$P($G(ST(NODE)),"^",21)+$P(FMDT,"^",3)
. . S $P(ST(NODE),"^",22)=$P(ST(NODE),"^",22)+$P(FMDT,"^",5)
. . F I=1:1:17 S $P(ST(NODE),"^",I)=$P(ST(NODE),"^",I)+$P(^XUCS(8987.2,X,1,Y,3,1,0),"^",I)
P S Y=XUCSBD D DD^%DT S BD=Y,Y=XUCSED D DD^%DT S ED=Y D HDR
S (NODE,OSITE)="" F S NODE=$O(ST(NODE)) Q:NODE="" D
. S SITE=$E(NODE,1,3) I SITE'=OSITE S OSITE=SITE D:$Y>(IOSL-11) HFF W !?1,$P($G(^DIC(4,SITE,0)),"^"),!
. S X=ST(NODE),CNT=$P(X,"^"),SET=$P(X,"^",21)
. S STR=$J(NODE,7)_$J($P(X,"^",16)/SET,6,0) ; Node and Commands
. S STR=STR_$J($P(X,"^",7)/SET,5,0) ; Global Gets
. S STR=STR_$J($P(X,"^",5)+$P(X,"^",6)/SET,4,0) ; Sets and Kills
. S STR=STR_$J($P(X,"^",9)/SET,5,0) ; Logical Reads
. S STR=STR_$J($P(X,"^",10)/SET,4,0) ; Logical Writes
. S STR=STR_$J($P(X,"^",2)/SET,4,0) ; Disk Reads
. S STR=STR_$J($P(X,"^",3)/SET,4,0) ; Disk Writes
. S STR=STR_$J($P(X,"^",11)/SET,5,0) ; DDP Requests
. S STR=STR_$J($P(X,"^",12)/SET,5,0) ; RVG Requests
. S STR=STR_$J($P(X,"^",13)/SET,5,0) ; Terminal Characters IN
. S STR=STR_$J($P(X,"^",14)/SET,6,0) ; Terminal Characters OUT
. S STR=STR_$J($P(X,"^",22)/CNT,5,0) ; Average Jobs
. S STR=STR_$J(CNT,4,0) ; Runs
. W STR W:$D(ET) $J(SET/CNT/60,4,0) W ! ; ET/Run
XIT I $E($G(IOST))'="C",'$D(ZTQUEUED) D ^%ZISC
K BD,CNT,CUM,ED,FMDT,GT30,GT30PCT,I,M,NODE,OSITE,PCT,SET,SITE,ST,STR
K SUM,X,XUCSBD,XUCSED,XUCSEND,XUCSRT,Y
Q
HFF W #
HDR W ?2,"MPM X-Site Stats/Sec Report for ",BD," to ",ED," (",$S(XUCSRT="A":"AM)",XUCSRT="P":"PM)",1:"AM&PM)")
W !?2,"Node",?9,"Cmds",?14,"Gets",?19,"S+K",?24,"LRd",?28,"LWt",?32,"DRd",?36,"DWt",?41,"DDP",?46,"RVG",?51,"TTI",?57,"TTO",?61,"Jobs",?68,"N" W:$D(ET) ?71,"ET"
W !?1 F I=1:1:69 W "="
W:$D(ET) "====" W ! Q
XUCSXST ;SFISC/HVB - CROSS-SITE SYSTATs for 486 SITES ;3/21/96 08:54 [ 04/02/2003 8:47 AM ]
+1 ;;7.3;TOOLKIT;**1001**;APR 1, 2003
+2 ;;7.3;TOOLKIT;**14**;Dec 15, 1995
A IF '$$CHKF^XUCSUTL
QUIT
SET U="^"
IF '$DATA(DT)
SET DT=$$HTFM^XLFDT($HOROLOG,1)
+1 SET XUCSEND=0
DO A3^XUCSUTL3
IF XUCSEND
GOTO XIT
+2 SET %ZIS="MQ"
DO ^%ZIS
IF POP
SET POP=0
GOTO XIT
+3 IF $DATA(IO("Q"))
Begin DoDot:1
+4 SET ZTSAVE("XUCS*")=""
SET ZTRTN="DQ^XUCSXST"
SET ZTDESC="MPM X-SITE SYSTEM STATS"
SET ZTIO=ION
+5 SET %DT="AEFRX"
SET %DT("A")="Queue for what DATE/TIME? "
SET %DT("B")="NOW"
SET %DT(0)="NOW"
DO ^%DT
KILL %DT
+6 IF +Y'<0
SET ZTDTH=Y
DO ^%ZTLOAD
DO HOME^%ZIS
+7 KILL IO("Q")
End DoDot:1
GOTO XIT
+8 USE IO
IF $EXTRACT(IOST)="C"
WRITE #
DQ ; Dequeue entry point
+1 KILL ST
SET X=0
FOR
SET X=$ORDER(^XUCS(8987.2,X))
IF X]"@"!(X="")
QUIT
SET NODE=^(X,0)
IF $DATA(^XUCS(8987.2,X))>1
Begin DoDot:1
+2 SET FMDT=XUCSBD
FOR
SET FMDT=$ORDER(^XUCS(8987.2,"C",FMDT))
IF FMDT=""
QUIT
IF $DATA(^(FMDT,X))
QUIT
+3 IF FMDT=""
QUIT
SET Y=$ORDER(^XUCS(8987.2,"C",FMDT,X,0))-1
+4 FOR
SET Y=$ORDER(^XUCS(8987.2,X,1,Y))
IF Y]"@"!(Y="")
QUIT
SET FMDT=^(Y,0)
IF FMDT>(XUCSED+.24)
QUIT
IF FMDT>XUCSBD&($DATA(^(5))>1)
Begin DoDot:2
+5 IF $EXTRACT($PIECE(FMDT,".",2),1,2)<12
IF XUCSRT="P"
QUIT
+6 IF $EXTRACT($PIECE(FMDT,".",2),1,2)>11
IF XUCSRT="A"
QUIT
+7 SET $PIECE(ST(NODE),"^",21)=$PIECE($GET(ST(NODE)),"^",21)+$PIECE(FMDT,"^",3)
+8 SET $PIECE(ST(NODE),"^",22)=$PIECE(ST(NODE),"^",22)+$PIECE(FMDT,"^",5)
+9 FOR I=1:1:17
SET $PIECE(ST(NODE),"^",I)=$PIECE(ST(NODE),"^",I)+$PIECE(^XUCS(8987.2,X,1,Y,3,1,0),"^",I)
End DoDot:2
End DoDot:1
P SET Y=XUCSBD
DO DD^%DT
SET BD=Y
SET Y=XUCSED
DO DD^%DT
SET ED=Y
DO HDR
+1 SET (NODE,OSITE)=""
FOR
SET NODE=$ORDER(ST(NODE))
IF NODE=""
QUIT
Begin DoDot:1
+2 SET SITE=$EXTRACT(NODE,1,3)
IF SITE'=OSITE
SET OSITE=SITE
IF $Y>(IOSL-11)
DO HFF
WRITE !?1,$PIECE($GET(^DIC(4,SITE,0)),"^"),!
+3 SET X=ST(NODE)
SET CNT=$PIECE(X,"^")
SET SET=$PIECE(X,"^",21)
+4 ; Node and Commands
SET STR=$JUSTIFY(NODE,7)_$JUSTIFY($PIECE(X,"^",16)/SET,6,0)
+5 ; Global Gets
SET STR=STR_$JUSTIFY($PIECE(X,"^",7)/SET,5,0)
+6 ; Sets and Kills
SET STR=STR_$JUSTIFY($PIECE(X,"^",5)+$PIECE(X,"^",6)/SET,4,0)
+7 ; Logical Reads
SET STR=STR_$JUSTIFY($PIECE(X,"^",9)/SET,5,0)
+8 ; Logical Writes
SET STR=STR_$JUSTIFY($PIECE(X,"^",10)/SET,4,0)
+9 ; Disk Reads
SET STR=STR_$JUSTIFY($PIECE(X,"^",2)/SET,4,0)
+10 ; Disk Writes
SET STR=STR_$JUSTIFY($PIECE(X,"^",3)/SET,4,0)
+11 ; DDP Requests
SET STR=STR_$JUSTIFY($PIECE(X,"^",11)/SET,5,0)
+12 ; RVG Requests
SET STR=STR_$JUSTIFY($PIECE(X,"^",12)/SET,5,0)
+13 ; Terminal Characters IN
SET STR=STR_$JUSTIFY($PIECE(X,"^",13)/SET,5,0)
+14 ; Terminal Characters OUT
SET STR=STR_$JUSTIFY($PIECE(X,"^",14)/SET,6,0)
+15 ; Average Jobs
SET STR=STR_$JUSTIFY($PIECE(X,"^",22)/CNT,5,0)
+16 ; Runs
SET STR=STR_$JUSTIFY(CNT,4,0)
+17 ; ET/Run
WRITE STR
IF $DATA(ET)
WRITE $JUSTIFY(SET/CNT/60,4,0)
WRITE !
End DoDot:1
XIT IF $EXTRACT($GET(IOST))'="C"
IF '$DATA(ZTQUEUED)
DO ^%ZISC
+1 KILL BD,CNT,CUM,ED,FMDT,GT30,GT30PCT,I,M,NODE,OSITE,PCT,SET,SITE,ST,STR
+2 KILL SUM,X,XUCSBD,XUCSED,XUCSEND,XUCSRT,Y
+3 QUIT
HFF WRITE #
HDR WRITE ?2,"MPM X-Site Stats/Sec Report for ",BD," to ",ED," (",$SELECT(XUCSRT="A":"AM)",XUCSRT="P":"PM)",1:"AM&PM)")
+1 WRITE !?2,"Node",?9,"Cmds",?14,"Gets",?19,"S+K",?24,"LRd",?28,"LWt",?32,"DRd",?36,"DWt",?41,"DDP",?46,"RVG",?51,"TTI",?57,"TTO",?61,"Jobs",?68,"N"
IF $DATA(ET)
WRITE ?71,"ET"
+2 WRITE !?1
FOR I=1:1:69
WRITE "="
+3 IF $DATA(ET)
WRITE "===="
WRITE !
QUIT