Configuração de Servidor · 13 min read · Dec 24, 2025
O SpamSnake Perfeito - Ubuntu Jeos 10.10 Maverick Meerkat - Página 2
6. Instalar Postfix:
apt-get install postfix postfix-mysql postfix-doc procmailVocê será solicitado a responder a duas perguntas. Responda da seguinte forma:
Tipo geral de configuração de e-mail: –> Internet Site
Nome do servidor de e-mail: –> server1.example.com
Parar o Postfix:
postfix stopVamos editar o Postfix com o seguinte:
vi master.cfPrecisamos adicionar dois itens abaixo do tipo de serviço de coleta. O serviço de coleta “coleta” e-mails locais (local significa “nesta máquina”) e os entrega. Esta é uma maneira de contornar a filtragem de conteúdo para e-mails gerados por esta máquina.
Deve ficar assim quando você terminar:
pickup fifo n - - 60 1 pickup
-o content_filter=
-o receive_override_options=no_header_body_checksEditar main.cf:
vi /usr/src/postfix.sh#!/bin/sh
postconf -e "alias_maps = hash:/etc/aliases"
newaliases
postconf -e "myorigin = domain.tld"
postconf -e "myhostname = server1.domain.tld"
postconf -e "mynetworks = 127.0.0.0/8, 192.168.0.0/24"
postconf -e "message_size_limit = 10485760"
postconf -e "local_transport = error:No local mail delivery"
postconf -e "mydestination = "
postconf -e "local_recipient_maps = "
postconf -e "relay_domains = mysql:/etc/postfix/mysql-relay_domains.cf"
postconf -e "relay_recipient_maps = mysql:/etc/postfix/mysql-relay_recipients.cf"
postconf -e "transport_maps = mysql:/etc/postfix/mysql-transports.cf"
postconf -e "virtual_alias_maps = hash:/etc/postfix/virtual"
postconf -e "disable_vrfy_command = yes"
postconf -e "strict_rfc821_envelopes = no"
postconf -e "smtpd_banner = $myhostname ESMTP SpamSnake"
postconf -e "smtpd_delay_reject = yes"
postconf -e "smtpd_recipient_limit = 100"
postconf -e "smtpd_helo_required = yes"
postconf -e "smtpd_client_restrictions = permit_sasl_authenticated, permit_mynetworks, permit"
postconf -e "smtpd_helo_restrictions = permit_sasl_authenticated, permit_mynetworks, permit"
postconf -e "smtpd_sender_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_non_fqdn_sender, reject_unknown_sender_domain, permit"
postconf -e "smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unknown_recipient_domain, reject_unauth_destination, whitelist_policy, grey_policy, rbl_policy, spf_policy, permit"
postconf -e "smtpd_data_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_pipelining"
postconf -e "smtpd_restriction_classes = spf_policy, rbl_policy, grey_policy, whitelist_policy"
postconf -e "spf_policy = check_policy_service unix:private/policy"
postconf -e "rbl_policy = reject_rbl_client zen.spamhaus.org, reject_rbl_client bl.spamcop.net"
postconf -e "grey_policy = check_policy_service unix:private/greyfix"
postconf -e "whitelist_policy = check_client_access mysql:/etc/postfix/mysql-global_whitelist.cf, check_sender_access mysql:/etc/postfix/mysql-global_whitelist.cf"
postconf -e "header_checks = regexp:/etc/postfix/header_checks"
touch /etc/postfix/virtual
echo "root [email protected]" >> /etc/postfix/virtual && echo "abuse [email protected]" >> /etc/postfix/virtual && echo "postmaster [email protected]" >> /etc/postfix/virtual
postmap /etc/postfix/virtual
touch /etc/postfix/header_checks
echo "/^Received:/ HOLD" >> /etc/postfix/header_checks
postmap /etc/postfix/header_checks
cat > /etc/postfix/mysql-global_whitelist.cf < /etc/postfix/mysql-relay_domains.cf < /etc/postfix/mysql-relay_recipients.cf < /etc/postfix/mysql-transports.cf < Nota: Para esta etapa, certifique-se de substituir [email protected], example.com e @example.com por valores reais que correspondam à sua configuração.
chmod +x /usr/src/postfix.she execute usando
./usr/src/postfix.sh*Nota: O usuário/senha para os arquivos cf precisa ser o mesmo que o usuário/senha que você usará com sua configuração do banco de dados Baruwa mais tarde. Certifique-se de alterar tudo em vermelho antes de executar o script.
Chamada de destinatário do Postfix (Opcional)
Este recurso consulta o servidor do destinatário para verificar se o destinatário existe. Se não, ele responde com um erro 550 ao servidor de envio e encerra a conexão. Se o usuário existir, o SpamSnake continuará processando o e-mail. Este é apenas outro método para evitar backscatter, mas tem um custo. Leia sobre isso em http://www.postfix.org/ADDRESS_VERIFICATION_README.html. Você pode pular este método e usar o método de script (mais adiante neste guia) se decidir que isso sobrecarregará seu servidor.
vi /etc/postfix/main.cfe adicione o seguinte:
verify_recipient = reject_unknown_recipient_domain, reject_unverified_recipient
look_ahead = check_recipient_access hash:/etc/postfix/access
unverified_recipient_reject_code = 550
address_verify_map = btree:/var/lib/postfix/verifyAdicione isso às suas classes de restrição smtpd:
verify_recipient, look_aheadAdicione isso às restrições de destinatário smptd:
smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination, look_ahead, whitelist_policy, grey_policy, rbl_policy, spf_policy, permittouch /etc/postfix/accesse adicione seus domínios:
domainA.com verify_recipient
domainB.com verify_recipient*Nota: Certifique-se de adicionar domínios válidos que você está filtrando.
Postmap:
postmap /etc/postfix/accessUma olhada final na instalação do Postfix:
less /etc/postfix/main.cfVerifique o conteúdo do arquivo em busca de erros e repare se necessário. Inicie o Postfix:
postfix startVerifique se o Postfix responde:
telnet 127.0.0.1 25Você deve ver:
220 [yourFQDNhere] ESMTP Postfix (Ubuntu)7. Instalar MailScanner (Apparmor, Clamav, DCC, Pyzor, Razor e Spamassassin)
cd /usr/src
wget http://http.us.debian.org/debian/pool/main/libt/libtool/libltdl3_1.5.26-4+lenny1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb
dpkg -i libltdl*
apt-get install razor pyzor clamav-daemon libclamav6 apparmorConfiguração do Apparmor para Clamav
Adicione clamav ao grupo www-data para que ele possa acessar o diretório:
usermod -a -G www-data clamavAgora edite o perfil para clamd:
vi /etc/apparmor.d/usr.sbin.clamde adicione a pasta Incoming à lista de pastas
/usr/sbin/clamd {
#clamav
/var/spool/MailScanner/ rw,
/var/spool/MailScanner/incoming/ rw,
}Recarregue o apparmor:
/etc/init.d/apparmor reloadConfiguração DCC 32bit/64bit
Instale o DCC a partir da fonte .deb:
cd /tmp
wget http://ppa.launchpad.net/jonasped/ppa/ubuntu/pool/main/d/dcc/dcc-common_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb && dpkg -i dcc-common_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb
wget http://ppa.launchpad.net/jonasped/ppa/ubuntu/pool/main/d/dcc/dcc-client_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb && dpkg -i dcc-client_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').debTeste nossa instalação com:
cdcc infoVocê deve obter ‘requests ok’ dos servidores.
Configuração do Pyzor
Como o pyzor não funciona muito bem com python2.6, a solução alternativa é adicionar o seguinte à primeira linha de /usr/bin/pyzor para fazê-lo parecer:
#!/usr/bin/python -Wignore::DeprecationWarningAqui fornecemos o endereço IP do servidor Pyzor ao Pyzor. Isso criará o endereço IP do servidor em um arquivo de servidores nele. Em seguida, testará a conexão. Se você estiver atrás de um firewall, abra a porta 24441/udp para dentro e para fora do seu servidor. Enquanto você estiver nisso, também abra 6277/udp para DCC, 2703/tcp para Razor e 783/tcp para SpamAssassin:
mkdir /var/lib/MailScanner
pyzor --homedir=/var/lib/MailScanner discover
pyzor pingConfiguração do Razor
Crie a configuração .razor:
cd && rm /etc/razor/razor-agent.conf
mkdir /var/lib/MailScanner/.razor
razor-admin -home=/var/lib/MailScanner/.razor -create
razor-admin -home=/var/lib/MailScanner/.razor -discover
razor-admin -home=/var/lib/MailScanner/.razor -registervi /var/lib/MailScanner/.razor/razor-agent.confdebuglevel = 0
razorhome = /var/lib/MailScanner/.razor/Instalar dependências:
apt-get install libconvert-tnef-perl libdbd-sqlite3-perl libfilesys-df-perl libmailtools-perl libmime-tools-perl libmime-perl libnet-cidr-perl libsys-syslog-perl libio-stringy-perl libfile-temp-perl libole-storage-lite-perl libarchive-zip-perl libsys-hostname-long-perl libnet-cidr-lite-perl libhtml-parser-perl libdb-file-lock-perl libnet-dns-perl libncurses5-dev libdigest-hmac-perl libdigest-sha1-perl libnet-ip-perl liburi-perl libfile-spec-perl spamassassin libnet-ident-perl libmail-spf-query-perl libmail-dkim-perl dnsutils libio-socket-ssl-perl gdebi-coreBaixar e instalar o MailScanner mais recente:
cd /usr/src && wget http://www.mailscanner.info/files/4/tar/MailScanner-install-4.81.4-1.tar.gz
tar xvfz MailScanner-install-4.81.4-1.tar.gz && cd MailScanner-install-4.81.4
./install.shExecute crontab -e e adicione as seguintes entradas:
37 5 * * * /opt/MailScanner/bin/update_phishing_sites &> /dev/null
07 * * * * /opt/MailScanner/bin/update_bad_phishing_sites &> /dev/null
58 23 * * * /opt/MailScanner/bin/clean.quarantine &> /dev/null
42 * * * * /opt/MailScanner/bin/update_virus_scanners &> /dev/null
3,23,43 * * * * /opt/MailScanner/bin/check_mailscanner &> /dev/null SpamAssassin
Primeiro precisamos desativar o arquivo de configuração padrão do SpamAssassin:
mv /etc/spamassassin/local.cf /etc/spamassassin/local.cf.disabledAgora vamos fazer backup do arquivo de configuração do SpamAssassin no MailScanner e depois editar:
cp /opt/MailScanner/etc/spam.assassin.prefs.conf /opt/MailScanner/etc/spam.assassin.prefs.conf.backSpamAssassin SQL Bayes
Pré-requisitos: Você precisará dos módulos perl-DBI e perl-DBD-MySQL instalados.
Assumptions and Variables:
Nome do Banco de Dados Bayes do SpamAssassin: sa_bayes
Nome de Usuário do Banco de Dados Bayes do SpamAssassin: sa_user
Senha do Banco de Dados Bayes do SpamAssassin: sa_password
Crie o banco de dados MySQL no servidor onde você pretende armazenar as informações bayesianas.
mysql -u root -p
mysql> create database sa_bayes;
mysql> GRANT ALL ON sa_bayes.* TO sa_user@localhost IDENTIFIED BY 'sa_password';
mysql> flush privileges;Importar estrutura do banco de dados:
mysql -u sa_user -p sa_bayes < /usr/share/doc/spamassassin/sql/bayes_mysql.sqlvi /etc/spamassassin/v310.pre para habilitar DCC:
loadplugin Mail::SpamAssassin::Plugin::DCCCrie o seguinte para evitar um erro em um teste lint:
mkdir /var/www/.spamassassinvi /opt/MailScanner/etc/spam.assassin.prefs.confe adicione o seguinte ao topo:
#pyzor
use_pyzor 1
pyzor_options --homedir /var/lib/MailScanner/
#razor
use_razor2 1
razor_config /var/lib/MailScanner/.razor/razor-agent.confCorrija o caminho do DCC:
dcc_path /usr/bin/dccprocAtualize a string do cabeçalho:
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-SpamCheck
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-SpamScore
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-Information
#use_auto_whitelist 0“YOURDOMAIN-COM” deve ser substituído por qualquer que você tenha usado para “%org-name%” no arquivo MailScanner.conf. Deixe o “X-“ no lugar. Este é o mesmo orgname usado no MailScanner.conf acima.
Adicione a string de conexão sql ao final:
bayes_store_module Mail::SpamAssassin::BayesStore::SQL
bayes_sql_dsn DBI:mysql:sa_bayes:localhost
bayes_sql_username sa_user
bayes_sql_password sa_password
bayes_sql_override_username rootvi v310.pree comente domainkeys, uma vez que DKIM o superou:
#loadplugin Mail::SpamAssassin::Plugin::DomainKeysAdicione ao cron:
30 01 * * * /usr/bin/sa-learn --force-expire --sync -p /opt/MailScanner/etc/spam.assassin.prefs.conf Instale pacotes perl ausentes:
perl -MCPAN -e shell
install IP::Country::Fast
install Encode::Detect
install Crypt::OpenSSL::RSADefina permissões para juntar tudo:
chown -R postfix:www-data /var/spool/postfix/hold
chmod -R ug+rwx /var/spool/postfix/holdTeste a configuração:
spamassassin -x -D -p /opt/MailScanner/etc/spam.assassin.prefs.conf --lintVerifique se há linhas como:
debug: bayes: Database connection established
debug: bayes: found bayes db version 3
debug: bayes: Using userid: 2Você deve ver linhas aparecerem com DCC, Pyzor e Razor que dizem carregando plugin e, esperançosamente, nenhum erro.
Configuração do MailScanner
Precisamos criar um diretório para o SpamAssassin no spool e dar permissões ao postfix para ele, se você executar sa-learn –force como root, o banco de dados bayes que é armazenado nesses diretórios mudará para root:root e o spamassassin dará erro ao olhar para o db. Apenas fique de olho no mail.log e você lembrará de mudar as permissões de volta. Também desative as configurações padrão do MailScanner:
mkdir /var/spool/MailScanner/spamassassinFaça backup do seu arquivo MailScanner.conf:
cp /opt/MailScanner/etc/MailScanner.conf /opt/MailScanner/etc/MailScanner.conf.dist
vi /opt/MailScanner/etc/MailScanner.confAltere os seguintes parâmetros no MailScanner.conf com o seguinte script:
vi /usr/src/mailscanner.shchmod +x mailscanner.she execute usando
./usr/src/mailscanner.shsed -i "/^%org-name% =/ c\%org-name% =orgname" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^%org-long-name% =/ c\%org-long-name% = longorgname" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^%web-site% =/ c\%web-site% = www.domain.tld" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Run As User =/ c\Run As User = postfix" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Run As Group =/ c\Run As Group = www-data" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Work Group =/ c\Incoming Work Group = clamav" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Work Permissions =/ c\Incoming Work Permissions = 0640" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Queue Dir =/ c\Incoming Queue Dir = /var/spool/postfix/hold" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Outgoing Queue Dir =/ c\Outgoing Queue Dir = /var/spool/postfix/incoming" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^MTA =/ c\MTA = postfix" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine User =/ c\Quarantine User = root" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Group =/ c\Quarantine Group = www-data" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Permissions =/ c\Quarantine Permissions = 0660" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Whole Message =/ c\Quarantine Whole Message = yes" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Virus Scanners =/ c\Virus Scanners = clamd" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Monitors for ClamAV Updates =/ c\Monitors for ClamAV Updates = /var/lib/clamav/*.cld /var/lib/clamav/*.cvd" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Clamd Socket =/ c\Clamd Socket = /var/run/clamav/clamd.ctl" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Clamd Lock File =/ c\Clamd Lock File = /var/run/clamav/clamd.pid" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Spam Subject Text =/ c\Spam Subject Text = *SPAM*" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Spam Actions =/ c\Spam Actions = deliver store" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^High Scoring Spam Actions =/ c\High Scoring Spam Actions = store delete" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Non Spam Actions =/ c\Non Spam Actions = deliver store" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^SpamAssassin User State Dir =/ c\SpamAssassin User State Dir = /var/spool/MailScanner/spamassassin" /opt/MailScanner/etc/MailScanner.conf *Nota: Certifique-se de alterar os itens em vermelho antes de executar o script.
Script de Inicialização do MailScanner:
vi /etc/init.d/mailscannercom o seguinte e faça um
chmod +x /etc/init.d/mailscanner#! /bin/sh
### BEGIN INIT INFO
# Provides: MailScanner daemon
# Required-Start: $local_fs $remote_fs
# Required-Stop: $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Controls mailscanner instances
# Description: MailScanner is a queue-based spam/virus filter
### END INIT INFO
# Author: Simon Walter <[email protected]>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/usr/sbin:/usr/bin:/bin:/sbin:/opt/MailScanner/bin
DESC="scanner de spam/vírus de e-mail"
NAME=MailScanner
PNAME=mailscanner
DAEMON=/opt/MailScanner/bin/$NAME
STARTAS=MailScanner
SCRIPTNAME=/etc/init.d/$PNAME
CONFFILE=/opt/MailScanner/etc/MailScanner.conf
# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0
run_nice=0
stopped_lockfile=/var/lock/subsys/MailScanner.off
# Read configuration variable file if it is present
[ -r /etc/default/$PNAME ] && . /etc/default/$PNAME
# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions
# sanity check for permissions
fail()
{
echo >&2 "$0: $1"
exit 1
}
check_dir()
{
if [ ! -d $1 ]; then
mkdir -p "$1" || \
fail "directory $1: does not exist and cannot be created"
fi
actual="$(stat -c %U $1)"
if [ "$actual" != "$2" ]; then
chown -R "$2" "$1" || \
fail "directory $1: wrong owner (expected $2 but is $actual)"
fi
actual="$(stat -c %G $1)"
if [ "$actual" != "$3" ]; then
chgrp -R "$3" "$1" || \
fail "directory $1: wrong group (expected $3 but is $actual)"
fi
}
user=$(echo $(awk -F= '/^Run As User/ {print $2; exit}' $CONFFILE))
group=$(echo $(awk -F= '/^Run As Group/ {print $2; exit}' $CONFFILE))
check_dir /var/spool/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/lib/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/run/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/lock/subsys ${user:-root} ${group:-root} #Required to Create Folder
check_dir /var/lock/subsys/MailScanner ${user:-postfix} ${group:-www-data}
#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
start-stop-daemon --start --quiet --startas $STARTAS --name $NAME --test > /dev/null \
|| return 1
start-stop-daemon --start --quiet --nicelevel $run_nice --chuid postfix:www-data --exec $DAEMON --name $NAME -- $DAEMON_ARGS \
|| return 2
# Add code here, if necessary, that waits for the process to be ready
# to handle requests from services started subsequently which depend
# on this one. As a last resort, sleep for some time.
# Set lockfile to inform cronjobs about the running daemon
RETVAL="$?"
if [ $RETVAL -eq 0 ]; then
touch /var/lock/subsys/mailscanner
rm -f $stopped_lockfile
fi
if [ $RETVAL -eq 0 ]; then
echo "MailScanner Iniciado"
fi
}
#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --retry=TERM/30 --name $NAME
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
# Remove lockfile for cronjobs
if [ $RETVAL -eq 0 ]; then
rm -f /var/lock/subsys/mailscanner
touch $stopped_lockfile
fi
if [ $RETVAL -eq 0 ]; then
echo "MailScanner Parado"
fi
}
#
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
start-stop-daemon --stop --signal 1 --quiet --name $NAME
return 0
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Iniciando $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Parando $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
restart|force-reload)
#
# If the "reload" option is implemented then remove the
# 'force-reload' alias
#
log_daemon_msg "Reiniciando $DESC" "$NAME"
do_stop
case "$?" in
0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
*)
echo "Uso: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
exit 3
;;
esac
exit 0Crie links simbólicos para o script do mailscanner funcionar:
chmod 755 /etc/init.d/mailscanner
update-rc.d mailscanner defaults
ln -s /opt/MailScanner/bin/Quick.Peek /usr/sbin/Quick.PeekInicie o sistema:
/etc/init.d/mailscanner start
/etc/init.d/postfix startVerifique seus logs em busca de erros:
tail -f /var/log/mail.logVerifique seu mail.log (tail –f /var/log/mail.log) e você deve ver o seguinte:
Jun 13 12:18:23 hoshi MailScanner[26388]: MailScanner E-Mail Virus Scanner version 4.81.4 starting...Parabéns - você agora tem o MailScanner registrando no MySQL.
Receba novas postagens na sua caixa de entrada
Sem spam. Cancele a assinatura a qualquer momento.