B / Y / U / S
HOME 웹 호스팅 도메인 매뉴얼 고객지원 설정정보 계정신청 2025-04-03 Thursday 
웹 호스팅
# 공지 사항
# 자주 묻는 질문
# 질문과 답변
# 가입 문의
커뮤니티
# 자유게시판
# 리눅스팁
# 아이큐 테스트
# 내홈 소개
# 겔러리
# 자료실

  리눅스팁  Go Unix Power Tools Online Book Go Bash Guide
Read No. 18 article 2001-08-06 04:08:46
NickName   풀비누
Subject   [웹호스팅]아파치-메일-ProFTPd초보자도 할수 있다(2)
4. 가상 메일서버



가상 메일 서버비스는 아파치 설정파일과 같이 그리 복잡하지 않다.

단, 네임서버만 잘 설정하고 access 파일과 Virtualtable 파일과 잘

편집해 주면 무리가 없다.

그리고 POP3데몬도 함께 설치해 주어야 한다.





4-1. sendmail 설치하기



먼저 sendmail이 설치되어 있는지 확인해 보자.



[san2@www san2]$ rpm -qa |grep sendmail

sendmail-8.9.3-10kr

[san2@www san2]$



필자의 시스템에는 버전이 8.9.3 인 RPM으로 설치되어 있다.

설치되어 있지 않다면 CD-ROM이나 해당 배포본의 FTP싸이트에서

다운로드하여 설치하자.



예: CD-ROM으로 설치하는 경우



[san2@www san2]$ su

Password: ********

[root@www san2]# mount /mnt/cdrom

[root@www san2]# cd /mnt/cdrom/RedHat/RPMS

[root@www RPMS]# rpm -Uvh sendmail*

sendmail                 #################################

[root@www RPMS]#

[root@www RPMS]# /etc/rc.d/init.d/sendmail start

[root@www RPMS]#





4-2. qpopper 설치하기



메일을 보내기만 하면 안되겠죠?? 클라이언트에서 메일을 받을 수 있어야

한다. 즉 클라이언트에서 받을 수 있게 하기 위해서는 POP3같은 데몬을

서버에 설치해 주어야 한다.



필자는 직접 qpopper 3.0 소스를 받아 컴파일하여 설치하였다.

