소개 | 분산 트랜잭션은 종종 서비스 지향의 문제점입니다. 많은 시나리오에서는 비즈니스를 통해 분산 트랜잭션을 피하지만 여전히 분산 트랜잭션에 의존해야 하는 몇 가지 시나리오가 있습니다 |
분산 트랜잭션 문제를 해결하는 방법은 다양하며, 다양한 솔루션을 제공하는 인터넷 블로그도 많습니다. 정리하면 일반적으로 다음 두 가지 방법으로 나눌 수 있습니다. 1. 2단계 커밋(줄여서 2PC): 일반적인 분산 트랜잭션 솔루션입니다. 이 방법에서 코디네이터 노드는 참가자 노드의 작업을 조정하고 커밋 또는 롤백 시 모든 노드가 합의에 도달하도록 하는 역할을 담당합니다.
엄격한 분산 트랜잭션과 2단계 커밋은 강력한 일관성을 달성하기 위한 메커니즘입니다. 엄격한 분산 트랜잭션은 원자성을 보장해야 하는 분산 시스템의 여러 참가자 노드가 수행하는 일련의 작업, 즉 모두 성공하거나 모두 실패하는 것을 의미합니다. 이 메커니즘은 모든 참가자 노드가 트랜잭션 실행 중에 동일한 프로토콜을 따르고 코디네이터 노드의 안내를 통해 트랜잭션을 구현하도록 요구합니다유연한 분산 트랜잭션은 분산 시스템에서 트랜잭션을 처리하는 방법입니다. 최선의 커밋 전략을 채택합니다. 즉, 트랜잭션 제출을 완료하기 위해 최선을 다하지만 일부 작업이 실패할 수도 있습니다. 유연한 분산 트랜잭션에서는 일반적으로 TCC(Try-Confirm-Cancel) 모드를 사용하여 트랜잭션 관리를 구현합니다. TCC 모델은 거래를 시도, 확인, 취소의 세 단계로 분해합니다.
먼저 분산 트랜잭션에 대한 전제 조건 보장을 해결하십시오. 메시지의 반복 전송이 비즈니스에 영향을 미치지 않도록 인터페이스는 멱등원이어야 합니다
2 신뢰할 수 있는 메시징 시스템 디자인(느낌이 좋고 비교적 간단하므로 공유하겠습니다)
위와 같이
실행 시작 예:
시도해 보세요{
if(prepare()) { //사전 전송 단계
doService(); //비즈니스 로직 실행
updateMsgStatus();//상태 확인을 위한 메시지 업데이트
}
}
1 메시지를 사전 전송하고 단계를 시도해 보세요. 사전 전송 메시지가 실패하면 아직 비즈니스가 실행되지 않은 것이므로 시스템 A와 B는 여전히 일관성이 있으며 처리가 필요하지 않습니다
이해하기 쉽습니다
2 미리 보낸 메시지가 성공하고 비즈니스 로직이 실행되기 시작합니다. 실행이 성공하면 업데이트된 미리 전송된 메시지의 상태가 전송 확인으로 변경됩니다. 이때 비즈니스 로직 실행이 실패하면 현재 전송된 메시지는 새로운 상태로 업데이트되지 않습니다. 이때 메시지 확인 시스템이 작동을 시작하고 비즈니스 시스템 1로 돌아가서 메시지 상태를 확인합니다. 업무 수행에 실패한 것으로 확인되면 사전 전송 상태를 실패 상태로 업데이트합니다.
3 이때 비즈니스 실행이 성공적으로 이루어지고 전송 확인 메시지가 업데이트되면 정상이며 완벽한 것입니다. 메시지 업데이트가 실패하더라도 메시지 확인 시스템은 계속해서 상태를 확인하고 메시지가 삭제되었는지 또는 전송이 확인되었는지 업데이트합니다.
4명의 메시지 발송자가 소비를 시작합니다
1> 예를 들어 소비가 실패하고 불일치가 발생하면 메시지 복구 시스템에서 메시지 상태를 감지하고 메시지를 다시 보냅니다
2>업무 실행이 실패하면 메시지가 확인되지 않습니다. 메시지 복구 시스템은 메시지 상태를 감지하여 메시지를 다시 보냅니다
3> 요청이 실패하면 위의 논리를 사용하여 이의신청을 다시 보내야 합니다. 물론, 최대 횟수를 초과하면 항상 보낼 수는 없습니다.
배달 못한 편지 대기열에 들어가서 수동 개입을 기다립니다.4> 요청이 성공하면 메시지가 성공적으로 소비됩니다. 이는 완벽하며 안정적인 메시지 서비스 문제를 해결합니다
셋, 열심히 제출하세요
실시간 성능이 약한 일부 시나리오에서 성공적인 메시지 푸시를 보장하기 위해 실패한 메시지가 반복적으로 제출되는 것은 비교적 간단합니다.예를 들어 거래가 완료되면 제3자 메시지를 푸시하세요. 이때 하드 제출을 사용할 수 있습니다
이 기사는 오픈 소스 중국 커뮤니티 [http://www.oschina.net]에서 재인쇄되었습니다.
위 내용은 안정적인 메시징 서비스 구현 살펴보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인터넷은 단일 운영 체제에 의존하지 않지만 Linux는 이에 중요한 역할을합니다. Linux는 서버 및 네트워크 장치에서 널리 사용되며 안정성, 보안 및 확장 성으로 인기가 있습니다.

Linux 운영 체제의 핵심은 명령 줄 인터페이스이며 명령 줄을 통해 다양한 작업을 수행 할 수 있습니다. 1. 파일 및 디렉토리 작업 LS, CD, MKDIR, RM 및 기타 명령을 사용하여 파일 및 디렉토리를 관리합니다. 2. 사용자 및 권한 관리는 UserAdd, Passwd, CHMOD 및 기타 명령을 통해 시스템 보안 및 리소스 할당을 보장합니다. 3. 프로세스 관리는 PS, Kill 및 기타 명령을 사용하여 시스템 프로세스를 모니터링하고 제어합니다. 4. 네트워크 운영에는 Ping, Ifconfig, SSH 및 기타 명령이 포함되어 있으며 네트워크 연결을 구성하고 관리합니다. 5. 시스템 모니터링 및 유지 관리 Top, DF, Du와 같은 명령을 사용하여 시스템의 작동 상태 및 리소스 사용을 이해합니다.

소개 Linux는 유연성과 효율성으로 인해 개발자, 시스템 관리자 및 전원 사용자가 선호하는 강력한 운영 체제입니다. 그러나 길고 복잡한 명령을 자주 사용하는 것은 지루하고 응급실이 될 수 있습니다.

Linux는 서버, 개발 환경 및 임베디드 시스템에 적합합니다. 1. 서버 운영 체제로서 Linux는 안정적이고 효율적이며 종종 고 대전성 애플리케이션을 배포하는 데 사용됩니다. 2. 개발 환경으로서 Linux는 효율적인 명령 줄 도구 및 패키지 관리 시스템을 제공하여 개발 효율성을 향상시킵니다. 3. 임베디드 시스템에서 Linux는 가볍고 사용자 정의 가능하며 자원이 제한된 환경에 적합합니다.

소개 : Linux 기반의 윤리적 해킹으로 디지털 프론티어 보안 점점 더 상호 연결된 세상에서 사이버 보안이 가장 중요합니다. 윤리적 해킹 및 침투 테스트는 취약점을 적극적으로 식별하고 완화하는 데 필수적입니다.

기본 Linux 학습 방법은 다음과 같습니다. 1. 파일 시스템 및 명령 줄 인터페이스 이해, 2. LS, CD, MKDIR, 3. 파일 생성 및 편집과 같은 파일 작업 배우기, 4. 파이프 라인 및 GREP 명령과 같은 고급 사용법, 5. 연습 및 탐색을 통해 지속적으로 기술을 향상시킵니다.

Linux는 서버, 임베디드 시스템 및 데스크탑 환경에서 널리 사용됩니다. 1) 서버 필드에서 Linux는 안정성 및 보안으로 인해 웹 사이트, 데이터베이스 및 응용 프로그램을 호스팅하기에 이상적인 선택이되었습니다. 2) 임베디드 시스템에서 Linux는 높은 사용자 정의 및 효율성으로 인기가 있습니다. 3) 데스크탑 환경에서 Linux는 다양한 사용자의 요구를 충족시키기 위해 다양한 데스크탑 환경을 제공합니다.

Linux의 단점에는 사용자 경험, 소프트웨어 호환성, 하드웨어 지원 및 학습 곡선이 포함됩니다. 1. 사용자 경험은 Windows 또는 MacOS만큼 친절하지 않으며 명령 줄 인터페이스에 의존합니다. 2. 소프트웨어 호환성은 다른 시스템만큼 좋지 않으며 많은 상용 소프트웨어의 기본 버전이 부족합니다. 3. 하드웨어 지원은 Windows만큼 포괄적이지 않으며 드라이버를 수동으로 컴파일 할 수 있습니다. 4. 학습 곡선은 가파르고 명령 줄 운영을 마스터하는 데 시간과 인내가 필요합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Dreamweaver Mac版
시각적 웹 개발 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구
