Sir.Guil
(usa CentOS)
Enviado em 13/09/2010 - 13:55h
Acho que resolvi o problema de uma forma simples,
se funcionar me avisa que vou publicar este também
________________________________________________________________________
#!/bin/bash
###################################################
# #
# Script para matar conexoes ociosas #
# #
# Nome: LIMPANDO_CONEXAO_ESPECIFICA Versao 0.1 #
# by Guilherme Moura de Souza #
# Colaboradores: agavioli #
# #
# Necessario criar o diretorio /u/log #
# #
# Recomendo rodar atraves do cron do root da #
# seguinte forma: */1 * * * * "caminho do script" #
# #
###################################################
LOG=/u/logs/"LIM_CON-"`date +%m%d`
LIMPANDO_CONEXAO() {
# Digite na frente do "=" o limete de tempo que sera permitido que a
# conexao fique ociosa "EM MINUTOS"
LIMITE=1
#Definindo o PTS/* ou TTY*
PTSocioso=tty7
#Buscando o tempo OCIOSO
Tempocioso=`w -h | grep "$PTSocioso" | tr -s " " | cut -d " " -f5`
#Verificando se alguma conexao esta acima do limite
H1=$(echo $Tempocioso | grep "m")
S=$(echo $Tempocioso | grep "s")
if [ -z $H1 ]; then
if [ -z $S ]; then
M=$(echo $Tempocioso | cut -d ":" -f1)
if [ $M -gt $LIMITE ]; then
skill -kill -v $PTSocioso >> $LOG
fi
fi; else
H2=$(echo $H1 | cut -d ":" -f1)
H3=$(echo $H1 | cut -d ":" -f2 | cut -d "m" -f1)
H=`awk 'BEGIN {print '$H2'*60+'$H3'}'`
if [ $H -gt $LIMITE ]; then
skill -kill -v $PTSocioso >> $LOG
fi
fi
}
# Iniciando Rotina e gerando LOGS
echo " ==================================== " >> $LOG
echo " Inicio da Varredura as "`date +%H:%M:%S` >> $LOG
LIMPANDO_CONEXAO
echo " Fim da Varredura as "`date +%H:%M:%S` >> $LOG