찾다
운영 및 유지보수엔진스Nginx 역방향 프록시의 SNI 기반 SSL 솔루션

Nginx 역방향 프록시의 SNI 기반 SSL 솔루션

Jun 10, 2023 pm 09:57 PM
nginx 리버스 프록시SSL 솔루션sni

Nginx 역방향 프록시의 SNI 기반 SSL 솔루션

인터넷 기술의 발전으로 웹 애플리케이션의 보안 문제가 점점 더 주목을 받고 있습니다. SSL 인증서는 데이터 전송 보안을 제공하는 암호화 기술로 웹 애플리케이션을 보호하는 중요한 수단 중 하나가 되었습니다. 일부 특별한 경우에는 동일한 서버에 여러 개의 SSL 인증서를 배포해야 합니다. 이때 필요에 따라 SNI 기반 SSL 솔루션이 등장합니다.

1. SNI(서버 이름 표시)란 무엇입니까?

SNI는 클라이언트가 SSL 연결을 설정할 때 "클라이언트 Hello" 메시지에 확장 필드를 포함시켜 클라이언트가 원하는 것을 서버에 알릴 수 있도록 하는 TLS 확장 프로토콜입니다. 연결합니다. 단일 IP 주소 및 포트에서 여러 도메인 이름이 동시에 서로 다른 SSL 인증서를 사용할 수 있습니다.

그러나 SNI는 모든 브라우저와 서버에서 지원되지 않습니다. SNI를 사용하는 경우 클라이언트와 서버가 동일한 SSL 프로토콜 버전을 지원하는지 확인해야 하며 클라이언트는 SNI 확장을 지원해야 합니다. Chrome, Firefox, IE7 이상, Opera 등 현재 일반적으로 사용되는 브라우저는 모두 SNI를 지원합니다.

2. Nginx 역방향 프록시 및 SSL

Nginx는 고성능 웹 서버이며 역방향 프록시를 지원합니다. 역방향 프록시는 다른 서버에 요청을 보내고 요청자에게 응답을 반환하는 정보 보안 기술입니다. 역방향 프록시 서버는 로드 균형 조정 및 SSL 암호화도 활성화합니다.

역방향 프록시 서버는 프런트엔드 웹 서버 및 백엔드와 통신하는 중간 계층 역할을 합니다. Nginx는 http와 https의 두 가지 서비스 모드를 지원합니다. https 서비스를 사용하는 경우 SSL 암호화 및 복호화가 필요합니다.

Nginx의 SSL 지원에는 단일 SSL 인증서 모드와 SNI 기반 다중 인증서 모드의 두 가지 모드가 있습니다. 단일 SSL 인증서 모드에서는 하나의 SSL 인증서만 사용할 수 있습니다. 즉, 다른 SSL 인증서를 다른 도메인 이름에 사용할 수 없습니다. SNI 기반 다중 인증서 모드에서는 다중 도메인 SSL 암호화 전송이 가능합니다.

3. SNI 기반 SSL 솔루션

  1. SSL 인증서 생성

먼저 SSL 인증서를 신청하고 해당 인증서 체인과 개인 키를 생성해야 합니다. 여기서는 두 개의 도메인 이름 abc.com 및 xyz.com을 사용하고 각각 두 개의 인증서를 생성한다고 가정합니다.

인증서 생성:

openssl req -newkey rsa:2048 -nodes -keyout abc.com.key -out abc.com.csr
openssl x509 -req -days 365 -in abc.com.csr -signkey abc.com .key -out abc.com.crt

openssl req -newkey rsa:2048 -nodes -keyout xyz.com.key -out xyz.com.csr
openssl x509 -req -days 365 -in xyz.com.csr - signkey xyz.com.key -out xyz.com.crt

인증서 체인 생성:

cat abc.com.crt domain.crt > abc.com-bundle.crt
cat xyz.com.crt domain.crt > ;

ssl_session_timeout 10m;
  1. # SSL 인증서 구성
  2. server {
listen 443 ssl;
server_name abc.com;
ssl_certificate /path/to/abc.com-bundle.crt;
ssl_certificate_key /path/to/abc.com.key;

}

server {

listen 443 ssl;
server_name xyz.com;
ssl_certificate /path/to/xyz.com-bundle.crt;
ssl_certificate_key /path/to/xyz.com.key;

}
}

각각 다른 SSL 인증서를 사용하려면 구성 파일에 ssl_certificate 및 ssl_certificate_key를 지정하세요. 동시에 각 도메인 이름에 대해 서버 블록을 구성해야 합니다.


구성 확인

Nginx를 다시 시작한 후 구성이 적용되는지 확인할 수 있습니다. 브라우저에 abc.com 및 xyz.com을 입력하면 브라우저는 TLS 핸드셰이크 단계 중에 SNI 요청을 보내고 해당 SSL 인증서를 반환합니다. 요청이 정상적으로 반환되면 SNI 기반 SSL 솔루션이 적용된 것입니다.

4. 요약

