메뉴 건너뛰기

Cloudera, BigData, Semantic IoT, Hadoop, NoSQL

Cloudera CDH/CDP 및 Hadoop EcoSystem, Semantic IoT등의 개발/운영 기술을 정리합니다. gooper@gooper.com로 문의 주세요.


*출처 : http://m.blog.naver.com/bansd2/40121228968


제목과 같은 프로그램을 이용하는 이유는 메일서버를 만들기 위함이며, saslauthd는 smtp인증을 받아야지만

메일을 보낼 수 있게 하기 위한 인증 모듈이다.

 

아웃룩에서 보내는 메일을 smtp인증을 받게 하기 위해서 사용을 하였다.

 

우분투에서 sendmail과 dovecot, saslauthd를 설치하기는 쉽다.

(sendmail 설치는 https://www.gooper.com/ss/index.php?mid=bigdata&category=2809&document_srl=3456 를 참조한다)


설치는 전부 root권한으로 진행하였다.

 

#apt-get install libsasl2-2 libsasl2-modules sasl2-bin

#apt-get install dovecot-pop3d dovecot-imapd

 

위와같이 하면 설치는 완료다.

 

문제는 설정!!!

 

이것때문에 난 한달에 가까운 시간을 버렸다.

 

일단 smtp인증을 받기 위해서 sendmail.cf 과 sendmail.mc 를 수정한다.

 

먼저 sendmail.mc 수정

 

dnl # These are the allowed auth mechanisms. To allow relaying for a userdnl # that uses one of them, you must set TRUST_AUTH_MECH.define(`confAUTH_MECHANISMS', `LOGIN PLAIN DIGEST-MD5 CRAM-MD5')dnldnl # These are the SMTP auth mechanisms which, if used,dnl # Sendmail will allow relaying for. TRUST_AUTH_MECH(`LOGIN PLAIN DIGEST-MD5 CRAM-MD5')dnl 

위 문장을 없으면 추가하고 있으면 위 문장과 같이 만든다.

그리고 Addr=127.0.0.1 이라고 나와있는 부분이 있을 텐데 이걸 전부 지워주거나 0.0.0.0으로 변경해준다.

그래야지만 다른 곳에서 아웃룩 등을 이용하여 메일 사용이 가능해진다.

 

저장 후 콘솔에서 m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf 입력

 

그 다음은 sendmail.cf 확인

 

O AuthMechanisms=LOGIN PLAIN DIGEST-MD5 CRAM-MD5  <-주석 되어 있는지 확인 후 주석있으면 제거

 

그 다음은 local-host-names 수정

/etc/mail/local-host-names 파일을 메일을 받을 도메인으로 수정해준다.

 

xxxx.co.kr처럼

 

마지막으로 Sendmail.conf 수정(없으면 생성)

/usr/lib/sasl2/Sendmail.conf 파일을 수정 및 생성하여 아래 내용을 기입한다.

pwcheck_method: saslauthd

 

이상으로 설정이 끝났다.

센드메일과 sasl을 재시작(시작)한다.

 

/etc/init.d/sendmail start(또는 restart)

(우분투는 service sendmail restart)


/etc/init.d/saslauthd start(또는 restart)

(우분투는 service sendmail restart)

 

원래는 access도 수정해야 하지만 smtp인증을 받으면 굳이 access에 RELAY설정을 하지 않아도

메일이 잘 간다.

스팸때문에 sasl를 설정하는 것이라면 access를 아무 것도 없이 하는 것도 좋은 방법인 것 같다.

 

 

 dovecot 설정

 

/etc/dovecot/dovecot.conf를 수정한다.

 

protocols = imap imaps pop3 pop3s

 

dovecot이 메일을 받을 프로토콜을 설정하는 구문이다. pop3만 넣어도 무관하다.

 

listen = *

 

위처럼 하면 모든 포트를 다 열고 대기하겠다는 뜻인것 같다. 자세히는 모르겠다.

 

disable_plaintext_auth = no

 

인증을 사용할지 안 할지를 설정하는 것 같은데 현재는 smtp인증을 사용하므로 no라고 해주면 되겠다.

(안해줘도 되는지는 자세히 모름)

 

mail_location = mbox:~/Maildir:INBOX=/var/mail/%u

 

마지막 설정이다. 메일을 보관할 폴더를 설정하는 부분이다. maildir로 설정할 수도 있는데 현재 dovecot(이 글을 쓰는 시점의 dovecot)은 mbox로 해야지만 제대로 작동한다. ~/Maildir <- 이 부분을 메일을 받기 원하는 디렉토리로 지정하면 된다.

 

설정이 다 끝나면 /etc/init.d/dovecot restart(또는 start)를 해주면 된다.


* pop3테스트(메일 주소로 사용할 메일주소(예, admin)의 OS계정이 미리 생성되어 있어야하며 

해당 계정의 home디렉토리 밑에 /home/admin/Maildir폴더가 메일주소로 사용할 계정으로 (예, admin) 소유자가 

설정되어 있어야 한다)


telnet localhost 110을 실행해서 접속이 되면 실행중인것이다.

(오류발생시 : https://www.gooper.com/ss/index.php?mid=bigdata&category=2809&page=1&document_srl=3497 참조)

 

이제 모든 설정이 다 끝났다. 아웃룩에서 smtp인증을 선택하고 메일을 보내면 끝이다.


추가 : dovecot에 SSL설정하는 방법 : http://blog.naver.com/jinkalee_new/220857802628




 

번호 제목 날짜 조회 수
501 Impala Admission Control 설정시 쿼리가 사용하는 메모리 사용량 판단 방법 2023.05.19 672
500 초기 오류(java.lang.NoSuchMethodError)에 따른 후속 작업에서 오류(java.lang.NoClassDefFoundError)가 발생되는 상황(quartz에서 주기적으로 작업시) 2016.08.29 670
499 compile할때와 exclude할때 대상을 표현하는 명칭이 다르므로 주의할것 2016.08.10 669
498 동시에 많은 요청이 endpoint로 몰려서java.net.NoRouteToHostException가 발생하는 경우의 처리방법 2016.10.17 664
497 [HDFS]Encryption Zone에 생성된 테이블 조회시 Failed to open HDFS file hdfs://nameservice1/tmp/zone1/sec_test_file.txt Error(255): Unknown error 255 Root cause: AuthorizationException: User:impala not allowd to do 'DECRYPT_EEK' on 'testkey' 2023.06.29 663
496 Kafka Offset Monitor로 kafka 상태 모니터링 하기 file 2016.11.08 663
495 Job이 끝난 log을 볼수 있도록 설정하기 2016.05.30 663
494 [Atlas Server]org.apache.hadoop.hbase.security.AccessDeniedException: Insufficient permissions (user=atlas/node01.gooper.com@GOOPER.COM, scope=default:atlas_janus, params=[table=default:atlas_janus,], action-CREATE)] 2023.05.15 659
493 kudu의 내부 table명 변경하는 방법 2022.11.10 655
492 Error: java.lang.RuntimeException: java.lang.OutOfMemoryError 오류가 발생하는 경우 2018.09.20 654
491 db를 통째로 새로운 이름의 db로 복사하는 방법/절차 2017.11.14 652
490 Error: Could not find or load main class nodemnager 가 발생할때 해결하는 방법 2015.06.05 652
489 [Kudu]ERROR: Unable to advance iterator for node with id '2' for Kudu table 'impala::core.pm0_abdasubjct': Network error: recv error from unknown peer: Transport endpoint is not connected (error 107) 2023.03.16 647
488 Container killed by the ApplicationMaster. Container killed on request. Exit code is 143 Container exited with a non-zero exit code 143 TaskAttempt killed because it ran on unusable node 오류시 조치방법 2017.04.06 646
487 [Hive canary]Hive에 Metastore canary red alert및 hive log파일에 Duplicate entry '123456' for key 'NOTIFICATION_LOG_EVENT_ID'가 발생시 조치사항 2023.03.10 645
486 spark-submit 실행시 "java.lang.OutOfMemoryError: Java heap space"발생시 조치사항 2018.02.01 641
485 Scala에서 countByWindow를 이용하기(예제) 2018.03.08 630
484 spark-shell실행시 "A read-only user or a user in a read-only database is not permitted to disable read-only mode on a connection."오류가 발생하는 경우 해결방법 2016.05.20 627
483 Query 1234:1234 expired due to client inactivity(timeout is 5m)및 invalid query handle 2022.06.10 626
482 hive metadata(hive, impala, kudu 정보가 있음) 테이블에서 db, table, owner, location를 조회하는 쿼리 2020.02.07 622
위로