메일 서버 · 5 min read · Jan 06, 2026

Postfix, Courier, MySQL 및 SquirrelMail을 이용한 가상 사용자 및 도메인 (Fedora 10)

Postfix, Courier, MySQL 및 SquirrelMail을 이용한 가상 사용자 및 도메인 (Fedora 10)

버전 1.0
저자: Falko Timme

이 튜토리얼은 Falko Timme의 저작권 (c) 2009입니다. 이는 Christoph Haas의 튜토리얼에서 파생된 것으로 http://workaround.org에서 찾을 수 있습니다. 이 튜토리얼은 Creative Commons 라이선스 2.5 또는 이후 버전 하에 자유롭게 사용할 수 있습니다.

이 문서는 MySQL 데이터베이스에 있는 가상 사용자 및 도메인을 기반으로 하는 Postfix 기반 메일 서버를 설치하는 방법을 설명합니다. 또한 Courier(Courier-POP3, Courier-IMAP)의 설치 및 구성을 시연하여 Courier가 Postfix가 사용하는 동일한 MySQL 데이터베이스에 대해 인증할 수 있도록 합니다.

결과적으로 생성된 Postfix 서버는 SMTP-AUTHTLS쿼터를 지원합니다(쿼터는 기본적으로 Postfix에 내장되어 있지 않으며, Postfix를 적절하게 패치하는 방법을 보여드리겠습니다). 비밀번호는 데이터베이스에 암호화된 형태로 저장됩니다(내가 찾은 대부분의 문서는 보안 위험이 있는 일반 텍스트 비밀번호를 다루고 있었습니다). 이 튜토리얼은 또한 이메일이 스팸 및 바이러스를 검사하도록 Amavisd, SpamAssassinClamAV의 설치를 다룹니다. 또한 사용자가 이메일을 읽고 보내고 비밀번호를 변경할 수 있도록 웹메일 인터페이스로 SquirrelMail을 설치하는 방법도 보여드리겠습니다.

이러한 “가상” 설정(가상 사용자 및 도메인이 MySQL 데이터베이스에 있는)은 “실제” 시스템 사용자 기반 설정보다 훨씬 더 성능이 뛰어납니다. 이 가상 설정을 사용하면 메일 서버가 수천 개의 도메인과 사용자를 처리할 수 있습니다. 또한 새 사용자/도메인을 추가하거나 기존 것을 편집할 때 MySQL 데이터베이스만 처리하면 되므로 관리가 더 쉽습니다. 더 이상 db 파일을 생성하기 위한 postmap 명령이나 Postfix를 다시 로드할 필요가 없습니다. MySQL 데이터베이스 관리를 위해 phpMyAdmin과 같은 웹 기반 도구를 사용할 수 있으며, 이 방법에서도 설치됩니다. 세 번째 장점은 사용자가 사용자 이름으로 이메일 주소를 가지므로(사용자 이름 + 이메일 주소 대신) 이해하고 기억하기가 더 쉽다는 것입니다.

이 방법은 실용적인 가이드로 의도되었으며, 이론적 배경은 다루지 않습니다. 이론적 배경은 웹의 많은 다른 문서에서 다루어집니다.

이 문서는 어떤 종류의 보증 없이 제공됩니다! 이는 이러한 시스템을 설정하는 유일한 방법이 아님을 말씀드리고 싶습니다. 이 목표를 달성하는 방법은 여러 가지가 있지만, 이것이 제가 선택한 방법입니다. 이것이 귀하에게 작동할 것이라는 보증을 제공하지 않습니다!

1 사전 참고

이 튜토리얼은 Fedora 10을 기반으로 하므로, 이 튜토리얼을 계속 진행하기 전에 기본 Fedora 10 서버 설치를 설정해야 합니다(예: The Perfect Server - Fedora 10의 처음 6장에 설명된 대로). 시스템은 정적 IP 주소를 가져야 합니다. 이 튜토리얼에서는 192.168.0.100을 IP 주소로 사용하고 server1.example.com을 호스트 이름으로 사용합니다.

