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地址所在的网段识别为本地网络,并且为之中继邮件
至此,如果你在虚拟中做的测试是无法向外网发送邮件的