Postfix邮件服务器搭建及配置

一、邮件服务器(Mail Server)的传输协议

1、简单邮件传输协议(SMTP):Simple Mail Transger Protocol

2、扩展的简单邮件传输协议(ESMTP):Extended Simple Mail Transger Protocol

3、邮局协议(POP3):Post Office Protocol

4、互联网邮件访问协议(IMAP4):Internet Mail Access Protocol

5、简单认证安全层(SASL):Simple Authintication Secure Layer

6、邮件传输代理(MTA):SMTP服务器

   sendmail(m4语言),qmail,postfix(模块化设计,与sendmail兼容,安全,效率高)

7、邮件投递代理(MDA):procmail,maildrop

8、邮件检索代理(MRA):pop3,imap4的实现

9、邮件用户代理(MUA):

   Outlook Express,Outlook

   Foxmail

   Thunderbird

   Evolution

   mutt(文本界面)

10、Webmail:Openwebmail、squirrelmail(小松鼠)、Extmail(Extman)

二、安装Postfix+SASL(courier-authlib)+MySQL

1、安装MySQL

如果没有mysql用户则添加:

# useradd -r mysql -s /sbin/nologin

# tar zxvf mysql-5.6.30-linux-glibc2.5-x86_64.tar.gz -C /usr/local/

# ln -sv /usr/local/mysql-5.6.30-linux-glibc2.5-x86_64 /usr/local/mysql

# chown mysql.mysql -R mysql-5.6.30-linux-glibc2.5-x86_64

创建MySQL的数据文件目录

# mkdir -pv /data/mysql

# chown -R mysql.mysql /data/mysql

初始化数据库

# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql

复制MySQL的服务启动脚本到/etc/rc.d/init.d/下

# cp support-files/mysql.server /etc/rc.d/init.d/mysqld

将mysqld添加到服务聊表并设置开机自启动

# chkconfig --add mysqld

# chkconfig mysqld on

MySQL的配置文件:/etc/my.cnf或/etc/mysql/my.cnf-->$MYSQL_Base/my.cnf -->

--defaults-extra-file=/path/to/some_my.cnf -->.my.cnf

如果找到的不同,则合并,如果不同,则以最后一个为准

本人把所有配置文件都删了只留了下面这个文件

# vim /etc/my.cnf

加入如下内容:

[client]

port = 3306

socket = /tmp/mysql.sock

[mysqld]

server_id = 1

log_bin = /data/mysql/mysql_binlog

lower_case_table_names=1

binlog-ignore-db=mysql,test

port = 3306

pid-file=/usr/local/mysql/mysql.pid

socket = /tmp/mysql.sock

skip-external-locking

key_buffer_size = 256M

max_allowed_packet = 1M

table_open_cache = 256

sort_buffer_size = 1M

read_rnd_buffer_size = 4M

thread_cache_size = 8

query_cache_size = 16M

thread_concurrency = 2

datadir = /data/mysql

添加MySQL的到环境变量:

# vim /etc/profile.d/mysql.sh加入如下内容:

export PATH=/usr/local/mysql/bin:$PATH

# source /etc/profile.d/mysql.sh

删除匿名用户:

mysql> drop user ''@'localhost';

mysql> drop user ''@'master.fansik.com';

给root用户添加密码:

mysql> update user set password=password('fanjinbao') where user='root';

mysql> flush privileges;

如果增加密码后还想直接用mysql直接登录那就:

# vim ~/.my.cnf加入:

[mysql]

user = root

password = fanjinbao

socket = /tmp/mysql.sock

导出头文件:

# ln -sv /usr/local/mysql/include/ /usr/include/mysql

导出库文件:

# vim /etc/ld.so.conf.d/mysql.conf加入:/usr/local/mysql/lib

# ldconfig -v

查看是否添加成功:

# ldconfig -p | grep mysql

2、安装postfix

postfix官方网站:http://www.postfix.org/

创建postfix用户和postdrop用户

# groupadd -g 2525 postfix

# useradd -g postfix -u 2525 -s /sbin/nologin -M postfix

# groupadd -g 2526 postdrop

# useradd -g postdrop -u 2526 -s /sbin/nologin -M postdrop

安装postfix

# tar xf postfix-2.10.10.tar.gz

# cd postfix-2.10.10

如果是最小化安装的CentOS系统,需要安装:

# yum -y install libaio* cyrus-sasl-devel db*-devel gcc openssl-devel

# make makefiles 'CCARGS=-DHAS_MYSQL -I/usr/local/mysql/include -DUSE_SASL_AUTH -DUSE_CYRUS_SASL -I/usr/include/sasl -DUSE_TLS ' 'AUXLIBS=-L/usr/local/mysql/lib -lmysqlclient -lz -lm -L/usr/lib64/sasl2 -lsasl2 -lssl -lcrypto'

# make

# make install

# postfix start

postfix的配置文件:

master:/etc/postfix/master.cf

mail:/etc/postfix/main.cf

参数 = 值:参数必须写在行的绝对行首,以空白开头的行被认为是上一行的延续

postfix启动脚本及开机自启动设置:http://www.cnblogs.com/fansik/p/5683775.html

postconf:配置postfix

   -d:显示默认配置

   -n:修改了的配置

   -m:显示支持的查找表类型

   -A:显示支持的SASL客户端插件类型

smtp状态码:

 1xx:纯信息

   2xx:正确

   3xx:上一步操作尚未完成,需要继续补充

   4xx:暂时性错误

   5xx:永久性错误

smtp协议命令:

   helo(smtp协议)

   ehlo(esmtp协议)

   mail from:

   rcpt to:

alias:邮件别名

   abc@fansik.com postmaster@fansik.com

   /etc/aliases-->hash-->/etc/aliases.db

   # newaliases

postfix默认把本机的IP地址所在的网段识别为本地网络,并且为之中继邮件

至此,如果你在虚拟中做的测试是无法向外网发送邮件的

posted @ 2016-07-18 18:03  fansik  阅读(1333)  评论(0编辑  收藏