방화벽이 꺼져 있는지(적어도 지금은) 및 SELinux가 비활성화되어 있는지 확인해야 합니다(이것은 중요합니다!).

2 일부 소프트웨어 설치

먼저 시스템의 기존 패키지를 업데이트합니다:

yum update

이제 나중에 필요할 소프트웨어를 설치합니다:

yum groupinstall 'Development Tools'
yum groupinstall 'Development Libraries'

3 Apache, MySQL, phpMyAdmin 설치

다음 명령어 하나로 모든 것을 설치할 수 있습니다(여기에는 Courier-IMAP을 빌드하는 데 필요한 패키지도 포함됩니다):

yum install ntp httpd mysql-server php php-mysql php-mbstring rpm-build gcc mysql-devel openssl-devel cyrus-sasl-devel pkgconfig zlib-devel phpMyAdmin pcre-devel openldap-devel postgresql-devel expect libtool-ltdl-devel openldap-servers libtool gdbm-devel pam-devel gamin-devel

4 Courier-IMAP, Courier-Authlib 및 Maildrop 설치

불행히도 Courier-IMAP, Courier-Authlib 및 Maildrop에 대한 rpm 패키지가 없으므로, 우리는 직접 빌드해야 합니다.

RPM 패키지는 root로 빌드해서는 안 됩니다. courier-imap은 컴파일이 root 사용자로 실행되는 것을 감지하면 컴파일을 거부합니다. 따라서 이제 일반 사용자 계정을 생성하고(falko라는 예시) 비밀번호를 설정합니다:

useradd -m -s /bin/bash falko  
passwd falko

나중에 falko가 rpm 패키지를 컴파일하고 설치할 수 있도록 sudo 명령이 필요합니다. 하지만 먼저 falko가 sudo를 사용하여 모든 명령을 실행할 수 있도록 허용해야 합니다:

실행:

visudo

열리는 파일에서 root ALL=(ALL) ALL이라는 줄이 있습니다. 그 줄 바로 아래에 falko에 대한 유사한 줄을 추가합니다:

| [...] ## Allow root to run any commands anywhere root ALL=(ALL) ALL falko ALL=(ALL) ALL [...] |

이제 rpm 패키지를 빌드할 준비가 되었습니다. 먼저 falko 사용자로 전환합니다:

su falko

다음으로 빌드 환경을 생성합니다:

mkdir $HOME/rpm  
mkdir $HOME/rpm/SOURCES  
mkdir $HOME/rpm/SPECS  
mkdir $HOME/rpm/BUILD  
mkdir $HOME/rpm/BUILDROOT  
mkdir $HOME/rpm/SRPMS  
mkdir $HOME/rpm/RPMS  
mkdir $HOME/rpm/RPMS/i386
echo "%_topdir $HOME/rpm" >> $HOME/.rpmmacros

이제 다운로드 디렉토리를 생성하고 http://www.courier-mta.org/download.php에서 소스 파일을 다운로드합니다:

mkdir $HOME/downloads  
cd $HOME/downloads
wget http://prdownloads.sourceforge.net/courier/courier-authlib-0.62.1.tar.bz2  
wget http://prdownloads.sourceforge.net/courier/courier-imap-4.4.1.20080920.tar.bz2  
wget http://prdownloads.sourceforge.net/courier/maildrop-2.0.4.20080726.tar.bz2

이제($HOME/downloads에 있는 동안) courier-authlib를 빌드할 수 있습니다:

sudo rpmbuild -ta courier-authlib-0.62.1.tar.bz2

빌드 프로세스 후, rpm 패키지는 $HOME/rpm/RPMS/i386에 있습니다($HOME/rpm/RPMS/x86_64는 x86_64 시스템인 경우):

cd $HOME/rpm/RPMS/i386

명령어

ls -l

은 사용 가능한 rpm 패키지를 보여줍니다:

