이럴때를 위해 맥북에서는 ssh를 미리 저장해 놓고 alias 만으로 접속하는 기능이 있습니다.
맥북의 .ssh/config 파일을 사용하면 여러 서버에 대한 SSH 접속 설정을 간결하게 관리하고, 짧은 별칭(alias)으로 쉽게 접속할 수 있습니다. 이는 특히 여러 원격 서버나 여러 GitHub 계정을 관리할 때 매우 유용합니다.
.ssh/config 파일 생성 또는 열기
맥(macOS)의 경우 .ssh/config 파일이 자동으로 생성되어 있지 않을 수 있습니다. 이 경우 직접 파일을 생성해야 합니다.
touch ~/.ssh/config
open ~/.ssh/config
.ssh/config 파일 내용 작성
파일을 열고 아래와 같은 형식으로 각 서버의 접속 정보를 입력합니다.
Host [별칭]
HostName [원격 서버의 IP 주소 또는 도메인 이름]
User [접속할 사용자 계정]
IdentityFile [SSH 키 파일 경로]
Port [SSH 포트 번호 (기본값 22, 변경된 경우)]
Host: 이 별칭은 SSH 접속 시 사용할 짧은 이름(alias)이 됩니다.
HostName: 접속할 원격 서버의 IP 주소 또는 도메인 이름을 입력합니다.
User: 원격 서버에 접속할 사용자 계정 이름을 입력합니다.
IdentityFile: 해당 서버에 접속할 때 사용할 SSH 키 파일의 경로를 지정합니다. 예를 들어, ~/.ssh/your_key.pem과 같이 입력할 수 있습니다 . AWS EC2와 같은 경우 pem 키 파일을 다운로드하여 권한을 변경한 후 사용합니다.
권한은 다음 명령을 사용하여 변경합니다.
chmod 600 your_key_file.pem
권한을 변경하지 않으면 다음과 같은 메시지가 나옵니다.
Permissions 0644 for '/Users/admin/.ssh/id_rsa' are too open.
It is required that your private key files are NOT accessible by others.
This private key will be ignored.
Load key "/Users/admin/.ssh/id_rsa.pub": bad permissions
git@github.com: Permission denied (publickey).
Port: SSH 접속에 사용되는 포트 번호입니다. 기본값은 22이며, 변경된 경우에만 작성합니다.
Github의 경우 HostName과 User명은 아래와 같이 동일한 값을 사용합니다.
HostName github.com
User git
예시:
# 개인 GitHub 계정
Host github.com-personal
HostName github.com
User git
IdentityFile ~/.ssh/id_rsa_personal
# 회사 GitHub 계정
Host github.com-work
HostName github.com
User git
IdentityFile ~/.ssh/id_rsa_work
# 개발 서버
Host dev_server
HostName 192.168.0.1
User ubuntu
IdentityFile ~/.ssh/dev_server_key.pem
Port 2222
# Amazon Linux 2003 EC2
Host aws-ec2
HostName ec2-1-100-200-333.ap-northeast-2.compute.amazonaws.com
User ec2-user
IdentityFile ~/myec2.pem
n8n은 n8n 사이트에 가입해서 서비스를 사용할 수도 있고, 직접 셀프 호스팅으로 설치해서 사용할 수도 있습니다. 가격은 Starter가 월24유로(약38,000원), Pro가 월60유로(약96,000원)으로 꽤 비용이 나가는 편입니다. https://n8n.io/pricing/
services:
n8n:
image: docker.n8n.io/n8nio/n8n # n8n Docker 이미지 사용
restart: always # 컨테이너 종료 시 항상 재시작
ports:
- "5678:5678" # 호스트의 5678 포트를 컨테이너의 5678 포트에 연결 (n8n 기본 포트)
environment:
# n8n 라이선스 키 (선택 사항, 없으면 기본 기능으로 실행)
# - N8N_LICENSE_KEY=YOUR_LICENSE_KEY
# 데이터베이스 설정 (PostgreSQL 사용 권장)
- DB_TYPE=postgresdb
- DB_POSTGRESDB_HOST=n8n_db
- DB_POSTGRESDB_PORT=5432
- DB_POSTGRESDB_DATABASE=n8n_database
- DB_POSTGRESDB_USER=n8n_user
- DB_POSTGRESDB_PASSWORD=your_n8n_db_password # 안전한 비밀번호로 변경!
# 웹훅 URL 설정 (선택 사항이지만 외부 접근 시 중요)
- N8N_HOST=your.domain.com # n8n에 접속할 도메인 주소
- N8N_PROTOCOL=https # HTTPS 사용 시
- WEBHOOK_URL=https://your.domain.com/ # 웹훅 URL
volumes:
- ~/.n8n:/home/node/.n8n # n8n 데이터를 호스트에 영구 저장 (볼륨 마운트)
n8n_db: # PostgreSQL 데이터베이스 서비스
image: postgres:13 # PostgreSQL 13 버전 이미지 사용
restart: always
environment:
- POSTGRES_DB=n8n_database
- POSTGRES_USER=n8n_user
- POSTGRES_PASSWORD=your_n8n_db_password # n8n 서비스의 DB_POSTGRESDB_PASSWORD와 동일하게 설정
volumes:
- pg_data:/var/lib/postgresql/data # PostgreSQL 데이터를 호스트에 영구 저장 (볼륨 마운트)
volumes:
pg_data: # PostgreSQL 데이터 볼륨 정의
입력이 완료되면 vi editor에서 esc를 누른 후 다음 명령을 입력하여 저장합니다.
:wq
n8n 컨테이너 실행
docker-compose.yml 파일이 있는 디렉토리에서 다음 명령어를 실행합니다
docker-compose up -d
컨테이너가 잘 실행되었는지는 아래 명령어를 사용합니다.
docker-compose ps
컨테이너 로그도 확인해 줍니다.
docker-compose logs
도메인 설정하기
n8n에서 사용할 도메인은 agent.codegear.info입니다. 이를 위해 AWS Route53에 A 레코드 생성해야 합니다. 생성방법은 다음과 같습니다.
codegear.info 호스팅 영역 클릭:
"호스팅 영역" 목록에서 codegear.info를 클릭하여 상세 페이지로 들어갑니다.
레코드 생성:
"레코드 생성(Create record)" 버튼을 클릭합니다.
레코드 설정:
레코드 이름(Record name):
agent를 입력합니다. 이렇게 하면 agent.codegear.info가 됩니다. (루트 도메인 codegear.info에 연결하려면 비워둡니다.)
레코드 유형(Record type):
A - IPV4 주소로 트래픽 라우팅을 선택합니다. (도메인을 IP 주소에 연결하는 가장 일반적인 유형입니다.)
값(Value):
Nginx 및 N8N이 설치된 AWS EC2 인스턴스의 퍼블릭 IP 주소를 입력합니다. (가급적 탄력적 IP 주소를 사용하는 것을 권장합니다. 탄력적 IP는 인스턴스 재부팅 시 IP가 변경되지 않습니다.)
예: 52.78.XXX.XXX
TTL(Time to Live):
기본값 (300초)을 유지하거나 원하는 값으로 설정합니다. TTL이 짧을수록 DNS 변경 사항이 더 빨리 전파되지만, DNS 서버에 더 많은 부하를 줍니다.
라우팅 정책(Routing policy):
단순 라우팅(Simple routing)을 유지합니다.
레코드 생성:
"레코드 생성" 버튼을 클릭하여 설정을 저장합니다.
DNS 전파 확인
터미널을 열어 다음 명령으로 DNS 전파를 확인할 수 있습니다.
nslookup agent.codegear.info
Nginx 설정
Nginx 설정 파일 구조 이해
Amazon Linux 2023의 Nginx는 일반적으로 /etc/nginx/nginx.conf가 메인 설정 파일이고, 이 파일 안에서 include /etc/nginx/conf.d/*.conf; 지시어를 통해 /etc/nginx/conf.d/ 디렉토리 안의 .conf 파일들을 불러옵니다. 따라서 우리는 주로 /etc/nginx/conf.d/agent.codegear.info.conf와 같은 별도의 파일을 생성하여 도메인별 설정을 관리하는 것이 좋습니다.
새로운 Nginx 설정 파일 생성: SSH로 EC2 인스턴스에 접속한 후, 다음 명령어를 사용하여 /etc/nginx/conf.d/ 디렉토리에 agent.codegear.info.conf 파일을 생성하고 편집합니다.
파일 내용 붙여넣기: vi 에디터에 다음 내용을 붙여넣으세요. 이 설정은 agent.codegear.info에 대한 HTTP/HTTPS 처리 및 N8N으로의 리버스 프록시를 담당합니다.내용을 붙여넣은 후 ecs를 누르고 :wq! 엔터를 입력하여 저장하고 종료합니다.
server {
listen 80;
listen [::]:80;
server_name agent.codegear.info;
# Certbot will use this location to verify domain ownership
location /.well-known/acme-challenge {
allow all;
root /usr/share/nginx/html; # Ensure this directory exists and is readable by Nginx
}
}
Certbot 실행 (필수): 위 Nginx 설정 파일은 agent.codegear.info에 대한 SSL 인증서가 /etc/letsencrypt/live/agent.codegear.info/ 경로에 있다고 가정합니다. 이 인증서는 Certbot을 실행해야 발급됩니다.
Certbot이 agent.codegear.info 도메인을 인식하고, 해당 도메인에 대한 SSL 인증서를 발급받은 후, agent.codegear.info.conf 파일 내의 ssl_certificate와 ssl_certificate_key 경로를 자동으로 채우거나 확인해 줍니다.
HTTP 트래픽을 HTTPS로 리디렉션할지 물으면 2: Redirect를 선택하는 것이 좋습니다.
sudo certbot --nginx -d agent.codegear.info
Nginx 설정 테스트 및 재시작: 이제 새로운 설정 파일이 올바른지 확인하고 Nginx를 다시 시작하여 변경 사항을 적용합니다.sudo nginx -t 명령어가 syntax is ok와 test is successful을 반환해야 합니다.
sudo nginx -t # Nginx 설정 파일 문법 검사
sudo systemctl restart nginx # Nginx 서비스 재시작
Certbot이 설정 파일에 SSL 관련된 셋팅을 자동으로 추가했으므로 이부분에 n8n이 사용하는 5678 포트로 redirect 처리가 필요합니다. 아래 내용을 ssl 아래에 추가하면 됩니다.
# --- Proxy headers for N8N ---
# Ensures N8N gets correct client IP, protocol, and host information.
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
# --- WebSocket support for N8N UI ---
# Crucial for N8N's real-time updates and interactive UI.
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
# --- Reverse proxy to N8N ---
location / {
proxy_pass http://localhost:5678/; # <-- Updated N8N internal port
proxy_http_version 1.1;
proxy_buffering off;
proxy_read_timeout 300s; # Increased timeout for long-running workflows
proxy_send_timeout 300s;
}
전체 설정 파일은 다음과 같습니다.
# --- HTTP Block: Handles HTTP requests and redirects to HTTPS ---
server {
listen 80;
listen [::]:80; # IPv6 listening
server_name agent.codegear.info;
# Certbot's domain validation challenge location.
# This must be present in the HTTP block to allow Certbot to renew certificates.
location ~ /.well-known/acme-challenge {
allow all;
root /usr/share/nginx/html; # Ensure this path is correct and accessible
}
# All other HTTP requests are permanently redirected to HTTPS.
# Certbot usually inserts/modifies this.
return 301 https://$host$request_uri;
}
# --- HTTPS Block: Handles secure (HTTPS) requests and proxies to N8N ---
server {
listen 443 ssl;
listen [::]:443 ssl; # IPv6 listening
http2 on; # Correct way to enable HTTP/2
server_name agent.codegear.info;
# --- Let's Encrypt (Certbot) managed SSL certificate paths ---
# These paths are filled in by Certbot after successful certificate issuance.
ssl_certificate /etc/letsencrypt/live/agent.codegear.info/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/agent.codegear.info/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf; # Certbot's recommended SSL options
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # Diffie-Hellman parameters for stronger security
# --- Proxy headers for N8N ---
# Ensures N8N gets correct client IP, protocol, and host information.
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
# --- WebSocket support for N8N UI ---
# Crucial for N8N's real-time updates and interactive UI.
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
# --- Reverse proxy to N8N ---
location / {
proxy_pass http://localhost:5678/; # <-- Updated N8N internal port
proxy_http_version 1.1;
proxy_buffering off;
proxy_read_timeout 300s; # Increased timeout for long-running workflows
proxy_send_timeout 300s;
}
# Optional: Error pages
# error_page 404 /404.html;
# location = /404.html { }
# error_page 500 502 503 504 /50x.html;
# location = /50x.html { }
}
1년 이상일 경우는 가격이 비슷하겠지만, 1년 사용료는 가격 차이가 꽤 납니다. 그러니 사이트 별로 꼭 비교하여 구매하시기 바랍니다.
AWS에 도메인 등록하기
Route 53을 DNS 서비스로 사용하고 기존 등록 기관은 유지하는 방법
이 방법은 도메인 등록 기관(예: 가비아, 후이즈, Godaddy 등)은 그대로 유지하되, 해당 도메인의 DNS 관리를 Route 53으로 위임하는 방식입니다.
AWS Route 53에서 "호스팅 영역" 생성:
AWS 콘솔에 로그인하여 Route 53 서비스로 이동합니다.
왼쪽 메뉴에서 "호스팅 영역"을 선택하고 "호스팅 영역 생성" 버튼을 클릭합니다.
"도메인 이름" 필드에 다른 곳에서 구매한 도메인 이름을 정확하게 입력합니다 (예: codegear.info).
"유형"은 "퍼블릭 호스팅 영역"으로 선택합니다.
"호스팅 영역 생성"을 클릭합니다.
Route 53에서 제공하는 네임서버(NS) 확인:
호스팅 영역이 생성되면 해당 호스팅 영역을 클릭하여 상세 정보를 확인합니다.
여기서 **NS (Name Server)** 유형의 레코드를 찾아 "값/트래픽 라우팅 대상"에 나열된 4개의 네임서버 주소를 확인합니다. 이 주소들이 바로 Route 53이 해당 도메인의 DNS 관리를 위해 제공하는 고유한 네임서버입니다. (예: `ns-xxxx.awsdns-xx.com.`, `ns-xxxx.awsdns-xx.net.`, `ns-xxxx.awsdns-xx.org.`, `ns-xxxx.awsdns-xx.co.uk.`)
**주의:** 네임서버 주소 마지막에 있는 온점(`.`)은 제외하고 복사합니다.
기존 도메인 등록 기관에서 네임서버 변경:
도메인을 구매했던 등록 기관(예: 가비아, 후이즈 등) 웹사이트에 로그인합니다.
도메인 관리 또는 네임서버 변경 메뉴로 이동합니다.
기존에 설정되어 있던 네임서버를 Route 53에서 복사한 4개의 네임서버 주소로 변경합니다. 등록 기관에 따라 네임서버를 1차, 2차, 3차, 4차 등으로 구분하여 입력하는 칸이 있을 수 있습니다. 각 칸에 맞게 입력합니다.
변경 사항을 저장합니다.
주의사항:
네임서버 변경은 전파(Propagation)되는 데 최대 48시간이 소요될 수 있습니다. 이 기간 동안 도메인 접속이 불안정할 수 있습니다. (경험상 이렇게까지 걸리지 않습니다. 보통 1시간 정도면 대부분 전파가 됩니다)
DNS 레코드를 추가할 때 TTL(Time To Live) 값을 적절히 설정해야 합니다. 값이 낮을수록 DNS 변경 사항이 빠르게 적용되지만, DNS 서버에 부하를 줄 수 있습니다. 일반적으로 웹사이트 연결에는 300초(5분) ~ 3600초(1시간) 정도가 적당합니다.
"인스턴스(Instance)" 드롭다운에서 탄력적 IP를 연결하고자 하는 실행 중인 EC2 인스턴스를 선택합니다. (인스턴스가 중지되어 있으면 목록에 표시되지 않을 수 있습니다.)
"프라이빗 IP 주소(Private IP address)"는 일반적으로 선택한 인스턴스의 기본 프라이빗 IP 주소가 자동으로 채워집니다. 변경할 필요 없습니다.
"연결(Associate)" 버튼을 클릭합니다.
연결 확인:
연결이 성공하면 "탄력적 IP" 목록에서 해당 IP 주소 옆에 "연결된 인스턴스 ID"가 표시됩니다.
EC2 대시보드의 "인스턴스(Instances)" 메뉴로 돌아가서 해당 인스턴스를 클릭합니다. 인스턴스 상세 정보의 "세부 정보(Details)" 탭에서 "탄력적 IP 주소(Elastic IP address)" 항목에 방금 연결한 IP 주소가 표시되는 것을 확인할 수 있습니다.
도메인을 서버에 연결
Route 53 호스팅 영역에 DNS 레코드 추가:
이제 원하는 AWS 서비스(예: EC2, S3, Amplify 등)에 트래픽을 라우팅하기 위한 레코드를 Route 53 호스팅 영역에 추가해야 합니다.
웹사이트 연결 (탄력적 IP 주소 사용):
"레코드 생성"을 클릭합니다.
"레코드 이름": `www` 또는 비워두면 도메인 자체를 의미합니다.
"레코드 유형": `A - IPv4 주소 및 일부 AWS 리소스로 트래픽 라우팅`을 선택합니다.
"값": 연결하고자 하는 EC2 인스턴스의탄력적 IP 주소를 입력합니다.
"라우팅 정책": "단순 라우팅"을 선택합니다.
"레코드 생성"을 클릭합니다.
Load Balancer, S3 버킷, CloudFront 등 연결:
"레코드 유형": `A` 또는 `AAAA`를 선택한 후 "별칭"을 "예"로 설정하고 연결하려는 AWS 리소스를 선택합니다. (Load Balancer, S3 웹사이트 호스팅, CloudFront 배포 등은 별칭 레코드를 통해 쉽게 연결할 수 있습니다.)
서브 도메인 연결 (CNAME):
`blog.mydomain.com`과 같은 서브 도메인을 연결하려면 "레코드 유형"을 `CNAME`으로 선택하고 "값"에 대상 도메인 이름을 입력합니다.
AWS EC2에 Nginx 설치하기
SSH로 EC2 인스턴스에 접속하기:
1.터미널 (macOS/Linux) 또는 PuTTY (Windows) 준비:
macOS/Linux: 터미널을 엽니다.
Windows: PuTTY 또는 Windows Terminal에서 OpenSSH 클라이언트를 사용할 수 있습니다. PuTTY를 사용하려면 `pem` 파일을 `ppk` 파일로 변환해야 합니다 (`PuTTYgen` 사용).
HTTP (80번 포트) 및 HTTPS (443번 포트) 인바운드 규칙으로 외부에서 Nginx 웹 서버에 접속할 수 있습니다.
7. Nginx 기본 페이지 확인
웹 브라우저를 열고 EC2 인스턴스의 퍼블릭 IP 주소 또는 퍼블릭 DNS를 입력합니다. http://your-instance-ip
정상적으로 설치되었다면 Nginx의 기본 환영 페이지가 표시될 것입니다.
이제 Amazon Linux 2023에 Nginx가 성공적으로 설치되었으며, 웹 서버로 사용할 준비가 완료되었습니다. Nginx 설정 파일은 /etc/nginx/nginx.conf에 있으며, 가상 호스트 설정 등은 /etc/nginx/conf.d/ 디렉토리에 .conf 파일을 생성하여 관리하는 것이 일반적입니다.
Nginx SSL 적용하기
Nginx에 SSL/TLS를 적용하여 HTTPS를 사용하면 웹사이트의 보안을 강화하고 사용자 데이터를 보호할 수 있습니다. 가장 일반적이고 권장되는 방법은 Let's Encrypt에서 무료 SSL 인증서를 발급받고, Certbot 도구를 사용하여 Nginx에 자동으로 적용하는 것입니다.
Amazon Linux 2023 환경에서 Certbot을 사용하여 Nginx에 SSL을 적용하는 단계를 안내해 드리겠습니다.
준비물:
도메인:SSL을 적용할 도메인 이름 (예: example.com).
DNS 설정:해당 도메인이 Nginx 서버의 퍼블릭 IP 주소를 가리키도록 DNS A 레코드가 설정되어 있어야 합니다. (설치 전 필수)
Nginx 설치 및 실행:앞서 설명한 대로 Nginx가 Amazon Linux 2023에 설치되어 실행 중이어야 합니다.
보안 그룹 및 방화벽:AWS EC2 인스턴스의 보안 그룹에서HTTP (80번 포트)와HTTPS (443번 포트)인바운드 규칙이 열려 있어야 합니다.
Nginx SSL 적용 (Certbot 사용):
1. Certbot 설치
Certbot은 Let's Encrypt 인증서를 쉽고 자동으로 발급하고 Nginx에 적용할 수 있도록 도와주는 도구입니다. Amazon Linux 2023에서는 dnf를 사용하여 설치할 수 있습니다.
Bash
# EPEL(Extra Packages for Enterprise Linux) 저장소 활성화 (Certbot이 EPEL에 있을 수 있습니다)
sudo dnf install epel-release -y
# Certbot 및 Nginx 플러그인 설치
# Amazon Linux 2023에서는 python3-certbot-nginx 대신 python-certbot-nginx 일 수 있습니다.
# 먼저 아래 명령을 시도하고 실패하면 'python-certbot-nginx'로 시도하세요.
sudo dnf install certbot python3-certbot-nginx -y
만약 python3-certbot-nginx가 없다는 오류가 발생하면, python-certbot-nginx로 다시 시도하거나, Certbot 공식 웹사이트에서 제공하는 Amazon Linux용 설치 지침을 확인하는 것이 가장 좋습니다. (현재 시간 기준으로는 python3-certbot-nginx가 일반적입니다.)
2. Nginx 설정 확인
Certbot이 Nginx 설정을 자동으로 수정하려면, Nginx가 올바르게 구성되어 있어야 합니다. 특히, 도메인 이름이 server_name 지시문에 명시되어 있어야 합니다.
기본 설정 파일은 /etc/nginx/nginx.conf 또는 /etc/nginx/conf.d/default.conf에 있을 수 있습니다. 예를 들어, default.conf 파일을 열어 편집합니다.
sudo vi /etc/nginx/nginx.conf
# 또는
sudo vi /etc/nginx/conf.d/default.conf
http 블록 내에 다음과 유사한 server 블록이 있는지 확인합니다 (아직 HTTPS 설정은 하지 않습니다):
server {
listen 80;
server_name your_domain.com www.your_domain.com; # 여기에 실제 도메인 이름을 입력하세요
# 기타 설정 (root, index, location 등)
# ...
}
변경 사항을 저장하고 Nginx 설정 구문이 올바른지 확인합니다.
sudo nginx -t
syntax is ok와 test is successful 메시지가 표시되어야 합니다.
Nginx를 다시 로드합니다.
sudo systemctl reload nginx
3. SSL 인증서 발급
이제 Certbot을 사용하여 Let's Encrypt 인증서를 발급받고 Nginx에 적용합니다.
sudo certbot --nginx
이 명령을 실행하면 Certbot이 몇 가지 질문을 할 것입니다:
이메일 주소:인증서 갱신 알림 및 보안 관련 통지를 받을 이메일 주소를 입력합니다.
서비스 약관 동의:약관에 동의합니다.
도메인 선택:Certbot이 Nginx 설정에서 감지한 도메인 목록이 표시됩니다. SSL을 적용할 도메인 번호를 선택하거나 all을 입력하여 모두 적용합니다.
예시: 1: your_domain.com 2: www.your_domain.com 원하는 도메인 번호를 쉼표로 구분하여 입력하거나, 1,2와 같이 입력할 수 있습니다.
HTTP -> HTTPS 리디렉션 설정:Certbot이 HTTP(80번 포트)로 들어오는 모든 요청을 HTTPS(443번 포트)로 자동으로 리디렉션할지 물어봅니다. **"2: Redirect"**를 선택하는 것이 좋습니다.
성공적으로 완료되면 Certbot이 인증서가 발급되었고 Nginx 설정이 업데이트되었다는 메시지를 표시합니다. 인증서는 /etc/letsencrypt/live/your_domain.com/ 경로에 저장됩니다.
4. Nginx 설정 자동 업데이트 확인
Certbot이 Nginx 설정 파일 (예: /etc/nginx/conf.d/default.conf 또는 새로운 설정 파일)을 자동으로 수정합니다. 변경된 내용은 다음과 유사할 것입니다:
server {
listen 80;
server_name your_domain.com www.your_domain.com;
return 301 https://$host$request_uri; # HTTP -> HTTPS 리디렉션
}
server {
listen 443 ssl http2; # HTTPS (443) 포트 및 HTTP/2 활성화
server_name your_domain.com www.your_domain.com;
ssl_certificate /etc/letsencrypt/live/your_domain.com/fullchain.pem; # 전체 인증서 체인
ssl_certificate_key /etc/letsencrypt/live/your_domain.com/privkey.pem; # 개인 키
include /etc/letsencrypt/options-ssl-nginx.conf; # Certbot이 제공하는 보안 설정
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # DH 매개변수 (보안 강화)
# 기타 설정 (root, index, location 등)
# ...
}