Servidor Postfix Total

Neste artigo aprenderemos a configurar um servidor de e-mail completo com Postfix, Courier-IMAP, MySQL, Amavis_new, antivírus McAfee Uvscan, antispam SpamAssassin, POP-BEFORE-SMTP, PostfixAdmin e SquirrelWebmail.

[ Hits: 374.725 ]

Por: Kleber em 26/07/2004


Instalação do Postfix



Vale à pena lembrar que o MySQL precisa estar instalado, com suas libs completas.

A primeira coisa que vamos fazer é aplicar o patch para o Postfix pra gerenciar as quotas, faça o seguinte:

Descompacte o source em um diretório de sua preferência (eu uso o /opt/sources):

# cd /opt/sources
# tar -xvzf postfix-2.1.0.tar.gz


Descompacte o arquivo dentro do diretório do Postfix

# cd postfix-2.1.0
# tar -xvzf postfix-2.1.0.patch.gz


Após terminar aplique o patch assim:

# patch -p0 < postfix-2.1.0.patch

Agora vamos para a instalação do Postfix:

Crie um usuário chamado postfix e um grupo chamado postdrop.

# groupadd -g 1010 postdrop
# useradd -s /bin/false -d /var/server/postfix -u 1010 -g postdrop postfix


Crie o diretório /var/server/postfix, você pode usar qualquer diretório para armazenar os Maildirs.

# mkdir -p /var/server/postfix
# chown postfix.postdrop -R /var/server/postfix


Renomeie o binário do sendmail para sendmail.old:

# mv /usr/sbin/sendmail /usr/sbin/sendmail.old

Se seu sistema possui um link simbólico em/usr/lib:

# mv /usr/lib/sendmail /usr/lib/sendmail.old

Após terminar entre no diretório que foi criado, e digite o seguinte comando.

# cd postfix-2.1.0
# make -f Makefile.init makefiles 'CCARGS=-DHAS_MYSQL -I/usr/include/mysql' 'AUXLIBS=/usr/lib/mysql -lmysqlclient -lz -lm -L/usr/lib'


OBS: isso é uma linha única. Outra coisa é que a minha instalação do mysql esta sob o /usr, se você instalou o mysql no /usr/local, altere os paths corretamente com sua instalação.

Depois de terminado rode o comando make, se você já possui uma instalação do Postfix rode o make update, se não rode o make install.

# make update
ou
# make install

A instalação te fará algumas perguntas, como localização de algumas pastas, responda todas as perguntas para a instalação ser finalizada.

Vamos verificar se o Postfix foi compilado pra usar o MYSQL, faça o seguinte:

# postconf -m
static
cidr
pcre
nis
regexp
environ
mysql
proxy
btree
unix
hash

Se tem o mysql listado, está tudo correto.

Crie arquivos com os seguintes nomes dentro de /etc/postfix:

mysql_virtual_alias_maps.cf

# Insira dentro do arquivo o que está abaixo
user = postfix
password= senha
dbname = postfix
table = alias
select_field = goto
where_field = address
hosts = localhost

mysql_virtual_mailbox_limit_maps.cf

# Insira dentro do arquivo o que está abaixo

user = postfix
password = senha
dbname = postfix
table = mailbox
select_field = quota
where_field = username
hosts = localhost

mysql_virtual_mailbox_maps.cf

# Insira dentro do arquivo o que está abaixo

user = postfix
password= senha
dbname = postfix
table = mailbox
select_field = maildir
where_field = username
hosts = localhost

Depois destes arquivos prontos, vamos criar nosso script para criação de usuários e tabelas do MYSQL. Lembram-se quando eu falei que iria usar as tabelas e usuários do postfixadmin? As tabelas que seguem nesse script são do postfixadmin, personalize se você deseja isso. Olhe no script e onde você encontrar password("postfix") ou password("postfixadmin"), altere para sua senha, ex.: password("sua senha"). Salve esse arquivo com um nome que você desejar, ex.: postfix.db. Esse script esta dentro da pasta do postfixadmin, caso queira aproveitá-lo.

DICA: O mysql por padrão vem com a senha em branco para o usuário root, se você não alterou essa senha, altere agora, rode o comando da seguinte forma:

# mysqladmin -u root -p password "sua senha"

Ele vai pedir uma senha, não digite nada apenas dê enter, após isso ter sido feito, para entrar no mysql agora como root será necessário você digitar sua senha, entre no mysql da seguinte forma:

# mysql -p

Quando for solicitado a senha digite sua senha.

Agora vamos criar nossas tabelas e usuários no MYSQL.

