Назад | Перейти на главную страницу

Как мне проверить размер очереди постфиксов?

Какой постфикс эквивалентен sendmail -bp?

Или, меньше набирать:

mailq
qshape active

покажет вам количество писем, отправленных в каждый домен, и как долго они находятся в активной очереди

qshape deferred 

покажет вам то же самое, но для отложенной очереди

postqueue -p

Вот что я использую, взятый из списка рассылки postfix. Я удалил имя автора, на случай, если оно ему здесь не нужно (его можно увидеть в источнике). Он отображает только итоги.

#!/usr/bin/env perl

# postfix queue/s size
# author: 
# source: http://tech.groups.yahoo.com/group/postfix-users/message/255133

use strict;
use warnings;
use Symbol;
sub count {
        my ($dir) = @_;
        my $dh = gensym();
        my $c = 0;
        opendir($dh, $dir) or die "$0: opendir: $dir: $!\n";
        while (my $f = readdir($dh)) {
                if ($f =~ m{^[A-F0-9]{5,}$}) {
                        ++$c;
                } elsif ($f =~ m{^[A-F0-9]$}) {
                        $c += count("$dir/$f");
                }
        }
        closedir($dh) or die "closedir: $dir: $!\n";
        return $c;
}
my $qdir = `postconf -h queue_directory`;
chomp($qdir);
chdir($qdir) or die "$0: chdir: $qdir: $!\n";
printf "Incoming: %d\n", count("incoming");
printf "Active: %d\n", count("active");
printf "Deferred: %d\n", count("deferred");
printf "Bounced: %d\n", count("bounce");
printf "Hold: %d\n", count("hold");
printf "Corrupt: %d\n", count("corrupt");

РЕДАКТИРОВАТЬ: исправлена ​​опечатка в строке 26.

postqueue -p | tail -n 1

Последняя строка в postqueue -p показывает сколько запросов и размер:

-- 317788 Kbytes in 11860 Requests.

[root @ server ~] # время mailq | grep -c '^ [0-9A-Z]'

10

реальный 0m1.333s

пользователь 0m0.003s

sys 0m0.003s

(результат выше указывает на то, что в очереди находится 10 писем)

Если у вас нет qshape вы можете установить его с помощью следующих команд yum:

yum groupinstall perl development
yum install postfix-perl-scripts

qshape выводит информацию о домене очереди Postfix и возрастном распределении. Вы можете прочитать больше об этом здесь:

http://www.postfix.org/QSHAPE_README.html

Пример вывода

% qshape -s hold | head
                         T  5 10 20 40 80 160 320 640 1280 1280+
                 TOTAL 486  0  0  1  0  0   2   4  20   40   419
             yahoo.com  14  0  0  1  0  0   0   0   1    0    12
  extremepricecuts.net  13  0  0  0  0  0   0   0   2    0    11
        ms35.hinet.net  12  0  0  0  0  0   0   0   0    1    11
      winnersdaily.net  12  0  0  0  0  0   0   0   2    0    10
           hotmail.com  11  0  0  0  0  0   0   0   0    1    10
           worldnet.fr   6  0  0  0  0  0   0   0   0    0     6
        ms41.hinet.net   6  0  0  0  0  0   0   0   0    0     6
                osn.de   5  0  0  0  0  0   1   0   0    0     4

Вот пример.

#!/bin/bash

for q in active  bounce  corrupt  defer  deferred  flush  hold  incoming  maildrop  pid  private  public  saved  trace

    do
        count=$(find /var/spool/postfix/$q ! -type d -print | wc -l)
        echo $q $count
    done