Tag Archives: linux

[CentOS] vsftpd 패시브 모드로 동작하게 하기

클라이언트가 FTP서버에 접속하여 데이터를 주고 받는데에는 엑티브 모드와 패시브 모드 두가지가 있습니다. 이 두가지의 차이는 다음과 같습니다.

엑티브 모드는 클라이언트가 데이터를 수신받을 임의의 포트를 열고 서버에 알려주면 서버는 자신의 20번 포트를 통해 클라이언트의 임의의 포트에 데이터를 전송해 줍니다.

하지만 엑티브 모드에서는 클라이언트가 방화벽(공유기등의 사설 네트워크) 밑에 있다면 외부에서 이 클라이언트에 직접 접근하는것을 불가능합니다. 그래서 패시브 모드에서는 이러한 동작을 반대로 진행합니다. 정리하면 다음과 같습니다.

패시브 모드는 서버가 데이터를 송신해줄 임의의 포트를 열고 클라이언트에 알려주면 클라이언트는 서버의 임의의 포트에 접속하여 데이터를 가져갑니다.

결과적으로 방화벽과 같은 복잡한 네트워크 환경에서는 FTP의 패시브 모드의 지원이 꼭 필요합니다. 하지만 여기서 문제가 있는데 패시브 모드에서 서버가 사용하는 임의의 포트가 1024 이후의 모든 임의의 포트라는 것입니다. 이는 서버의 보안이나 방화벽 설정을 함에 있어 껄끄러움으로 작용하게 됩니다.

vsftpd에서는 이 패시브모드의 포트의 범위를 임의 설정할 수 있습니다. 그렇게 되면 방화벽 설정도 한결 용이해 질것입니다. /etc/vsftpd/vsftpd.conf 파일에 다음의 내용을 추가해줍니다.

pasv_enable=Yes
pasv_min_port=10090
pasv_max_port=10100

위에서 설정한 포트의 범위는 원하시는 적절한 범위로 설정하시기 바랍니다. 이제 방화벽 설정을 추가해 보겠습니다. /etc/sysconfig/iptables 에 다음을 추가하겠습니다.

-A INPUT -m state --state NEW -m tcp -p tcp --dport 10090:10100 -j ACCEPT

이제 데몬들을 재시작하면 패시브 모드가 정상적으로 동작하게 됩니다.

ftp> get eye.sql
local: eye.sql remote: eye.sql
229 Entering Extended Passive Mode (|||10093|).
150 Opening BINARY mode data connection for eye.sql (13719976 bytes).
 30% |****************                                       |  4094 KiB  682.45 KiB/s    00:13 ETA

파일을 한번 다운로드 받아보았습니다. 정상적으로 패시브 모드로 진입하는것을 확인할 수 있습니다.

[CentOS] sendmail + dovecot 설치하기

리눅스 기반의 메일시스템으로 가장 많이 쓰이고 있는 sendmail + dovecot 조합의 설치와 설정에 대해 알아보겠습니다. 여기서 설명할 설정은 제가 선호하는 설정이라는것을 감안하고 봐주시기 바랍니다.

먼저 sendmail을 설치합니다. sendmail은 메일의 송수신을 담당하게 됩니다. 25번 포트를 사용하여 외부로부터의 메일을 수신하는 역할을 합니다.

$ yum install sendmail sendmail-cf cyrus-sasl*

/etc/mail/access 파일에 인증없이 메일을 송신할 수 있는 호스트를 정의해 줍니다. 기본적으로 메일서버 본인이 해당되게 됩니다.

Connect:localhost.localdomain           RELAY
Connect:localhost                       RELAY
Connect:127.0.0.1                       RELAY
Connect:123.123.123.123                 RELAY
Connect:mail.theeye.pe.kr               RELAY

/etc/mail/local-host-names 파일에는 메일주소로 사용될 수 있는 도메인들을 입력합니다. 물론 현재세팅중인 서버를 메일서버로 사용하는 도메인들을 사용하셔야 합니다.

# local-host-names - include all aliases for your machine here.
theeye.pe.kr

