fila sendmail - exibe o número de mensagens por domínio

4

Existe um comando simples para descobrir o número atual de mensagens por domínio na fila do sendmail do linux? O mailq mostra uma lista detalhada, mas não é conveniente para uma rápida visão geral.

Estou usando o Centos e o sendmail.

mailq -v | egrep -v '^-' | get_domains.pl | sort | uniq -c
But the above command output is as following:
1 domain.com>

O comando acima não cumpriu minha exigência, qualquer ajuda a esse respeito, por favor.

Aqui está a saída atualizada:

domain.com> has 5 message(s)
domain.com.pk> has 1 message(s)
abc.com.pk> has 2 message(s)
xyz.coinfo.net.cn> has 1 message(s)
mmm.com> has 1 message(s)
    
por User4283 15.09.2011 / 17:46

3 respostas

2

Bem, se você for usar o perl, também pode ir até o fim.

O seguinte é uma maneira bastante imperfeita de contar o número de mensagens por domínio:

#!/usr/bin/perl

use strict;

my @mailq = 'cat /home/users/rilindo/mailq'; #Had to simulate the output of the mail command here. Change this to the actual mailq path, e.g. /usr/bin/mailq
my %domains = ();

foreach my $m (@mailq) {
    $m =~ s/^\s+//;
    $m =~ s/\s+$//;
    $m =~ s/>//;
    next if $m =~ /Queue/;
    if ($m =~ /\d\d:\d\d:\d\d/) {
        $domains{(split(/@/,$m))[1]}++;
    }
    else {
        $domains{(split(/@/,$m))[1]}++;
    }
}

foreach my $d (keys %domains) {
    print $d . " has $domains{$d} message(s)" . "\n";
}

Essencialmente, enviamos uma saída do comando mailq para uma matriz e iteramos. Para cada registro na matriz, removemos os espaços e as linhas iniciais e finais e, em seguida, dividimos no sinal "@". Em seguida, inserimos o domínio como uma chave (se não existir) e, em seguida, o incrementamos em um hash. Na próxima tentativa, ele simplesmente incrementará o valor se o mesmo domínio for encontrado. A partir daí, passamos pelo hash e depois imprimimos o domínio com o número total de correspondências.

O resultado:

[rilindo@localhost ~]$ ./parsemail.pl 
domain.com has 6 message(s)
domain3.com has 2 message(s)
domain1.com has 2 message(s)

Como eu disse, não é perfeito, mas faz o trabalho. Se nada mais, você terá uma idéia de onde ir a partir daqui.

A propósito, já que parece que você sabe perl, a revisão das estruturas de dados hash do Perl provará ser muito útil:

link

Ou:

link

    
por 18.09.2011 / 21:17
3

Tente isto:

# mailq -v | awk 'BEGIN { FS = "@" } \
!/^[a-zA-Z0-9-]|^[ \t]+(\(|\/|Total requests:)/ { print $2 }' | sort | uniq -c
    
por 18.09.2011 / 19:58
1

"simples" é relativo. A saída do mailq é uma dor real para analisar, mas isso pode ser feito. A saída detalhada mailq típica é algo como:

-Queue ID- --Size-- ----Arrival Time---- -Sender/Recipient-------
637F5CFF9C*    1497 Sat Dec 18 21:40:34  [email protected] 
                                         [email protected]

637F5CFF9d*    1497 Sat Dec 18 21:40:35  [email protected] 
                                         [email protected]

Algumas práticas de hackers criam o que você precisa:

Primeiro, você quer eliminar essa linha superior - é útil para um ser humano, mas não é relevante para nossas metas de análise.   Maneira mais fácil: mailq -v | egrep -v '^-'

Agora você deseja obter as informações do destinatário e extrair o nome do domínio. Perl é seu amigo aqui - canalize a saída através deste script prático (vamos chamá-lo de get_domains.pl ):

#!/usr/bin/perl
$/ = "\n\n";                                    # Use a blank line as the separator.
while (<>) {
        ($x,$recip) = split(/\n/, $_);          # Extract the recipient line
        ($user,$domain) = split(/@/, $recip);   # Get the domain.
        print "$domain\n";                      # Print Recipient Domain
}

Isso deixa a parte fácil - contando os domínios (canalizar sort | uniq -c ).

Então, mailq -v | egrep -v '^-' | get_domains.pl | sort | uniq -c dará a você algo como:

    1 domain.com
    1 domain2.com
    
por 15.09.2011 / 19:56