# mysql -p < postfix.db
Enter password:
Em enter password digite a senha do root que você alterou.

Script mysql com usuários e tabelas.

USE mysql;
# Postfix user & password
INSERT INTO user (Host, User, Password) VALUES ('localhost','postfix',password('sua senha'));
INSERT INTO db (Host, Db, User, Select_priv) VALUES ('localhost','postfix','postfix','Y');
# Postfix Admin user & password
INSERT INTO user (Host, User, Password) VALUES ('localhost','postfixadmin',password('sua senha'));
INSERT INTO db (Host, Db, User, Select_priv, Insert_priv, Update_priv, Delete_priv) VALUES ('localhost', 'postfix', 'postfixadmin', 'Y', 'Y', 'Y', 'Y');
FLUSH PRIVILEGES;
GRANT USAGE ON postfix.* TO postfix@localhost;
GRANT SELECT, INSERT, DELETE, UPDATE ON postfix.* TO postfix@localhost;
GRANT USAGE ON postfix.* TO postfixadmin@localhost;
GRANT SELECT, INSERT, DELETE, UPDATE ON postfix.* TO postfixadmin@localhost;
CREATE DATABASE postfix;
USE postfix;
#
# Table structure for table admin
#
CREATE TABLE admin (
username varchar(255) NOT NULL default '',
password varchar(255) NOT NULL default '',
created datetime NOT NULL default '0000-00-00 00:00:00',
modified datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
PRIMARY KEY (username),
KEY username (username)
) TYPE=MyISAM COMMENT='Postfix Admin - Virtual Admins';

#
# Table structure for table alias
#
CREATE TABLE alias (
address varchar(255) NOT NULL default '',
goto text NOT NULL,
domain varchar(255) NOT NULL default '',
created datetime NOT NULL default '0000-00-00 00:00:00',
modified datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
PRIMARY KEY (address),
KEY address (address)
) TYPE=MyISAM COMMENT='Postfix Admin - Virtual Aliases';

#
# Table structure for table domain
#
CREATE TABLE domain (
domain varchar(255) NOT NULL default '',
description varchar(255) NOT NULL default '',
aliases int(10) NOT NULL default '-1',
mailboxes int(10) NOT NULL default '-1',
maxquota int(10) NOT NULL default '-1',

created datetime NOT NULL default '0000-00-00 00:00:00',
modified datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
PRIMARY KEY (domain),
KEY domain (domain)
) TYPE=MyISAM COMMENT='Postfix Admin - Virtual Domains';

#
# Table structure for table domain_admins
#
CREATE TABLE domain_admins (
username varchar(255) NOT NULL default '',
domain varchar(255) NOT NULL default '',
created datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
KEY username (username)
) TYPE=MyISAM COMMENT='Postfix Admin - Domain Admins';

#
# Table structure for table log
#
CREATE TABLE log (
timestamp datetime NOT NULL default '0000-00-00 00:00:00',
username varchar(255) NOT NULL default '',
domain varchar(255) NOT NULL default '',
action varchar(255) NOT NULL default '',
data varchar(255) NOT NULL default '',
KEY timestamp (timestamp)
) TYPE=MyISAM COMMENT='Postfix Admin - Log';

#
# Table structure for table mailbox
#
CREATE TABLE mailbox (
username varchar(255) NOT NULL default '',
password varchar(255) NOT NULL default '',
name varchar(255) NOT NULL default '',
maildir varchar(255) NOT NULL default '',
quota int(10) NOT NULL default '-1',
domain varchar(255) NOT NULL default '',
created datetime NOT NULL default '0000-00-00 00:00:00',
modified datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
PRIMARY KEY (username),
KEY username (username)
) TYPE=MyISAM COMMENT='Postfix Admin - Virtual Mailboxes';

#
# Table structure for table vacation
#
CREATE TABLE vacation (
email varchar(255) NOT NULL default '',
subject varchar(255) NOT NULL default '',
body text NOT NULL,
cache text NOT NULL,
domain varchar(255) NOT NULL default '',
created datetime NOT NULL default '0000-00-00 00:00:00',
active tinyint(4) NOT NULL default '1',
PRIMARY KEY (email),
KEY email (email)
) TYPE=MyISAM COMMENT='Postfix Admin - Virtual Vacation';

Por enquanto não iremos configurar os arquivos principais do Postfix, são eles: main.cf e master.cf. Iremos instalar agora o POP-BEFORE-SMTP.

Página anterior     Próxima página

