Nginx는 안정적인 고성능 웹 서버이자 역방향 프록시 서버입니다. 강력한 로드 밸런싱 및 캐싱 기능 외에도 Nginx는 HTTP 기본 인증도 지원합니다. HTTP 기본 인증은 요청 헤더에 사용자 이름과 비밀번호를 추가하여 사용자의 신원을 확인하는 간단한 인증 방법입니다. 이번 글에서는 Nginx를 사용하여 HTTP 기본 인증을 구현하는 방법을 알아봅니다.
1. 사용자 이름과 비밀번호 설정
먼저 비밀번호 파일을 만들어야 합니다. htpasswd 명령을 사용하여 이 파일을 만들 수 있습니다. htpasswd는 HTTP 기본 인증 비밀번호를 관리하기 위한 명령줄 도구입니다.
터미널에서 다음 명령을 사용하여 비밀번호 파일을 만들 수 있습니다.
htpasswd -c /etc/nginx/.htpasswd username
그 중 -c는 새 비밀번호 파일을 만드는 것을 의미하고, /etc/nginx/.htpasswd는 비밀번호 파일의 경로이며, 사용자 이름은 다음과 같습니다. 이름은 추가하려는 사용자입니다. 이 명령을 실행하면 비밀번호를 묻는 메시지가 표시됩니다. 비밀번호를 입력한 후 htpasswd는 비밀번호를 해시하여 비밀번호 파일에 저장합니다.
비밀번호 파일에 사용자를 더 추가하려면 다음 명령을 사용하세요.
htpasswd /etc/nginx/.htpasswd username2
비밀번호 파일이 이미 존재하므로 이 명령에는 -c 옵션이 없습니다. 명령을 입력하면 비밀번호를 묻는 메시지가 나타납니다. 일단 입력되면 htpasswd는 사용자 이름과 비밀번호를 해시하고 비밀번호 파일에 추가합니다.
2. Nginx에서 기본 인증 적용
이제 사용자 이름과 비밀번호 해시가 포함된 비밀번호 파일을 만들었습니다. 다음으로 Nginx에서 HTTP 기본 인증을 적용해야 합니다.
서버 블록 또는 위치 블록에 다음 지침을 추가해야 합니다.
auth_basic "Restricted"; auth_basic_user_file /etc/nginx/.htpasswd;
첫 번째 지침은 Nginx에게 요청에 대해 기본 인증을 수행하고 팝업 로그인 상자에 설명 정보로 "Restricted"를 표시하도록 지시합니다.
두 번째 지시문은 Nginx에게 /usr/share/nginx/.htpasswd 파일을 사용하여 사용자를 인증하도록 지시합니다.
예를 들어 Nginx의 기본 서버 블록에 다음 코드를 추가할 수 있습니다.
server { listen 80 default_server; listen [::]:80 default_server; root /var/www/html; index index.html index.htm index.nginx-debian.html; auth_basic "Restricted"; auth_basic_user_file /etc/nginx/.htpasswd; }
이제 Nginx 서버에 기본 인증을 성공적으로 추가했습니다.
3. HTTP 기본 인증 테스트
이제 방금 설정한 인증 기능을 테스트해 보겠습니다. 컬(curl)이나 파이어폭스(Firefox)와 같은 도구를 사용하여 테스트할 수 있습니다.
curl을 사용하여 테스트:
curl -I http://localhost
명령줄에 사용자 이름과 비밀번호를 묻는 메시지가 표시됩니다. 올바른 사용자 이름과 비밀번호를 입력하면 HTTP 응답 헤더에 다음 코드가 포함된 것을 볼 수 있습니다.
HTTP/1.1 200 OK Server: nginx/1.14.0 (Ubuntu) ...
Firefox로 테스트:
Firefox에서 서버 주소 http://localhost를 입력하세요. Firefox는 "제한됨"이라는 단어와 설명이 포함된 창을 띄워 사용자 이름과 비밀번호를 입력하라는 메시지를 표시합니다. 올바른 사용자 이름과 비밀번호를 입력하면 서버 기본 웹 페이지로 리디렉션됩니다.
요약
이 글에서는 Nginx를 사용하여 HTTP 기본 인증을 구현하는 방법을 소개합니다. HTTP 기본 인증은 웹 서버의 민감한 리소스를 보호하는 데 사용할 수 있는 간단하지만 효과적인 인증 방법입니다. 먼저 htpasswd 명령을 사용하여 비밀번호 파일을 만든 다음 Nginx 구성에서 기본 인증 지시문을 적용하여 Nginx 서버에 HTTP 기본 인증을 쉽게 추가할 수 있습니다.
위 내용은 Nginx를 사용하여 HTTP 기본 인증을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

