>  기사  >  운영 및 유지보수  >  Nginx 역생성 데이터베이스에서 프런트엔드와 백엔드 분리를 달성하는 방법

Nginx 역생성 데이터베이스에서 프런트엔드와 백엔드 분리를 달성하는 방법

WBOY
WBOY원래의
2023-06-10 12:01:441541검색

인터넷 기술의 급속한 발전으로 인해 프런트엔드와 백엔드 분리라는 아이디어가 개발자들 사이에서 점점 더 널리 사용되고 있습니다. 프런트엔드와 백엔드의 분리는 프런트엔드와 백엔드 개발을 분리하고 병렬화할 수 있으며, 개발 효율성을 높이고, 개발 복잡성을 줄이고, 시스템 성능과 확장성을 향상시킬 수 있습니다.

프런트엔드와 백엔드가 분리된 아키텍처에서는 프런트엔드가 인터페이스를 통해 백엔드에 데이터를 요청하고, 백엔드가 요청된 데이터를 처리한 후 프런트엔드로 반환합니다. 이 과정에서 Nginx는 역방향 프록시 기술을 통해 데이터를 전송하고 전달하는 역할을 할 수 있습니다. 이 기사에서는 Nginx 역생성 데이터베이스에서 프런트엔드와 백엔드 분리를 달성하는 방법을 소개합니다.

1. Nginx 리버스 프록시 데이터베이스

프런트엔드와 백엔드 분리 아키텍처에서 프런트엔드는 인터페이스를 통해 백엔드에 데이터를 요청하고 반환된 데이터를 처리합니다. 데이터베이스가 공용 네트워크에 직접 노출되면 보안 위험이 커집니다. 따라서 보안을 보장하기 위해 역방향 프록시 기술을 사용하여 데이터 전송 프로세스를 프록시해야 합니다.

Nginx에서는 다음 구성을 통해 역방향 프록시 데이터베이스를 구현할 수 있습니다.

location /api/ {
    proxy_pass http://localhost:8080;
}

이 구성의 의미는 프런트 엔드가 "/api/" 경로로 요청을 보낼 때 Nginx가 요청을 다음 경로로 전달한다는 것입니다. 로컬 8080 포트, 백엔드에서 반환된 데이터는 프런트엔드로 다시 전달됩니다. 이러한 방식으로 데이터베이스의 보안이 보장될 수 있습니다.

2. Nginx 역세대 로드 밸런싱

실제 애플리케이션에서 단일 백엔드 서버의 로드가 너무 크면 서버의 응답 시간이 느려지거나 심지어 충돌할 수도 있습니다. 따라서 백엔드 서버의 로드 밸런싱을 위해서는 Nginx 역세대 로드 밸런싱 기술을 사용해야 합니다.

Nginx의 로드 밸런싱 구성은 다음과 같습니다.

upstream backend {
    server 127.0.0.1:8080;
    server 127.0.0.1:8081;
}

server {
    listen 80;
    server_name localhost;

    location /api/ {
        proxy_pass http://backend;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

이 구성은 요청을 백엔드 서버 클러스터 중 하나로 전달하는 것을 의미합니다. 서버 중 하나가 사용량이 많거나 문제가 있으면 자동으로 다른 서버로 전환됩니다. 서버.

3. Nginx 역생성 캐시

프런트엔드와 백엔드가 분리된 아키텍처에서는 각 요청마다 데이터를 다시 얻으려면 프런트엔드가 백엔드에 요청을 자주 보내야 합니다. 데이터베이스에서 데이터를 읽으면 많은 시간과 리소스가 낭비됩니다. 이때 시스템의 응답 속도와 성능을 향상시키기 위해서는 Nginx의 역세대 캐싱 기능을 사용하여 자주 사용하는 데이터를 캐싱해야 합니다.

Nginx의 캐시 구성은 다음과 같습니다.

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m;
server {
    listen 80;
    server_name localhost;

    location /api/ {
        proxy_pass http://backend;
        proxy_cache my_cache;
        proxy_cache_valid 200 60m;
        proxy_cache_valid 404 1m;
        proxy_cache_bypass $http_pragma;
        proxy_cache_revalidate on;
        proxy_cache_min_uses 2;
        proxy_cache_lock on;
    }
}

이 구성의 의미는 10M 캐시 영역에 데이터를 캐시한다는 의미입니다. 일정 시간 내에 캐시된 데이터에 대한 요청이 없으면 캐시가 만료되어 캐시가 종료됩니다. 지워졌습니다. 동시에, Proxy_cache_valid를 통해 다양한 상태 코드의 캐시 시간을 지정할 수 있으며, Proxy_cache_bypass를 통해 캐시 업데이트를 제어할 수도 있습니다.

4. Nginx 역세대 HTTPS

프론트엔드와 백엔드 분리 아키텍처에서는 데이터 전송 보안을 고려하여 HTTP를 HTTPS로 업그레이드해야 합니다. Nginx에서는 다음 구성을 통해 역방향 프록시 HTTPS를 구현할 수 있습니다.

server {
    listen 443;
    server_name localhost;

    ssl on;
    ssl_certificate /etc/nginx/cert.pem;
    ssl_certificate_key /etc/nginx/key.pem;
    ssl_session_timeout 5m;

    location /api/ {
        proxy_pass http://backend;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

이 구성의 의미는 포트 443을 수신하고 SSL 구성을 활성화하며 인증서와 키를 동시에 구성하는 것입니다. 동시에 요청을 프록시할 때 관련 헤더를 설정해야 합니다.

요약

프런트엔드와 백엔드 분리 아키텍처에서 Nginx는 역방향 프록시 기술, 로드 밸런싱, 캐싱, HTTPS 등의 기능을 통해 데이터의 안전한 전송을 구현하고 확장성을 향상시키는 매우 중요한 역할을 합니다. 시스템의. Nginx는 다양한 작업과 애플리케이션 시나리오를 완료할 수 있는 매우 유연하고 강력한 역방향 프록시 서버입니다.

위 내용은 Nginx 역생성 데이터베이스에서 프런트엔드와 백엔드 분리를 달성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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