Dyn Email Delivery에서 SendGrid로 마이그레이션하는 방법
게시 됨: 2016-11-23Dyn이 DNS 관리 사업을 위해 Oracle에 인수되었다는 최근 뉴스와 함께 사람들은 완전히 이메일에 초점을 맞춘 솔루션을 찾고 있습니다. 우리 팀은 Dyn 이메일 전송에서 SendGrid로 마이그레이션하는 방법에 대한 질문이 증가했기 때문에 이 가이드를 작성하기로 결정했습니다.
시작하기 전에 둘러보고 싶다면 SendGrid 문서를 확인하세요. 클래스룸은 API 참조 및 세부정보를 살펴보기 전에 이메일에 대해 배울 수 있는 좋은 장소입니다.
우리는 창립 이래 API 우선, 이메일 전용 회사였으며 이것이 우리 제품에 반영되어 있음을 알게 될 것입니다. 당사의 HTTP 이메일 엔드포인트, 웹훅, SMTP 및 비 이메일 API는 당사 비즈니스의 핵심이며 기능에 반영되어 있음을 알 수 있습니다. 이 가이드는 현재 제공업체에 없는 유용한 기능을 강조하면서 SendGrid에서 설정하는 방법에 대한 기본 사항을 제공하는 것을 목표로 합니다.
API 키 가져오기
먼저 SendGrid 계정이 필요합니다. 다음으로 전송에 사용할 API 키를 생성해야 합니다. 설정 -> API 키로 이동하거나 이 링크를 사용하십시오. SendGrid 및 보안 모범 사례는 각기 다른 앱에 대해 서로 다른 API 키를 사용하는 것입니다. API 키에는 세분화된 권한이 있으므로 개별 엔드포인트에 대한 읽기 또는 쓰기 액세스를 활성화하거나 비활성화할 수 있습니다. 생성한 API 키에 Mail Send 에 대한 전체 액세스 권한이 있는지 확인하세요. (참고: API 키를 생성하려면 먼저 계정이 프로비저닝을 통과해야 합니다.)
API 라이브러리
Dyn은 Python 및 PHP로 공식 SDK를 제공하지만 고객이 더 쉽게 통합할 수 있도록 공식적으로 지원되는 7개의 API 라이브러리를 제공합니다. 코드를 다시 작성하거나 마이그레이션의 일부로 ESP와 통신하는 방법을 리팩토링하는 경우 지금이 다음 라이브러리를 평가할 좋은 시간입니다.
- sendgrid-csharp – 공식 C# 라이브러리
- sendgrid-go – 공식 바둑 라이브러리
- sendgrid-java – 공식 자바 라이브러리
- sendgrid-nodejs – 공식 NodeJS 라이브러리
- sendgrid-php – 공식 PHP 라이브러리
- sendgrid-python – 공식 Python 라이브러리
- sendgrid-ruby – 공식 Ruby 라이브러리
SMTP
SMTP를 통해 보내는 경우 몇 가지 차이점을 알고 있어야 합니다. 첫째, Dyn이 요구하는 메시지 크기에 따라 특정 SMTP 서버를 사용하는 것에 대해 걱정할 필요가 없습니다. 또한 Dyn의 10MB 제한에 비해 최대 19.5MB의 메시지를 수락합니다. 인증하려면 'apikey' 문자열을 SMTP 사용자 이름으로 제공하고 API 키를 비밀번호로 사용하십시오. 그런 다음 호스트 이름을 smtp.sendgrid.net 으로 지정하십시오.
또한 Dyn에 비해 추가 포트 옵션을 제공합니다. 포트 25, 2525 및 587에서 암호화되지 않은 또는 TLS를 통해 SMTP를 사용하여 연결할 수 있습니다. 또한 포트 465에서 SSL을 통해 연결할 수도 있습니다. 일반적으로 포트 587을 사용하는 것이 호스팅 공급자와 관련된 문제가 가장 적은 경향이 있기 때문에 권장합니다.
SMTP를 통해 전송된 이메일을 사용자 지정하는 메커니즘은 X-SMTPAPI 헤더입니다. 이 헤더를 사용하면 키/값 대체를 정의하고, 일괄 메일 병합 스타일 요청을 보내고, 보내기에 대해 활성화된 필터(클릭 추적 등)를 제어할 수 있습니다. 카테고리별로 이메일을 그룹화하거나 unique_args를 사용하여 이메일당 메타데이터를 추적할 수 있습니다. 이메일 트랜잭션에 필요한 전송 시간과 대역폭의 양을 줄일 수 있는 강력한 기능이며 탐색할 가치가 있습니다.
HTTP
이메일을 보내기 위한 기본 끝점은 메일/보내기 끝점입니다. 이 끝점에 대한 요청은 API 키가 전달자 토큰으로 제공된 권한 부여 헤더를 통해 인증됩니다. 문서에서 더 자세한 예를 찾을 수 있습니다.
Dyn의 HTTP API에 비해 엔드포인트는 수신자를 사용자 지정 및 관리할 수 있는 더 많은 기능을 제공하며 단일 요청으로 여러 메시지를 보낼 수도 있습니다.
개인화를 사용하면 콘텐츠 사용자 지정을 위한 대체 값 또는 사용자 ID 또는 주문 번호와 메시지를 연결하기 위한 custom_args와 같은 각 메시지에 대한 수신자 및 메타데이터를 정의할 수 있습니다. 일반적인 사용 사례에 대한 개인화의 여러 예가 있습니다. cURL 예제 호출을 찾을 수도 있습니다.
클릭 추적과 같은 기능은 tracking_settings 및 mail_settings 매개변수를 통해 구성됩니다. "send_at" 매개변수를 사용하여 최대 72시간 전에 전송을 예약할 수도 있습니다.
또한 API 요청에 첨부 파일을 매우 쉽게 추가할 수 있습니다. 파일을 Base64 문자열로 인코딩하고 MIME 콘텐츠 정보와 함께 JSON 페이로드에 직접 포함하기만 하면 됩니다. Documentation Classroom의 다음 섹션에서 첨부 파일을 포함하는 방법에 대해 자세히 알아볼 수 있습니다.
웹훅
SendGrid는 수신 거부, 반송 등과 같은 실시간 이메일 이벤트를 게시하기 위한 Event Webhook과 이메일을 수신하고 이에 프로그래밍 방식으로 응답하기 위한 Inbound Parse Webhook의 두 가지 웹훅을 제공합니다.
이러한 기능은 Dyn에서 사용할 수 없지만 이메일 관리에 자동화를 추가하는 데 유용할 수 있습니다. 설정을 시작할 때 살펴볼 가치가 있습니다.
이메일이 아닌 API 엔드포인트
이메일을 보내지 않는 API 엔드포인트의 경우 API v3 개요를 확인하세요. 우리는 대부분의 경우 직관적인 HTTP 메서드와 응답 코드를 사용하고 호출에 대한 속도 제한을 적용합니다. API v2는 더 이상 사용되지 않지만 지원을 중지할 일정은 없습니다. 모든 새로운 통합은 v3를 선호해야 합니다. API v3 인증은 Bearer 토큰이 있는 인증 헤더로 수행됩니다.
마케팅 캠페인
우리가 제공하는 또 다른 기능은 목록을 관리하고, 동적 세그먼트를 만들고, 자산을 업로드하고, 시각적 편집기로 이메일 템플릿을 디자인하고, 자동 A/B 테스트 등을 수행할 수 있는 강력한 마케팅 캠페인 플랫폼입니다. 물론 이러한 모든 기능 뒤에는 개방형 API도 있습니다.
몇 가지 자주 묻는 질문
Q: 거래 이메일용 템플릿을 지원합니까?
A: 그렇습니다. 그리고 그것들은 역동적입니다! SendGrid의 트랜잭션 템플릿은 Handlebars 구문을 기본적으로 지원합니다. 기본 대체 및 대체 외에도 목록에 대한 열거/반복을 사용하고 조건문 등을 활용할 수 있습니다. 자세히 알아보려면 여기를 클릭하세요.
Q: 샌드박스나 이메일을 보내지 않고 테스트할 수 있는 방법이 있습니까?
A: HTTP를 통해 보낼 때 샌드박스 모드를 활성화할 수 있습니다. 테스트에 사용할 수 있는 "싱크" 주소도 있습니다.
Q: 내 IP 주소/발신자 평판을 SendGrid로 전송할 수 있습니까?
A: IP 또는 평판을 마이그레이션할 수는 없지만 자동으로 새 IP를 워밍업하도록 도와드릴 수 있습니다.
Q: SendGrid는 강제 TLS 를 지원합니까 ?
A: 물론입니다. 수신 서버가 TLS를 지원하도록 요구하고 준수하지 않는 서버로 가는 메시지를 삭제할 수 있습니다.
Q: 수신자가 수신하려는 이메일 유형을 정의하도록 허용할 수 있습니까?
A: 네. 수신자에게 이메일에 대한 더 많은 제어 권한을 부여하면 사람들이 원하는 이메일을 보낼 수 있으므로 모두에게 더 좋습니다. 자세한 내용은 구독 취소 그룹을 확인하세요.
SendGrid로 마이그레이션하는 데 관심이 있는 경우 sendgrid.com/pricing에서 자세한 정보를 찾을 수 있습니다.