NGINX는 동시성이 높은 자원 소비 시나리오에 적합하지만 APACHE는 복잡한 구성 및 기능 확장이 필요한 시나리오에 적합합니다. 1.NGINX는 고성능과의 많은 동시 연결을 처리하는 것으로 알려져 있습니다. 2. Apache는 안정성과 풍부한 모듈 지원으로 유명합니다. 선택할 때는 특정 요구에 따라 결정해야합니다.

nginxissentialderformodernwebapplicationsduetoitsrolessareareverseproxy, loadbalancer 및 Webserver, HighperformanceAndscalability를 제공합니다

Nginx를 통해 웹 사이트 보안을 보장하려면 다음 단계가 필요합니다. 1. 기본 구성을 만들고 SSL 인증서 및 개인 키를 지정하십시오. 2. 구성 최적화, HTTP/2 및 OCSPStapling 활성화; 3. 인증서 경로 및 암호화 제품군 문제와 같은 공통 오류 디버그; 4. Let 'sencrypt 및 세션 멀티플렉싱 사용과 같은 응용 프로그램 성능 최적화 제안.

NGINX는 고성능 HTTP 및 리버스 프록시 서버로 높은 동시 연결을 처리하는 데 능숙합니다. 1) 기본 구성 : 포트를 듣고 정적 파일 서비스를 제공합니다. 2) 고급 구성 : 리버스 프록시 및로드 밸런싱을 구현하십시오. 3) 디버깅 기술 : 오류 로그를 확인하고 구성 파일을 테스트하십시오. 4) 성능 최적화 : GZIP 압축을 활성화하고 캐시 정책을 조정합니다.

Nginx 캐시는 다음 단계를 통해 웹 사이트 성능을 크게 향상시킬 수 있습니다. 1) 캐시 영역을 정의하고 캐시 경로를 설정하십시오. 2) 캐시 유효성 기간 구성; 3) 다른 컨텐츠에 따라 다른 캐시 정책을 설정합니다. 4) 캐시 저장 및로드 밸런싱을 최적화합니다. 5) 캐시 효과를 모니터링하고 디버그합니다. 이러한 방법을 통해 NGINX 캐시는 백엔드 서버 압력을 줄이고 응답 속도 및 사용자 경험을 향상시킬 수 있습니다.

dockercompose를 사용하면 Nginx의 배포 및 관리를 단순화 할 수 있으며 Dockerswarm 또는 Kubernetes를 통한 스케일링은 일반적인 관행입니다. 1) DockerCompose를 사용하여 Nginx 컨테이너를 정의하고 실행하십시오. 2) Dockerswarm 또는 Kubernetes를 통한 클러스터 관리 및 자동 스케일링 구현.

NGINX의 고급 구성은 서버 블록 및 리버스 프록시를 통해 구현 될 수 있습니다. 1. 서버 블록을 사용하면 여러 웹 사이트를 한쪽으로 실행할 수있게되면 각 블록은 독립적으로 구성됩니다. 2. 리버스 프록시는 요청을 백엔드 서버로 전달하여로드 밸런싱 및 캐시 가속도를 실현합니다.

작업자 프로세스 수, 연결 풀 크기, GZIP 압축 및 HTTP/2 프로토콜을 활성화하고 캐시 및로드 밸런싱을 사용하여 NGINX 성능 튜닝을 달성 할 수 있습니다. 1. 작업자 프로세스 수 및 연결 풀 크기 조정 : Worker_ProcessesAuto; 이벤트 {worker_connections1024;}. 2. GZIP 압축 및 HTTP/2 프로토콜 활성화 : http {gzipon; server {listen443sslhttp2;}}. 3. 캐시 최적화 사용 : http {proxy_cache_path/path/to/cachelevels = 1 : 2k


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

WebStorm Mac 버전
유용한 JavaScript 개발 도구

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기
