Postfix 설정 · 2 min read · Oct 11, 2025
Postfix, Courier 및 MySQL을 이용한 가상 사용자 및 도메인 (CentOS 5.1) - 페이지 5
14 테스트 Postfix
Postfix가 SMTP-AUTH 및 TLS 준비가 되었는지 확인하려면
telnet localhost 25Postfix 메일 서버에 연결한 후 다음을 입력합니다.
ehlo localhost다음과 같은 줄이 보이면
*250-STARTTLS *및
*250-AUTH PLAIN LOGIN *모든 것이 정상입니다.
[root@server1 ~]# telnet localhost 25
Trying 127.0.0.1...
Connected to localhost.localdomain (127.0.0.1).
Escape character is '^]'.
220 server1.example.com ESMTP Postfix
ehlo localhost
250-server1.example.com
250-PIPELINING
250-SIZE 10240000
250-VRFY
250-ETRN
250-STARTTLS
250-AUTH PLAIN LOGIN
250-AUTH=PLAIN LOGIN
250-ENHANCEDSTATUSCODES
250-8BITMIME
250 DSN
quit
221 2.0.0 Bye
Connection closed by foreign host.
[root@server1 ~]#quit시스템의 셸로 돌아가려면 입력합니다.
15 데이터베이스 채우기 및 테스트
데이터베이스를 채우려면 MySQL 셸을 사용할 수 있습니다:
mysql -u root -p
USE mail;최소한 domains 및 users 테이블에 항목을 생성해야 합니다:
INSERT INTO `domains` (`domain`) VALUES ('example.com');
INSERT INTO `users` (`email`, `password`, `quota`) VALUES ('[email protected]', ENCRYPT('secret'), 10485760);(비밀번호를 암호화하기 위해 두 번째 INSERT 문에서 ENCRYPT 구문을 사용해야 합니다!)
다른 두 테이블에 항목을 추가하려면 다음과 같이 작성할 수 있습니다:
INSERT INTO `forwardings` (`source`, `destination`) VALUES ('[email protected]', '[email protected]');
INSERT INTO `transport` (`domain`, `transport`) VALUES ('example.com', 'smtp:mail.example.com');MySQL 셸을 종료하려면 다음을 입력합니다.
quit;대부분의 사람들은 MySQL에 대한 그래픽 프론트 엔드가 있는 것이 더 쉽기 때문에, mail 데이터베이스를 관리하기 위해 phpMyAdmin을 사용할 수도 있습니다 (이 예에서는 http://192.168.0.100/phpmyadmin/ 또는 http://server1.example.com/phpmyadmin/에서). 다시 말하지만, 사용자를 생성할 때 비밀번호를 암호화하기 위해 ENCRYPT 함수를 사용해야 합니다:
도메인 및 사용자 테이블에 대해 더 이상 설명할 필요는 없다고 생각합니다.
forwardings 테이블은 다음과 같은 항목을 가질 수 있습니다:
| source | destination | |
| [email protected] | [email protected] | [email protected]의 이메일을 [email protected]로 리디렉션합니다. |
| @example.com | [email protected] | [email protected]에 대한 Catch-All 계정을 생성합니다. example.com으로 오는 모든 이메일은 [email protected]로 도착하며, users 테이블에 존재하는 이메일은 제외됩니다 (즉, [email protected]가 users 테이블에 존재하는 경우, [email protected]로 오는 이메일은 여전히 [email protected]로 도착합니다). |
| @example.com | @anotherdomain.tld | example.com으로 오는 모든 이메일을 anotherdomain.tld의 동일한 사용자에게 리디렉션합니다. 예를 들어, [email protected]로 오는 이메일은 [email protected]로 전달됩니다. |
| [email protected] | [email protected], [email protected] | [email protected]의 이메일을 두 개 이상의 이메일 주소로 전달합니다. 목적지 아래 나열된 모든 이메일 주소는 이메일의 사본을 받습니다. |
transport 테이블은 다음과 같은 항목을 가질 수 있습니다:
| domain | transport | |
| example.com | : | example.com의 이메일을 로컬로 배달합니다. 이 기록이 이 테이블에 전혀 존재하지 않는 것과 같습니다. |
| example.com | smtp:mail.anotherdomain.tld | example.com의 모든 이메일을 smtp를 통해 mail.anotherdomain.com 서버로 배달합니다. |
| example.com | smtp:mail.anotherdomain.tld:2025 | example.com의 모든 이메일을 smtp를 통해 mail.anotherdomain.com 서버로 배달하지만, 기본 포트 25가 아닌 포트 2025에서 배달합니다. |
| example.com | smtp:[1.2.3.4]
smtp:[1.2.3.4]:2025
smtp:[mail.anotherdomain.tld] | 대괄호는 Postfix가 대괄호 안의 주소에 대한 MX DNS 레코드를 조회하는 것을 방지합니다. IP 주소에 대해 의미가 있습니다. | | .example.com | smtp:mail.anotherdomain.tld | example.com의 모든 하위 도메인에 대한 메일은 mail.anotherdomain.tld로 배달됩니다. | | * | smtp:mail.anotherdomain.tld | 모든 이메일은 mail.anotherdomain.tld로 배달됩니다. | | [email protected] | smtp:mail.anotherdomain.tld | [email protected]의 이메일은 mail.anotherdomain.tld로 배달됩니다. |
자세한 내용은
man transport를 참조하십시오.
transport 테이블의 항목 순서가 중요하다는 점을 기억해 주십시오! 항목은 위에서 아래로 순서대로 처리됩니다.
중요: Postfix는 transports에 대한 캐싱 메커니즘을 사용하므로, transport 테이블의 변경 사항이 적용되기까지 시간이 걸릴 수 있습니다. 즉시 적용되도록 하려면, transport 테이블에서 변경한 후 다음을 실행하십시오.
postfix reload16 참고 문헌
튜토리얼: Debian-Sarge 및 Postfix 2.1을 사용한 ISP 스타일 이메일 서비스: http://workaround.org/articles/ispmail-sarge/
Postfix + 쿼터: http://vhcs.net/new/modules/newbb/viewtopic.php?topic_id=3496&forum=17
saslauthd를 사용하여 암호화된 메일 비밀번호: http://www.syscp.de/docs/public/contrib/cryptedmailpws
17 링크
- Postfix MTA: http://www.postfix.org/
- Postfix 쿼터 패치: http://web.onda.com.br/nadal/
- phpMyAdmin: http://www.phpmyadmin.net/
- CentOS: http://www.centos.org
새 게시물을 받은 편지함에서 받기
스팸은 없습니다. 언제든지 구독 해지 가능합니다.