/etc/mail/sendmail.mc 파일중 다음의 항목들의 주석을 해제하거나 수정을 해줍니다.

define(`SMART_HOST', `mail.theeye.pe.kr')dnl

TRUST_AUTH_MECH(`EXTERNAL DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
define(`confAUTH_MECHANISMS', `EXTERNAL GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl

DAEMON_OPTIONS(`Port=smtp, Name=MTA')dnl

FEATURE(masquerade_envelope)dnl
FEATURE(`allmasquerade')

위의 항목들은 모두 MAILER(smtp)dnl 위에 정의되어야 합니다. 주의가 필요합니다.

스팸을 조금이라도 걸러내기 위해 DNS기반의 스팸 블랙리스트 체크를 추가할수도 있습니다. MAILER(smtp)dnl 바로 위에 다음의 항목을 추가해줍니다. 저는 다음의 2가지를 사용하고 있습니다.

FEATURE(dnsbl,`sbl.spamhaus.org',`',`Rejected - see http://www.spamhaus.org/sbl/')dnl
FEATURE(dnsbl, `spamlist.or.kr', `Rejected - see http://www.kisarbl.or.kr/')dnl

이제 다음의 명령을 사용하여 설정을 컴파일 해줍니다.

$ make -C /etc/mail
make: Entering directory `/etc/mail'
make: Leaving directory `/etc/mail'

이제 메일 데몬을 자동시작되도록 등록한 뒤에 실행해 보겠습니다. 여기에 추가로 메일 송신시에 cyrus-sasl이라는 데몬을 사용하게 됩니다. 같이 실행 하도록 하겠습니다.

$ chkconfig --level 345 saslauthd on
$ service saslauthd start
Starting saslauthd:                                        [  OK  ]

$ chkconfig --level 345 sendmail on
$ service sendmail start
Starting sendmail:                                         [  OK  ]
Starting sm-client:                                        [  OK  ]

정상적으로 데몬이 떠있는지 텔넷으로 접속하여 확인해 보도록 하겠습니다.

$ telnet localhost 25
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
220 theeye.pe.kr ESMTP Sendmail 8.14.4/8.14.4; Sun, 19 Jan 2014 13:27:14 +0900
EHLO localhost
250-theeye.pe.kr Hello localhost [127.0.0.1], pleased to meet you
250-ENHANCEDSTATUSCODES
250-PIPELINING
250-8BITMIME
250-SIZE
250-DSN
250-ETRN
250-AUTH GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN  # 이 라인이 있다면 정상
250-DELIVERBY
250 HELP

이번에는 imap, pop3 서버를 설치해보도록 하겠습니다. 각종 메일 클라이언트들이 이 프로포콜을 사용하여 수신받은 메일을 가져가게 됩니다.

$ yum install dovecot

설치는 너무 간단해서 딱히 할말이 없군요^^ /etc/dovecot/dovecot.conf 의 다음의 주석을 제거해 줍니다.

protocols = imap pop3 lmtp
listen = *, ::

IPv6를 사용하지 않는다면 listen 항목의 ::는 지우셔도 됩니다. 이번에는 Plain Text 로그인을 가능하게 하기 위해 /etc/dovecot/conf.d/10-auth.conf 의 다음의 내용을 주석 해제 후 값을 변경해 줍니다.

# Disable LOGIN command and all other plaintext authentications unless
# SSL/TLS is used (LOGINDISABLED capability). Note that if the remote IP
# matches the local IP (ie. you're connecting from the same computer), the
# connection is considered secure and plaintext authentication is allowed.
disable_plaintext_auth = no

이제 데몬을 구동해 줍시다.

$ chkconfig --level 345 dovecot on
$ service dovecot start
Starting Dovecot Imap:                                     [  OK  ]

최종적으로 사용하게 되는 포트는 25(smtp), 110(pop3), 143(imap), 993(imaps), 995(pop3s)입니다. /etc/sysconfig/iptables 에서 방화벽 연결을 해제해 주도록 합니다.

-A INPUT -m state --state NEW -m tcp -p tcp --dport 25 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 110 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 993 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 995 -j ACCEPT

설정이 완료되었습니다.