[falko@server1 i386]$ ls -l  
total 588  
-rw-r--r-- 1 root root 139458 2009-01-21 16:12 courier-authlib-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root 311705 2009-01-21 16:12 courier-authlib-debuginfo-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root  34723 2009-01-21 16:12 courier-authlib-devel-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root  17784 2009-01-21 16:12 courier-authlib-ldap-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root  14096 2009-01-21 16:12 courier-authlib-mysql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root  13349 2009-01-21 16:12 courier-authlib-pgsql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root   8150 2009-01-21 16:12 courier-authlib-pipe-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root root  34986 2009-01-21 16:12 courier-authlib-userdb-0.62.1-1.fc10.i386.rpm  
[falko@server1 i386]$

설치할 패키지를 선택하고 다음과 같이 설치합니다:

sudo rpm -ivh courier-authlib-0.62.1-1.fc10.i386.rpm  
sudo rpm -ivh courier-authlib-devel-0.62.1-1.fc10.i386.rpm  
sudo rpm -ivh courier-authlib-mysql-0.62.1-1.fc10.i386.rpm

이제 다운로드 디렉토리로 돌아갑니다:

cd $HOME/downloads

그리고 sudo 없이 rpmbuild를 다시 실행합니다. 그렇지 않으면 컴파일이 root로 실행되었기 때문에 실패합니다:

rpmbuild -ta courier-imap-4.4.1.20080920.tar.bz2

빌드 프로세스 후, rpm 패키지는 $HOME/rpm/RPMS/i386에 있습니다($HOME/rpm/RPMS/x86_64는 x86_64 시스템인 경우):

cd $HOME/rpm/RPMS/i386

명령어

ls -l

은 사용 가능한 rpm 패키지를 보여줍니다:

[falko@server1 i386]$ ls -l  
total 1864  
-rw-r--r-- 1 root  root  139458 2009-01-21 16:12 courier-authlib-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root  311705 2009-01-21 16:12 courier-authlib-debuginfo-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   34723 2009-01-21 16:12 courier-authlib-devel-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   17784 2009-01-21 16:12 courier-authlib-ldap-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   14096 2009-01-21 16:12 courier-authlib-mysql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   13349 2009-01-21 16:12 courier-authlib-pgsql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root    8150 2009-01-21 16:12 courier-authlib-pipe-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   34986 2009-01-21 16:12 courier-authlib-userdb-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 falko falko 398287 2009-01-21 17:02 courier-imap-4.4.1.20080920-1.10.i386.rpm  
-rw-r--r-- 1 falko falko 895637 2009-01-21 17:02 courier-imap-debuginfo-4.4.1.20080920-1.10.i386.rpm  
[falko@server1 i386]$

courier-imap을 다음과 같이 설치할 수 있습니다:

sudo rpm -ivh courier-imap-4.4.1.20080920-1.10.i386.rpm

이제 다운로드 디렉토리로 돌아갑니다:

cd $HOME/downloads

그리고 maildrop 패키지를 빌드하기 위해 rpmbuild를 다시 실행합니다:

sudo rpmbuild -ta maildrop-2.0.4.20080726.tar.bz2

빌드 프로세스 후, rpm 패키지는 $HOME/rpm/RPMS/i386에 있습니다($HOME/rpm/RPMS/x86_64는 x86_64 시스템인 경우):

cd $HOME/rpm/RPMS/i386

명령어

ls -l

은 사용 가능한 rpm 패키지를 보여줍니다:

[falko@server1 i386]$ ls -l  
total 3080  
-rw-r--r-- 1 root  root  139458 2009-01-21 16:12 courier-authlib-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root  311705 2009-01-21 16:12 courier-authlib-debuginfo-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   34723 2009-01-21 16:12 courier-authlib-devel-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   17784 2009-01-21 16:12 courier-authlib-ldap-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   14096 2009-01-21 16:12 courier-authlib-mysql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   13349 2009-01-21 16:12 courier-authlib-pgsql-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root    8150 2009-01-21 16:12 courier-authlib-pipe-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 root  root   34986 2009-01-21 16:12 courier-authlib-userdb-0.62.1-1.fc10.i386.rpm  
-rw-r--r-- 1 falko falko 398287 2009-01-21 17:02 courier-imap-4.4.1.20080920-1.10.i386.rpm  
-rw-r--r-- 1 falko falko 895637 2009-01-21 17:02 courier-imap-debuginfo-4.4.1.20080920-1.10.i386.rpm  
-rw-r--r-- 1 root  root  301762 2009-01-21 17:33 maildrop-2.0.4.20080726-3.10.i386.rpm  
-rw-r--r-- 1 root  root  726303 2009-01-21 17:33 maildrop-debuginfo-2.0.4.20080726-3.10.i386.rpm  
-rw-r--r-- 1 root  root  133025 2009-01-21 17:33 maildrop-devel-2.0.4.20080726-3.10.i386.rpm  
-rw-r--r-- 1 root  root   58561 2009-01-21 17:33 maildrop-man-2.0.4.20080726-3.10.i386.rpm  
[falko@server1 i386]$

