메뉴 건너뛰기

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




 

번호 제목 날짜 조회 수
421 bash는 PS1 변수를 통해 프롬프트의 모양을 바꿀 수 있다. 2016.03.30 514
420 Elastic Search For Hadoop 2.2.0설치하기(5대 클러스터링) 2016.04.04 509
419 elasticsearch 기동시 permission denied on key 'vm.max_map_count' 오류발생시 조치사항 2017.06.23 508
418 Caused by: java.lang.ClassNotFoundException: org.apache.spark.Logging 발생시 조치사항 2017.04.19 508
417 서버중 slave,worker,regionserver만 재기동해야 할때 필요한 기동스크립트및 사용방법 2017.02.03 507
416 Hadoop - 클러스터 세팅및 기동 2015.04.28 506
415 Java 8에서 pom.xml에 JavaDoc 관련 태그가 설정되어 있으나 오류등으로 실패하면 나머지 Maven작업이 종료되는 문제 해결 방법 2017.01.24 504
414 [HIVESERVER2]프로세스의 thread및 stack trace를 덤프하는 방법(pstack, jstack) 2022.05.11 502
413 queryTranslator실행시 NullPointerException가 발생전에 java.lang.ArrayIndexOutOfBoundsException발생시 조치사항 2016.06.16 502
412 mongodb에서 큰데이타 sort시 오류발생에 대한 해결방법 2015.12.22 502
411 java.lang.IllegalArgumentException: Does not contain a valid host:port authority: master 오류해결방법 2015.05.06 502
410 Windows7 64bit 환경에서 Apache Hadoop 2.7.1설치하기 2017.07.26 501
409 Soft memory limit exceeded (at 100.05% of capacity) 오류 조치 2022.01.17 500
408 우분투 서버에 GUI로 접속하기 file 2018.05.27 497
407 원격의 origin/master를 기준으로 dev branch를 만들어 작업후 원격의 origin/dev에 push하는 방법 file 2016.11.22 496
406 [TLS]TLS용 사설 인증서 변경 혹은 신규 지정시 No trusted certificate found 오류 발생시 확인및 조치사항 2022.03.15 495
405 [개발] 온라인 IDE - 개발 환경 구축 없어 어디서나 웹브라우저로 개발하기 2022.05.02 492
404 source, sink를 직접 구현하여 사용하는 예시 2019.05.30 490
403 github에 있는 프로젝트와 로컬에서 작업한 프로젝트 합치기 2016.11.22 490
402 S2RDF를 실행부분만 추출하여 1건의 triple data를 HDFS에 등록, sparql을 sql로 변환, sql실행하는 방법및 S2RDF소스 컴파일 방법 2016.06.15 490
위로