>PHP 프레임워크 >Laravel >로드 밸런싱, 분산, 클러스터링 이해 및 여러 서버 코드 동기화 방법

로드 밸런싱, 분산, 클러스터링 이해 및 여러 서버 코드 동기화 방법

步履不停
步履不停원래의
2019-07-03 14:42:184463검색

로드 밸런싱, 분산, 클러스터링 이해 및 여러 서버 코드 동기화 방법

이 용어들의 개념을 한번에 설명해드리겠습니다

Cluster

저희 프로젝트가 머신에서 실행되거나, 이 머신이 실패하거나, 사용자 요청량이 상대적으로 많은 경우, 한 머신에서는 이를 지원할 수 없습니다. 당사 웹사이트에 접속하지 못할 수도 있습니다. 그렇다면 어떻게 해결해야 할까요? 여러 대의 컴퓨터가 동시에 웹 사이트를 실행할 수 있도록 여러 대의 컴퓨터를 사용하고 동일한 프로그램을 배포해야 합니다. 그렇다면 요청을 모든 시스템에 어떻게 배포합니까? 그래서 로드 밸런싱이라는 개념이 등장했습니다.

로드 밸런싱

로드 밸런싱은 역방향 프록시를 기반으로 모든 현재 요청을 지정된 정책 알고리즘에 따라 여러 서버에 분산할 수 있음을 의미합니다. 로드 밸런싱을 달성하기 위해 일반적으로 사용되는 것은 nginx, lvs입니다. 그런데 이제 문제도 생겼는데, 로드밸런싱 서버에 문제가 생기면 어떻게 해야 할까요? 중복성의 모든 개념이 등장합니다.

Redundancy

Redundancy는 실제로 두 개 이상의 서버, 즉 마스터 서버와 슬레이브 서버를 의미합니다. 마스터 서버의 로드 밸런싱 서버에 문제가 발생하여 슬레이브 서버가 마스터 서버를 교체하여 로드 밸런싱을 계속할 수 있다고 가정해 보겠습니다. 이를 달성하는 방법은 keepalive를 사용하여 가상 호스트를 점유하는 것입니다.

Distributed

Distributed는 실제로 대규모 프로젝트를 분할하여 독립적으로 실행하는 것을 의미합니다.

위의 예를 들어보세요. 트래픽이 특히 높다고 가정해 보겠습니다. CDN과 동일한 메커니즘을 사용하여 배포할 수 있습니다. 베이징, 항저우, 선전 3곳에 동일한 클러스터가 구축됐다. 베이징에 가까운 사용자는 베이징의 클러스터에 액세스하고, 선전에 가까운 사용자는 선전의 클러스터에 액세스합니다. 이러한 방식으로 우리의 온라인 전투는 세 개의 영역으로 나누어지며 각 영역은 독립적입니다.

또 다른 예는 Redis 배포입니다. Redis 배포는 Redis의 데이터를 서로 다른 서버에 배포하는 반면, mysql 클러스터는 각 서버에 동일한 데이터를 저장합니다. 이는 또한 분산 및 클러스터링의 개념을 이해합니다.

mysql master-slave

mysql 마스터 서버는 sql 작업 로그를 bin.log 로그에 기록하고 슬레이브 서버는 마스터의 bin.log 로그를 읽은 다음 sql 문을 실행합니다.

마스터와 슬레이브에는 다음과 같은 문제가 있습니다.

1. 마스터 서버는 쓰고 읽을 수 있지만 슬레이브는 쓰기만 할 수 있습니다.

슬레이브가 읽은 데이터가 아직 기록되지 않았습니다. 이 문제를 해결하는 방법은 무엇입니까?

1. 캐시된 경우 캐시에서 읽습니다.
2. 마스터로부터 강제 읽기.
3. pxc 클러스터를 사용하면 모든 노드를 읽고 쓸 수 있으며 읽기 및 쓰기의 일관성이 뛰어납니다.

laravel이 데이터 불일치를 해결하는 방법

config/database.php mysql 구성 블록에서 Sticky를 true로 설정하세요.

sticky는 현재 요청 주기 동안 데이터베이스에 기록된 레코드를 즉시 읽는 데 사용할 수 있는 선택적 값입니다. . 고정 옵션이 활성화되어 있고 현재 요청 주기 동안 "쓰기" 작업이 수행된 경우 모든 "읽기" 작업은 "쓰기" 연결을 사용합니다. 이를 통해 동일한 요청 주기에 작성된 데이터를 즉시 읽을 수 있으므로 마스터-슬레이브 지연으로 인한 데이터 불일치 문제를 피할 수 있습니다. 그러나 활성화 여부는 애플리케이션의 요구 사항에 따라 다릅니다.

코드가 여러 서버에 동기화되면 어떻게 되나요?

Laravel은 원격 서버의 일상적인 작업을 정의하기 위한 간결하고 가벼운 구문 세트를 제공하는 확장 패키지 laravel/envoy를 제공합니다. 블레이드 스타일 구문은 배포 작업 구성, Artisan 명령 실행 등에 사용될 수 있습니다.

composer global require laravel/envoy

Envoy 작업은 모두 프로젝트 루트 디렉터리의 Envoy.blade.php에 정의되어야 합니다. 내용 작성

@servers(['web-1' => '192.168.1.1', 'web-2' => '192.168.1.2'])

@task('deploy', ['on' => ['web-1', 'web-2']])
    cd site
    git pull origin {{ $branch }}
    composer update
    php artisan migrate
@endtask

위 코드는 envoy가 명령줄에서 배포를 실행할 때 실행을 위해 web-1 및 web-2에 ssh를 실행한다는 의미입니다

    cd site
    git pull origin {{ $branch }}
    php artisan migrate

물론 이 전제는 원격에 ssh를 추가했다는 것입니다 섬기는 사람.

더 많은 Laravel 관련 기술 기사를 보려면 Laravel Tutorial 칼럼을 방문하여 알아보세요!

위 내용은 로드 밸런싱, 분산, 클러스터링 이해 및 여러 서버 코드 동기화 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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