Páginas do artigo
   1. Introdução
   2. Softwares necessários
   3. Instalação do Postfix
   4. Instalação do POP-BEFORE-SMTP
   5. Instalação e configuração do Courier-IMAP
   6. Instalação e configuração do Amavis_new
   7. Configuração do main.cf e master.cf
   8. Instalação e configuração do PostfixAdmin
   9. Instalação e configuração do SquirrelWebmail
   10. Testando o sistema
   11. Fontes de pesquisa
   12. Sobre o autor
Outros artigos deste autor
Nenhum artigo encontrado.
Leitura recomendada

Debian + Postfix + MySQL + PostfixAdmin + MailScanner + Webmail + Quotas

Exim4 com MailScanner + Clamav

Instalando o Qmail no RedHat 9

Gerando estatísticas do seu servidor de email utilizando o isoqlog

Instalando o servidor de mensagens Postfix no Slackware 10.1

  
Comentários
[1] Comentário enviado por nunix79 em 26/07/2004 - 19:26h

Artigo excelente meus parabéns, é de grande valia.

Fabio Nunes

[2] Comentário enviado por wconserta em 26/07/2004 - 20:35h

Nota 10 pelo artigo , e notei que vc mesmo tendo usado o shack procurou deixar o artigo de modo que todos possam usar independente de distro, vou procura estudar seu artigo mais o do Maximo para fazer meu server de e-mail

Parabens

[3] Comentário enviado por y2h4ck em 26/07/2004 - 22:36h

O artigo ta massa ... so faltou falar do SpamAssassin

[4] Comentário enviado por gustavo_marcon em 27/07/2004 - 08:59h

Também achei ótimo o artigo, mas concordo que faltou falar + do SpamAssassin.... Estou precisando montar um "servidor de email remoto" para pegar emails de contas de servidores como Bol. BrTurbo, etc e passar um antispam do porte do Spam Assassin. Entrei no artigo só para ler a respeito dele, mas como falei ele está falho neste ponto. No mais o artigo está ótimo e veio complementar outros já existentes deixando assim nosso site ainda mais completo nesse aspecto.

Falow galera! Quem tiver dicas sobre Fetchmail + SpamAssassin porfavor me mandem!!!!!

[5] Comentário enviado por klinux em 27/07/2004 - 09:08h

Obrigado pelos comentários,
Vou atualizar o doc em breve, falando mais sobre spamassassin e greylist.
Obrigado mesmo :) é assim que a comunidade cresce :)

[6] Comentário enviado por gustavo_marcon em 27/07/2004 - 09:14h

Blz é assim que a coisa anda. Obrigadão mesmo, tô precisando mesmo do SpamAssassin. Falow galera!

[7] Comentário enviado por jeffestanislau em 27/07/2004 - 14:23h

Muito bom mesmo o artigo... Parabéns... e os acrescimos futuros serão de grande valia!!!
Novamente, parabéns klinux!!!

[8] Comentário enviado por guifreitas em 27/07/2004 - 17:06h

Jul 27 17:05:13 catatau postfix/trivial-rewrite[21635]: fatal: open dictionary: need "type:name" form instead of: "virtual"
Jul 27 17:05:14 catatau postfix/master[20202]: warning: process /usr/lib/postfix/trivial-rewrite pid 21635 exit status 1
Jul 27 17:05:14 catatau postfix/master[20202]: warning: /usr/lib/postfix/trivial-rewrite: bad command startup -- throttling

transport_maps = virtual

virtual o que?

[9] Comentário enviado por klinux em 27/07/2004 - 17:18h

Me desculpe, tem que fazer uma inclusao na tabela domain, incluindo o campo transport, irei coloar as informacoes no doc original!

[10] Comentário enviado por klinux em 27/07/2004 - 17:51h

Caro guifreitas, realmente foi um descuido meu, olhe em http://200.96.158.74/postfix_tutorial.htm
la adicionei o que e necessário para funcionar, qualquer coisa entre em contato, obrigado.

[11] Comentário enviado por guifreitas em 27/07/2004 - 17:57h

valeu klinux
e parabéns pelo doc, muito fera!
ps.: esta rodando em debian!

[12] Comentário enviado por y2h4ck em 02/08/2004 - 10:04h

Aug 2 07:05:31 beowulf postfix/cleanup[3078]: fatal: /etc/postfix/mysql_virtual_alias_maps.cf: mysql options file does not include table name

to tendo esse problema ... mas veja o meu arquivo

[root@beowulf /]# cat /etc/postfix/mysql_virtual_mailbox_limit_maps.cf
user=post
password=******
dbname=postfix
table=mailbox
select_field=quota
where_field=username
hosts=localhost