박재호님 홈페이지(http://www.kies.co.kr/~jhpark/Sendmail/popper.html)

에 자세한 정보가 있으니 꼭 방문하도록 한다.

여기에서는 모든 개념적인 설명은 제외하고 오직 설치에만 언급한다.



일단 qpopper 3.0을 다운로드하자.



ftp://ftp.qualcomm.com/eudora/servers/unix/popper/



에 접속하면 2.53 버전과 3.0b17, 3.0b18 버전이 있다.

필자는 qpopper3.0b18.tar.Z (2,432KB)을 다운로드 하였고,

/usr/local/src 에 그 소스를 컴파일하고

/usr/local/qpopper 라는 디렉토리에 설치할 것이다.



# cp qpopper3.0b18.tar.Z /usr/local/src/

# cd /usr/local/src

# ls

qpopper3.0b18.tar.Z

# uncompress qpopper3.0b18.tar.Z

# tar xvf qpopper3.0b18.tar

# cd qpopper3.0

# ./configure --enable-specialauth \

              --enable-bulletins=/var/spool/bulls \

              --enable-servermode

# make

# cp popper/popper /usr/local/lib/

#



/etc/services 파일을 다음과 같이 편집한다.



-----------------------------------------------------------

#pop-2  109/tcp  postoffice # POP version 2

#pop-2  109/udp

#pop-3  110/tcp    # POP version 3

#pop-3  110/udp

pop3    110/tcp    # popper

-----------------------------------------------------------





/etc/inetd.conf 파일도 다음과 같이 편집한다.



-----------------------------------------------------------

#pop-2 stream tcp nowait root /usr/sbin/tcpd ipop2d

#pop-3 stream tcp nowait root /usr/sbin/tcpd ipop3d

pop3   stream tcp nowait root /usr/local/lib/popper popper -s

-----------------------------------------------------------



슈퍼데몬을 재 실행한다.



# /etc/rc.d/init.d/inet restart



이제 여러분의 리눅스 박스는 클라이언트에서 메일을 받을 준비가 되어 있다.

다음은 sendmail 설정파일의 예이다. 꼭 이해하고 넘어가야 한다.





4-3. /etc/sendmail.cf



--------------------------------------------------------------

# anything else is bogus

R$*   $#error $@ 5.7.1 $: "550 Relaying denied" #<------[주의]

# 중략

Cwlocalhost

# file containing names of hosts for which we receive email

Fw/etc/sendmail.cw

--------------------------------------------------------------

부연설명하자면 [주의]부분을 주석으로 처리하면 spam 메일 문제가 있다.

주석으로 처리되어 있다면 어쩌면 여러분의 리눅스박스는 Spamer의

본거지가 될 수도 있다는 것이다.

주석으로 처리되어 있다면 주석을 위와 같이 제거하고 access파일을

아래와 같이 편집해 준다.

그리고

Fw/etc/sendmail.cw

와 같이 주석처리가 되어 있지 않아야 한다.





4-4. /etc/sendmail.cw



--------------------------------------------------------------

# sendmail.cw - include all aliases for your machine here.

# 네임서버에 등록된 모든 도메인을 이 파일에 다음과 같이 적어준다.

linux.ac.kr

linuxer.net

linuxer.com

sonamu.co.kr

--------------------------------------------------------------



4-5. /etc/sendmail.cm



특별하게 편집할 필요은 없다. 그냥 넘어간다.





4-6. /etc/mail/access



-------------------------------------------------------------

# 예제:

# cyberspammer.com REJECT

# sendmail.org  OK

# 128.32  RELAY

#

# 주의 사항!!!

#

# 설정 파일을 작성할 때 sendmail.org 와 OK, 128.32 와 RELAY 사이는

# 스페이스가 아니라 꼭!!! <탭>키를 사용하여 띄워야 합니다.

localhost.localdomain  RELAY

localhost              RELAY

linux.ac.kr            OK

linuxer.net            OK

linuxer.com            OK

sonamu.co.kr           OK

192.168                RELAY



# access 파일을 고친 이후에는

#

# makemap hash /etc/mail/access < /etc/mail/access

#

# 명령으로 갱신해 주어야 합니다.

----------------------------------------------------------





4-7. /etc/mail/virtusertable



매우 중요한 설정파일이다. 이 파일을 어떻게 잘 편집하느냐에 따라서

웹호스팅의 성공여부가 달려 있다고 해도 좋다. 주의 깊게 살펴보자.



필자가 왜 이렇게 설정했는가에 대해서는 맨위의 '나의 목표'를 다시한번

읽어보기 바란다.



------------------------------------------------------------

# 이 파일을 보면 김정균님이 쓰신 예제를 보면 쉽게 이해 할 수 있다.



webmaster at linux.ac.kr       san2

ftp at linux.ac.kr             san2

study at linux.ac.kr           san2

study-app at linux.ac.kr       san2

study-net at linux.ac.kr       san2

game at linux.ac.kr            gamedori at hanmail.net

@linuxer.com                com

webmaster at linuxer.net       net

ftp at linuxer.net             net

meeting at linuxer.net         meet

admin at sonamu.co.kr          sonamu

----------------------------------------------------------



부연설명하자면



도메인 linux.ac.kr(메일서버) 에 대해서

game at linux.ac.kr 로 오는 메일은 gamedori at hanmail.net 으로

메핑하고 나머지 webmaster at linux.ac.kr ftp at linux.ac.kr

study at linux.ac.kr study-app at linux.ac.kr study-net at linux.ac.kr

로 오는 메일은 이 서버 관리자인 root의 일반 유저인 'san2' 계정으로

보낸다.



@linux.ac.kr              san2



로 설정해 버린면 linux.ac.kr 도메인(메일서버)을 사용하여 오는 메일은

모두 'san2'가 받게 되어 버린다. 다른 일반 유저까지도 포함하기 때문에

하나하나씩 지정해 주어야 한다.



도메인 linuxer.com(메일서버) 에 대해서

webmaster at linuxer.com ftp at linuxer.com stock at linuxer.com 으로 오

는 메일은 모두 com 유저가 받아 볼 수 있다.



이것을 이해 할 수 있다면 나머지 linuxer.net 과 sonamu 메일서버에 대해

서는 쉽게 이해 하리라 생각된다.



파일 편집이 끝났으면 다음과 같은 명령을 꼭 실행해 주어야 한다.



# makemap hash /etc/mail/virtusertable < /etc/mail/virtusertable



이로써 가상메일서버 설정이 모두 끝났다.







5. 가상 FTP서버 (ProFTPd)



가상 FTP는 FTP데몬만 잘 설치해 주면 크게 문제가 없다.

여기에서는 ProFTPd 데몬을 설치와 각 도메인에 대한 Anonymous

FTP를 설정해 보자.



5-1. ProFTPd 설치하기



CD-ROM이나 각 배포본의 FTP에서 RPM으로 다운로드하든지

http://www.proftpd.org/ 에서 소스로 받든지 간에 여러분의 자유이다.

필자는 가상FTP를 테스트할 쯤에는 1.2.0pre6 의 버전의 소스를 다운로드

하여 설치하였다.



ftp://linux.sarang.net/ 에 접속하면 RPM으로 다운로드하여 설치할 수

있다.



소스를 컴파일하여 설치할 경우



소스를 컴파일할 디렉토리는 /usr/local/src 이고 설치할 디렉토리는

/usr/local/proftpd 이다.



# cp proftpd-1.2.0pre6.tar.gz /usr/local/src/

# cd /usr/local/src

# ls

proftpd-1.2.0pre6.tar.gz

# tar zxvf proftpd-1.2.0pre6.tar.gz

# cd proftpd-1.2.0pre6

# ./configure --prefix=/usr/local/proftpd \

              --sysconfdir=/etc --localstatedir=/var/run \

              --enable-autoshadow --datadir=/home/ftp

# make

# make install

# mkdir /home/ftp



RPM으로 설치하는 경우



# rpm -Uvh proftpd-1.2.0pre6-1.i386.rpm

#





소스를 컴파일하여 설치하든지 RPM으로 설치하여 설치하든지

/etc/inetd.conf 파일을 다음과 같이 주석을 추가해 주어야 한다.

즉 웹 호스팅 성격에 맞게 Proftpd를 standalone 으로 데몬을

가동하기 위해서이다.



-----------/etc/inetd.conf ---------------------------------

# 중략

#ftp stream tcp nowait root /usr/sbin/tcpd in.ftpd -l -a

#ftp stream tcp nowait root /usr/sbin/tcpd  in.ftpd

# 중략

----------------------------------------------------------



그리고 슈퍼데몬을 재가동시킨다.



# /etc/rc.d/init.d/inet restart





5-2. /etc/proftpd.conf



이제 마지막 단계인 ProFTPd 설정파일을 편집해 보자.



---------/etc/proftpd.conf ---------------------------------



ServerName           "ProFTPD ALZZA Default Installation"

ServerType           standalone      # standalone 으로 설정

ServerAdmin          ftp at linux.ac.kr 

# sendmail virtualtable 을 보라.

DefaultServer        on

AuthPAMAuthoritative on

Port                 21

MaxInstances         30

User                 nobody

Group                nobody



<Directory /*>

  AllowOverwrite    on

</Directory>



##Global 설정 VirtualHost 까지 영향을 주므로 자원 낭비가 덜하다. ##

<Global>

Umask               022  # 각 VirtualHost 마다 따로 정의해도된다.

DisplayLogin        .welcome.msg

# 원래는 hidden파일이 아닌 welcome.msg이다.

DisplayFirstChdir   .message

#User               ftp              # Global로 넣지 않은게 좋다.

#Group              ftp              # Global로 넣지 않은게 좋다.

#MaxClients         10               # Global로 넣지 않는다.

#MaxClientsPerHost  1                # Global로 넣지 않는다

UserAlias           anonymous     ftp

RequireValidShell  off  

# Anonymous 접속허용을 위해서는 off로 꼭 설정.

ShowSymlinks                 on

</Global>

########Global end ###################################



<Anonymous ~ftp>

User              ftp  # 모든 Anonymous 에 꼭 넣어주어야 한다.

Group             ftp  # 모든 Anonymous 에 꼭 넣어주어야 한다.

#UserAlias        anonymous ftp

# Global로 설정되어 있으므로 넣을 필요없다.

MaxClients        10   "죄송합니다. 최대 인원은 %m명 입니다."

MaxClientsPerHost 1    "호스트당 1회만 접속가능합니다."

<Limit WRITE>

DenyAll

</Limit>

# 읽기/쓰기/디렉토리만들기를 허용하기 위해서는 다음 주석제거.

#<Directory incoming>

#<Limit WRITE>

#AllowALL

#</Limit>

#</Directory>



</Anonymous>



###### 가상 FTP 호스트설정 부분 ##########################



<VirtualHost ftp.linuxer.com>

ServerName        "ftp.linuxer.com"

ServerAdmin       ftp at linuxer.com



Umask             002

MaxClients        10  "죄송합니다. 최대 인원은 %m명 입니다."

MaxClientsPerHost 1   "호스트당 1회만 접속가능합니다."



<Anonymous /home/com/vir-ftp>

User              ftp

Group             com       # Umask 002 와 관련이 있다.

<Limit WRITE>

DenyAll

</Limit>



<Directory incoming>

<Limit WRITE>

Order Allow,Deny  # 컴파(,)다음에 칸을 빈칸을 띄지 않는다.

Allow from all

Deny from 192.168.15.,haker.com

# C클래스 192.168.15.* 와 haker.com 은 쓰기를 금한다.

</Limit>

</Directory>



### Umask 에 대해서 생각해 보자 ++++++imcoming 디렉토리#######



# umask 는 새로 생성된 디렉토리나 파일에 대해서만 퍼미션을 기본적

# 으로 적용시킨다.

# 즉 Global 에서 umask 022 로 설정되어 있으므로 Anonymous 가

# 접속하여 새로 생성시킬 수 있는

# 디렉토리에 대해서 755의 퍼미션, 그리고 파일에 대해서는 644의 퍼미

# 션을 준다.



# 잠깐 디렉토리의 소유자에 관해서도 생각해보자.

# Anonymous가 새로생성된 디렉토리가 755 이므로 이 디렉토리의 소유자

# 는 root 나 다른 user가 아니고 "ftp" 소유자가 된다.

# 즉 UserAlias Anonymous ftp 이므로 모든 Anonymous 에 대해서

# 다른 Anonymous가 생성시킨 디렉토리나 파일을 지우거나 바꿀 수 있다.



# 한가지 더.....Anonymous가 아닌 일반 유저로 들어왔을 경우를 생각해보자.

# imcoming 디렉토리의 퍼미션이 777 로 되어 있더라도 Aonymous 가 생성

# 된 디렉토리나 파일은 지우거나 바꿀수 없다.(755이므로) 단, incoming 디렉

# 토리 하에서는 퍼미션이 777이므로 생성할 수 있다.



# ftp.linuxer.com 에 대해서 관리자는 "com" 유저이다. 관리자가 Anonymous

# 가 생성한 디렉토리나 파일을 지울 수 없다면 관리자 라고 할 수 있겠는가?

# 여기에 그 해법이 바로 Umask 과 웹호스팅 관리자의 능력에 달려있다.



# /home/com/vir-ftp 의 소유자는 ftp가 아닌 "com" 의 소유자로 해야하고,

# incoming 하위 디렉토리 에 대해서 Unamsk 070 이나 020 으로 설정하면

# 퍼미션은 707 이나 757 이 된다.

# 즉 소유자가 누가되던지 간에 Others가 지우거나 생성할 수 있는 것이다.

# 일반 유저로 들어왔을 경우에 해당한 것이다.



# 이런 방법이 싫다면 Anonymous Group 정도를 VirtualHost 관리자인

# "com" 으로 대체해도 된다.

# 그리고 Umask 002 로 설정하면 775의 퍼미션을 생성되어 "com"유저가

# 관리할 수 있다..이때는 com 그룹에 "com"유저가 포함되어 있어거나

# 단독으로 "com" 유저만 포함해야 한다.

# 이유는 "com" 그룹에 포함된 다른 유저가 피해를 줄 수 있기 때문이다.

# 또는 User 와 Group 에 적어도 관리자가 포함되어 있어야 한다.

# 왜냐하면 "com" 유저는 고객이고 "root" 권한을 획득할 수 없기 때문이다.



# 방법은 여러가지이다.



# 이처럼 Anonymous 가 FTP클라이언트로 접속하여 디렉토리를 생성

# 하고 지울수 있게 하기 위해서는 소유자와 퍼미션 - incoming 디렉토리

# 에 대한 접근 정책 - 그리고 Umask 의 순서로 관리해야한다.

# 예를 들어 아무리 Umask 000 으로 설정했더라도 imcoming 디렉토리에

# 대한 쓰기 권한이 없다면 Anonymous 는 쓸 수 없다는 것이다.....



# 좀더 많은 정보를 원한다면 ProFTPD Reference.html 을 읽어보라.





</Anonymous>

</VirtualHost>



###### VirtualHost <ftp.linuxer.net>의 정의 ###################



<VirtualHost ftp.linuxer.net>

ServerName        "ftp.linuxer.net"

ServerAdmin       ftp at linuxer.net



#Umask            002

# 주석으로 처리되어 있기 때문에 Global 에서 설정한 022을 따른다.

MaxClients        10  "죄송합니다. 최대 인원은 %m명 입니다."

MaxClientsPerHost 1   "호스트당 1회만 접속가능합니다."



<Anonymous /home/net/vir-ftp>

User              ftp

Group             ftp

# ftp.linuxe.com 처럼 incoming 디렉토리가 정의되어 있지 않기 

# 때문에Anonymous는 디렉토리를 생성할 수 없고 따로 지정할 필요도 

# 없다.

<Limit WRITE>

DenyAll

</Limit>

</Anonymous>

</VirtualHost>



-------------end 
-------------------------------------------



설정파일 편집이 모두 끝났으면 Anonymous가 접근할 수 있는 디렉토리를

만들어주자.



# su com

$ mkdir ~com/vir-ftp

$ mkdir ~com/vir-ftp/pub incoming

$ chmod 705 ~com/vir-ftp/pub

$ chmod 707 ~com/vir-ftp/incoming

$

$ su net

Password : ******

$ mkdir ~com/vir-ftp

$ mkdir ~com/vir-ftp/pub

$ chmod 705 ~com/vir-ftp/pub

$



FTP데몬을 재 가동한다.



# /etc/rc.d/init.d/proftpd restart



이제 Anonymous 가 접속할때 보여주는 .welcome.msg 파일도 만들어

주자. vir-ftp 밑에 이 파일이 존재하면 된다.



----------~HOME/vir-ftp/.welcome.msg ----------------------

환영합니다......

ProFTPd Alzza Linux 6.0 2.2.12(안정)

ftp://%L/



o 남은 용량 : %F KB

o 현 사용자 수 : %N/%M (하나의 호스트당 1명까지 접속허가합니다)

o %R의 %u(%U)님이 접속한

o 현 시각은 %T년 입니다.



Admin-mailto:%E

-----------end 
--------------------------------------------



위의 결과는



-----------------------------------------------------------

환영합니다......

 ProFTPd Alzza Linux 6.0 2.2.12(안정)

 ftp://ftp.linux.ac.kr/



 o 남은 용량 : 302868 KB

 o 현 사용자 수 : 2/10 (호스트당 1회 접속만 허가합니다)

 o 192.168.12.5의 UNKNOWN(anonymous)님이 접속한

 o 현 시각은 Tue Sep 14 22:05:36 1999년 입니다.



 Admin-mailto:ftp at linux.ac.kr

-----------------------------------------------------------



이로써 가상 FTP 설정도 모두 끝났다.







6. 마치며



휴~~~ 글을 쓴다는것이 이렇게 힘들줄은 모랐다..



4일동안의 테스트 및 문서작성을 끝내고 있는 중입니다.

어떻게 하다보니 시스템을 작살(?)내는 경우가 있어 다시 설치하여 테스

트하는 실수도 있었다.

물론 필자는 평상시에 Backup 에 많은 시간을 투자하므로 다시설치하여

복구하는데에는 많은 시간을 요하지 않았다.



이 글을 쓰겠다고 맘 먹은지 거의 한달만에 문서를 완료하였다. 그동안

개인적인 사정등으로 차일피일 미루다 보니 이렇게 되었다.



이상의 내용에서 질문이나 의문나는 점 또는 보강이나 잘못된 점이 있으면



http://linuxer.suwon.ac.kr/cgi-bin/CrazyWWWBoard.cgi?db=qna



의 질문과 답변의 게시판을 이용해 주시면 감사하겠습니다.



끝까지 읽어 주셔서 감사합니다.



1999년 9월 16일 "도시 측량실험실" 에서 백수"산이" 씀..........
Regist Addr [ 127.0.0.1 ] 목록보기 윗글 아랫글
정규표현식 [ 상세 검색 ]
Page Loading [ 0.05 Sec ] SQL Time [ 0 Sec ]

Copyleft 1999-2025 by JSBoard Open Project
Theme Designed by IDOO And follow GPL2

개인정보 취급방침 이용 약관 사이트 맵 어드민 관리