이제 maildrop을 다음과 같이 설치할 수 있습니다:

sudo rpm -ivh maildrop-2.0.4.20080726-3.10.i386.rpm

모든 필요한 패키지를 컴파일하고 설치한 후, 다음을 입력하여 다시 root가 될 수 있습니다:

exit

5 Postfix에 쿼타 패치 적용

Postfix 소스 rpm을 가져와 쿼타 패치로 패치한 후, 새로운 Postfix rpm 패키지를 빌드하고 설치해야 합니다.

cd /usr/src  
wget http://ftp-stud.fht-esslingen.de/pub/Mirrors/fedora/linux/releases/10/Fedora/source/SRPMS/postfix-2.5.5-1.fc10.src.rpm  
rpm -ivh postfix-2.5.5-1.fc10.src.rpm

마지막 명령은 무시할 수 있는 몇 가지 경고를 표시합니다:

warning: user mockbuild does not exist - using root  
warning: group mockbuild does not exist - using root
cd /root/rpmbuild/SOURCES  
wget http://vda.sourceforge.net/VDA/postfix-2.5.5-vda-ng.patch.gz  
gunzip postfix-2.5.5-vda-ng.patch.gz  
cd /root/rpmbuild/SPECS/

이제 postfix.spec 파일을 편집해야 합니다:

vi postfix.spec

| [...] # Patches Patch0: postfix-2.5.5-vda-ng.patch Patch1: postfix-2.1.1-config.patch Patch3: postfix-alternatives.patch Patch6: postfix-2.1.1-obsolete.patch Patch7: postfix-2.1.5-aliases.patch Patch8: postfix-large-fs.patch Patch9: postfix-2.4.0-cyrus.patch Patch10: postfix-2.4.5-open_define.patch [...] %prep %setup -q # Apply obligatory patches %patch0 -p1 -b .vda-ng %patch1 -p1 -b .config %patch3 -p1 -b .alternatives %patch6 -p1 -b .obsolete %patch7 -p1 -b .aliases %patch8 -p1 -b .large-fs %patch9 -p1 -b .cyrus %patch10 -p1 -b .open_define [...] |

그런 다음 쿼타 및 MySQL 지원이 포함된 새로운 Postfix rpm 패키지를 빌드합니다:

rpmbuild -ba postfix.spec

우리의 Postfix rpm 패키지는 /root/rpmbuild/RPMS/i386에 생성되며(/root/rpmbuild/RPMS/x86_64는 x86_64 시스템인 경우), 그곳으로 이동합니다:

cd /root/rpmbuild/RPMS/i386

명령어

ls -l

은 사용 가능한 패키지를 보여줍니다:

[root@server1 i386]# ls -l  
total 11828  
-rw-r--r-- 1 root root 4006842 2009-01-21 18:26 postfix-2.5.5-1.fc10.i386.rpm  
-rw-r--r-- 1 root root 8028042 2009-01-21 18:26 postfix-debuginfo-2.5.5-1.fc10.i386.rpm  
-rw-r--r-- 1 root root   51909 2009-01-21 18:26 postfix-pflogsumm-2.5.5-1.fc10.i386.rpm  
[root@server1 i386]#

Postfix 패키지를 선택하고 다음과 같이 설치합니다:

rpm -ivh postfix-2.5.5-1.fc10.i386.rpm
Share: X/Twitter LinkedIn

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

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