[root@beowulf /]#

alguem sabe oq ta pegando ... ele gera esse log de erro toda vez que eu restarto o postfix ...
e ele nao esta enviando emails ...
fica tudo amontoado ...
mailq mostra que nao foram enviados ...

alguem sabe como arrumar ?

[13] Comentário enviado por eduardort em 13/08/2004 - 17:29h

Quando vou rodar o script de criação das tabelas do bando de dados, está me voltando a seguinte mensagem:

bash-2.05b# mysql -p < postfix.db
Enter password:
ERROR 1062 at line 4: Duplicate entry 'localhost-postfix' for key 1

Detalhe importante, eu estou usando Freebsd 4.9

Valeu

[14] Comentário enviado por trgtecno em 05/11/2004 - 18:43h

você é um cara paciente e dedicado. Parabéns.

[15] Comentário enviado por lamba0 em 09/12/2004 - 20:02h

esta me dando esse erro na hora do make install...
gcc -Wmissing-prototypes -Wformat -DHAS_MYSQL -I/usr/bin/mysql -g -O -I. -I../../include -DLINUX2 -c dict_mysql.c
dict_mysql.c:118: mysql.h: No such file or directory
make: *** [dict_mysql.o] Error 1
make: *** [update] Error 1
o mysql foi instalado com o apt-get do debian... saberia me dizer o que preciso mudar na hora do "make -f" ? pois coloquei /usr/bin e não deu certo...
Valew

[16] Comentário enviado por martinws em 03/01/2005 - 08:52h

Para min esta dando o mesmo erro acima, mais na hora do
# make

eu uso slackware linux 10.0
alguem saberia me dizer onde eu baixo as lib necessarias para a distro slack 10 ?

Muito obrigado

[17] Comentário enviado por paulsantos em 17/03/2005 - 19:14h

Estou com este erro. Alguém poderia me ajudar? Uso o fedora core2

gcc -Wmissing-prototypes -Wformat -DHAS_MYSQL -I/usr/include/mysql -g -O -I. -I../../include -DLINUX2 -o master master.o master_conf.o master_ent.o master_sig.o master_avail.o master_spawn.o master_service.o master_status.o master_listen.o master_vars.o master_wakeup.o master_flow.o ../../lib/libglobal.a ../../lib/libutil.a /usr/lib/mysql -lmysqlclient -lz -lm -L/usr/lib -ldb -lnsl -lresolv
/usr/lib/mysql: file not recognized: à um diretório
collect2: ld returned 1 exit status
make: ** [master] Erro 1
make: ** [update] Erro 1

[18] Comentário enviado por ximenes10 em 21/03/2005 - 11:37h

