Postfix 설정 · 2 min read · Oct 11, 2025

Postfix, Courier 및 MySQL을 이용한 가상 사용자 및 도메인 (CentOS 5.1) - 페이지 5

14 테스트 Postfix

Postfix가 SMTP-AUTHTLS 준비가 되었는지 확인하려면

telnet localhost 25

Postfix 메일 서버에 연결한 후 다음을 입력합니다.

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;

최소한 domainsusers 테이블에 항목을 생성해야 합니다:

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 테이블은 다음과 같은 항목을 가질 수 있습니다:

sourcedestination
[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.tldexample.com으로 오는 모든 이메일을 anotherdomain.tld의 동일한 사용자에게 리디렉션합니다. 예를 들어, [email protected]로 오는 이메일은 [email protected]로 전달됩니다.
[email protected][email protected], [email protected][email protected]의 이메일을 두 개 이상의 이메일 주소로 전달합니다. 목적지 아래 나열된 모든 이메일 주소는 이메일의 사본을 받습니다.

transport 테이블은 다음과 같은 항목을 가질 수 있습니다:

domaintransport
example.com:example.com의 이메일을 로컬로 배달합니다. 이 기록이 이 테이블에 전혀 존재하지 않는 것과 같습니다.
example.comsmtp:mail.anotherdomain.tldexample.com의 모든 이메일을 smtp를 통해 mail.anotherdomain.com 서버로 배달합니다.
example.comsmtp:mail.anotherdomain.tld:2025example.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 reload

16 참고 문헌

튜토리얼: 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 링크

Share: X/Twitter LinkedIn

새 게시물을 받은 편지함에서 받기

스팸은 없습니다. 언제든지 구독 해지 가능합니다.