SNI 기반 SSL 솔루션은 동일한 서버에 여러 SSL 인증서를 배포할 수 있으며, 이는 다중 도메인 SSL 암호화를 사용해야 하는 시나리오에 적합합니다. 그러나 SNI는 모든 브라우저와 서버에서 지원되지 않으므로 이를 사용할 때 클라이언트와 서버가 동일한 SSL 프로토콜 버전을 지원하는지 확인해야 하며 클라이언트는 SNI 확장을 지원해야 합니다. 구성 프로세스 중에 각 도메인 이름에 대한 서버 블록을 구성하고 해당 SSL 인증서와 개인 키를 지정해야 합니다.

위 내용은 Nginx 역방향 프록시의 SNI 기반 SSL 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
nginx를 시작하는 방법nginx를 시작하는 방법Apr 14, 2025 pm 01:06 PM

질문 : nginx를 시작하는 방법? 답변 : nginx 스타트 업 설치 nginx verification nginx is nginx 시작 다른 시작 옵션을 자동으로 시작합니다.

nginx가 시작되었는지 확인하는 방법nginx가 시작되었는지 확인하는 방법Apr 14, 2025 pm 01:03 PM

nginx가 시작되었는지 확인하는 방법 : 1. 명령 줄을 사용하십시오 : SystemCTL 상태 nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. 포트 80이 열려 있는지 확인하십시오. 3. 시스템 로그에서 nginx 시작 메시지를 확인하십시오. 4. Nagios, Zabbix 및 Icinga와 같은 타사 도구를 사용하십시오.

nginx를 닫는 방법nginx를 닫는 방법Apr 14, 2025 pm 01:00 PM

Nginx 서비스를 종료하려면 다음 단계를 따르려면 다음 단계를 결정합니다. Red Hat/Centos (SystemCTL 상태 NGINX) 또는 Debian/Ubuntu (서비스 NGINX 상태) 서비스 중지 : Red Hat/Centos (SystemCTL STOP NGINX) 또는 DEBIAN/UBUNTU (서비스 NGINX STOP) DIA AUTAL STARTUP (옵션) : RED HAT/CENTOS (SystemCTLED) 또는 DEBIAN/UBUNT (SystemCTLED). (Syst

Windows에서 nginx를 구성하는 방법Windows에서 nginx를 구성하는 방법Apr 14, 2025 pm 12:57 PM

Windows에서 Nginx를 구성하는 방법은 무엇입니까? nginx를 설치하고 가상 호스트 구성을 만듭니다. 기본 구성 파일을 수정하고 가상 호스트 구성을 포함하십시오. 시작 또는 새로 고침 Nginx. 구성을 테스트하고 웹 사이트를보십시오. SSL을 선택적으로 활성화하고 SSL 인증서를 구성하십시오. 포트 80 및 443 트래픽을 허용하도록 방화벽을 선택적으로 설정하십시오.

nginx403 오류를 해결하는 방법nginx403 오류를 해결하는 방법Apr 14, 2025 pm 12:54 PM

서버는 요청 된 리소스에 액세스 할 수있는 권한이 없으므로 Nginx 403 오류가 발생합니다. 솔루션에는 다음이 포함됩니다. 파일 권한 확인 권한을 확인하십시오. .htaccess 구성을 확인하십시오. nginx 구성을 확인하십시오. Selinux 권한을 구성하십시오. 방화벽 규칙을 확인하십시오. 브라우저 문제, 서버 장애 또는 기타 가능한 오류와 같은 다른 원인을 해결하십시오.

Linux에서 Nginx를 시작하는 방법Linux에서 Nginx를 시작하는 방법Apr 14, 2025 pm 12:51 PM

Linux에서 Nginx를 시작하는 단계 : Nginx가 설치되어 있는지 확인하십시오. systemctl start nginx를 사용하여 nginx 서비스를 시작하십시오. SystemCTL을 사용하여 NGINX를 사용하여 시스템 시작시 NGINX의 자동 시작을 활성화하십시오. SystemCTL 상태 nginx를 사용하여 시작이 성공했는지 확인하십시오. 기본 환영 페이지를 보려면 웹 브라우저의 http : // localhost를 방문하십시오.

nginx가 시작되었는지 확인하는 방법은 무엇입니까?nginx가 시작되었는지 확인하는 방법은 무엇입니까?Apr 14, 2025 pm 12:48 PM

Linux에서는 다음 명령을 사용하여 nginx가 시작되었는지 확인하십시오. SystemCTL 상태 Nginx 판사 명령 출력에 따라 : "active : running"이 표시되면 Nginx가 시작됩니다. "Active : 비활성 (죽음)"이 표시되면 Nginx가 중지됩니다.

nginx304 오류를 해결하는 방법nginx304 오류를 해결하는 방법Apr 14, 2025 pm 12:45 PM

질문에 대한 답변 : 304 수정되지 않은 오류는 브라우저가 클라이언트 요청의 최신 리소스 버전을 캐시했음을 나타냅니다. 솔루션 : 1. 브라우저 캐시를 지우십시오. 2. 브라우저 캐시를 비활성화합니다. 3. 클라이언트 캐시를 허용하도록 nginx를 구성합니다. 4. 파일 권한을 확인하십시오. 5. 파일 해시를 확인하십시오. 6. CDN 또는 리버스 프록시 캐시를 비활성화합니다. 7. nginx를 다시 시작하십시오.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.