o meu esta dando o meso erro :
______________________________________
dict_mysql.c: At top level:
dict_mysql.c:730: error: parse error before '*' token
dict_mysql.c:731: warning: `plmysql_dealloc' was used with no prototype before its definition
dict_mysql.c: In function `plmysql_dealloc':
dict_mysql.c:734: error: `PLDB' undeclared (first use in this function)
make: *** [dict_mysql.o] Error 1
make: *** [update] Error 1
root@canoa:~/programas/postfix-2.2.1#
_______________________________________
Qual e o problema? Sou Slack 10.1

[19] Comentário enviado por tardego em 05/08/2006 - 06:33h

que erro é este? eu uso o conectiva 10

make -f Makefile.in MAKELEVEL= Makefiles
(echo "# Do not edit -- this file documents how Postfix was built for your machi
ne."; /bin/sh makedefs) >makedefs.tmp
No <db.h> include file found.
Install the appropriate db*-devel package first.
See the RELEASE_NOTES file for more information.
make: ** [Makefiles] Erro 1
make: ** [makefiles] Erro 2

[20] Comentário enviado por vinicius.almeida em 25/08/2006 - 10:29h

Tenho este servidor de email aqui na empresa como teste gostaria de colocar um bloqueio de anexos (exe,dll,bat) como faria isso, alguem poderia me passar um tutorial passo a passo..

[21] Comentário enviado por removido em 18/10/2006 - 19:26h

aqui deu o mesmo erro do paulsantos e eu resolvi modificando a linha de comando ^^

ficou assim:
make -f Makefile.init makefiles 'CCARGS=-DHAS_MYSQL -I/usr/include/mysql' 'AUXLIBS=/usr/lib/mysql/libmysqlclient.so -lz -lm -L/usr/lib'

[22] Comentário enviado por luizfernando_f em 17/03/2007 - 09:35h

Excelente artigo,

Obrigado pela dica..........vou fazer isto que você diz no seu artigo.......tomara que resolva la.....vlw.......Parabéns pelo artigo

[23] Comentário enviado por jonathanrock em 15/04/2007 - 20:38h

Está dando alguns erros pode ajudar ?

[24] Comentário enviado por andrentfs em 05/05/2007 - 23:11h

Desenvolvi um script para configurar o servidor postfix e disponibilizei no meu site, só que faltam alguns ajustes, conto com a ajuda de todos, o script faz toda a instalação do servidor, só que faltam algumas coisas, preciso da colaboração de todos, meu site é www.andreluiz.eti.br/index.php, espero que me ajudem a concluir esta tarefa, desde já muito obrigado.

Sejá forte, use software livre.

[25] Comentário enviado por gzanatta00 em 05/06/2007 - 08:13h

amigo estou com um problema q ja me atormenta
a muito tempo, meu servidor de e-mail envia e recebe
e-mails por um unico ip ex: 200.180....3,
que esta configurado dentro do bind ex:
pop3 IN A 200.180....3
smtp IN A 200.180....3
mail IN A 200.180.....3
E DENTRO DOs .cf que esta no diretorio
/etc/postfix, ..... entao eu pensei o seguinte
fazer com que o servidor enviasse e-mails pelo ip
200.180....4, e recebesse pelo ip 200.180...3
pq estou caindo quase todos os dias nas listas negras
e ja me cansei se ficar liberando e tal....
so que nao sei qual os arquivos q tenho q mudar...
ou se existe outra forma de acabar com isso

me de uma ajuda ai..

[26] Comentário enviado por linhocbj em 06/12/2007 - 16:22h

Ola pessoal.

Cara , seu artigo esta show.. fui fazendo direitinho, mas dai Parei no mesmo lugar que o amigo guifreitas ..

"""fatal: open dictionary: need "type:name" form instead of: "virtual"
No link que vc passou para elem, naum esta mais disponivel... alguem me ajude por favor.

Grato..

[27] Comentário enviado por rodrigosalmeida em 07/01/2008 - 00:49h

Boa... esse artigo está muito bem explicado...muito didático...Parabens...

[28] Comentário enviado por tecnoplace em 16/02/2008 - 17:47h

Quando vou rodar o script de criação das tabelas do bando de dados, está me voltando a seguinte mensagem:

bash-2.05b# mysql -p < postfix.db
Enter password:
ERROR 1062 at line 3: Duplicate entry 'localhost-postfix' for key 1

Detalhe importante, eu estou usando UNBUNTU 7.10

Valeu

[29] Comentário enviado por volcom em 21/02/2008 - 15:42h

Fala Klinux!!

Preciso fazer meu Postfix enviar as mensagens do Mailman...internamente tudo funciona, quando crio uma nova lista, envia mensagem administrativa tanto para o meu domínio quanto para outro domínio, mas quando eu envio mensagem para a lista, nenhum dos membros recebe, não aparece nada para os mederadores e não ocorre o envio.

Será que tem alguma luz? hehehe

Utilizo Debia Etch...

Abraço

[30] Comentário enviado por ttater em 11/01/2010 - 10:48h

Olá estou tendo dificuldades no momento do make install: (Ubuntu 9.10 -Desktop)

gcc -Wmissing-prototypes -Wformat -DHAS_MYSQL -I/usr/include/mysql -DHAS_PCRE -g -O -I. -I../../include -DLINUX2 -o master master.o master_conf.o master_ent.o master_sig.o master_avail.o master_spawn.o master_service.o master_status.o master_listen.o master_vars.o master_wakeup.o master_watch.o master_flow.o ../../lib/libglobal.a ../../lib/libutil.a /usr/lib/mysql -lmysqlclient -lz -lm -L/usr/lib -L/usr/lib -lpcre -ldb -lnsl -lresolv
/usr/bin/ld: /usr/lib/mysql: No such file: File format not recognized
collect2: ld returned 1 exit status
make: ** [master] Erro 1
make: ** [update] Erro 1

Obrigado.

[31] Comentário enviado por terciocosta em 16/06/2010 - 11:11h

o postfix funciona com o oracleXE ao invez do MySql?

[32] Comentário enviado por carlos domingues em 05/07/2012 - 17:24h

Ao enviar o Email de teste pelo console, deu erro 451 4.3.5 Server Configuration error.
Já verifiquei todas as minhas configurações e não consegui achar nada. Agradeço imensamente se alguem puder ajudar me.



Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts