백엔드 개발 PHP 튜토리얼 비동기 코루틴 개발 실습: 고성능 메시지 큐 시스템 구축

비동기 코루틴 개발 실습: 고성능 메시지 큐 시스템 구축

Dec 02, 2023 pm 12:13 PM
코루틴 비동기식 고성능

비동기 코루틴 개발 실습: 고성능 메시지 큐 시스템 구축

비동기 코루틴 개발 실습: 고성능 메시지 큐 시스템 구축

인터넷이 발전하면서 메시지 큐 시스템은 확장 가능한 고성능 분산 시스템을 구축하는 데 핵심 구성 요소가 되었습니다. 메시지 큐 시스템을 구축할 때 비동기 코루틴을 적용하면 시스템의 성능과 확장성을 효과적으로 향상시킬 수 있습니다. 이 기사에서는 고성능 메시지 큐 시스템 구축을 예로 들어 비동기 코루틴의 실제 개발을 소개하고 구체적인 코드 예제를 제공합니다.

  1. 비동기 코루틴의 개념과 장점
    비동기 코루틴은 단일 스레드에서 높은 동시 처리를 달성할 수 있는 이벤트 중심 동시 프로그래밍 모델입니다. 기존 멀티스레딩 모델과 비교하여 비동기 코루틴에는 다음과 같은 장점이 있습니다.

1.1 경량: 비동기 코루틴은 추가 스레드를 생성할 필요가 없으며 대규모 동시성을 달성하기 위해 소수의 코루틴만 생성하면 됩니다. 이는 시스템 자원의 소비를 크게 줄여줍니다.

1.2 효율성: 비동기 코루틴은 비차단 I/O 및 이벤트 중심 메커니즘을 활용하여 매우 낮은 오버헤드로 효율적인 작업 예약 및 처리를 달성하며 컨텍스트 전환 오버헤드의 영향을 받지 않습니다.

1.3 확장성: 비동기 코루틴은 스레드 풀 크기와 같은 매개변수를 수동으로 조정할 필요 없이 시스템 로드가 증가함에 따라 자동으로 확장될 수 있습니다.

  1. 메시지 큐 시스템 설계 및 구현
    메시지 큐 시스템을 설계할 때 가장 먼저 고려해야 할 것은 큐의 데이터 구조와 메시지의 생산자-소비자 모델입니다. 일반적인 메시지 큐 시스템은 일반적으로 FIFO(선입선출) 데이터 구조와 게시-구독 모델을 사용하여 생산자와 소비자 간의 메시지 전달을 구현합니다. 다음은 비동기 코루틴을 기반으로 개발된 간단한 메시지 대기열 시스템의 샘플 코드입니다.
import asyncio

message_queue = []
subscriptions = {}

async def publish(channel, message):
    message_queue.append((channel, message))
    await notify_subscribers()

async def notify_subscribers():
    while message_queue:
        channel, message = message_queue.pop(0)
        for subscriber in subscriptions.get(channel, []):
            asyncio.ensure_future(subscriber(message))

async def subscribe(channel, callback):
    if channel not in subscriptions:
        subscriptions[channel] = []
    
    subscriptions[channel].append(callback)

async def consumer(message):
    print("Received message:", message)

async def main():
    await subscribe("channel1", consumer)
    await publish("channel1", "hello world")

if __name__ == "__main__":
    asyncio.run(main())
로그인 후 복사

위 코드에서는 message_queue 목록을 사용하여 게시된 메시지와 사전 구독을 저장합니다. 구독자와 해당 채널을 저장합니다. publish 함수는 메시지를 게시하는 데 사용되고, notify_subscribers 함수는 구독자에게 알리는 데 사용되고, subscribe 함수는 채널을 구독하는 데 사용됩니다. 및 consumer< /code> 함수는 예제 소비자 역할을 합니다. <code>message_queue列表来存储发布的消息,使用一个字典subscriptions来存储订阅者和对应的通道。publish函数用于发布消息,notify_subscribers函数用于通知订阅者,subscribe函数用于订阅某个通道,consumer函数作为一个示例的消费者。

main函数中,我们首先使用subscribe函数订阅了channel1通道,并将consumer函数指定为订阅者。然后我们使用publish函数发布了一条消息到channel1通道,notify_subscribers会自动地将消息发送给订阅者。

  1. 性能优化与扩展
    为了进一步优化和扩展消息队列系统的性能,我们可以结合使用异步I/O和协程池来提高消息的处理能力。通过使用异步I/O,我们可以充分利用系统资源,提高系统的吞吐量。协程池可以用来限制并发任务数量,并避免过多的上下文切换。

下面是一个基于异步I/O和协程池的消息队列系统的优化示例代码:

import asyncio
from concurrent.futures import ThreadPoolExecutor

message_queue = []
subscriptions = {}
executor = ThreadPoolExecutor()

async def publish(channel, message):
    message_queue.append((channel, message))
    await notify_subscribers()

async def notify_subscribers():
    while message_queue:
        channel, message = message_queue.pop(0)
        for subscriber in subscriptions.get(channel, []):
            await execute(subscriber(message))

async def execute(callback):
    loop = asyncio.get_running_loop()
    await loop.run_in_executor(executor, callback)

async def subscribe(channel, callback):
    if channel not in subscriptions:
        subscriptions[channel] = []
    
    subscriptions[channel].append(callback)

async def consumer(message):
    print("Received message:", message)

async def main():
    await subscribe("channel1", consumer)
    await publish("channel1", "hello world")

if __name__ == "__main__":
    asyncio.run(main())
로그인 후 복사

在优化示例代码中,我们使用executor来创建一个协程池,并通过execute

main 함수에서 먼저 subscribe 함수를 사용하여 channel1 채널을 구독하고 consumer를 지정합니다. 가입자를 위한 기능입니다. 그런 다음 publish 기능을 사용하여 channel1 채널에 메시지를 게시하면 notify_subscribers가 자동으로 구독자에게 메시지를 보냅니다.

    성능 최적화 및 확장
      메시지 대기열 시스템의 성능을 더욱 최적화하고 확장하기 위해 비동기 I/O와 코루틴 풀을 함께 사용하여 메시지 처리 기능을 향상시킬 수 있습니다. 비동기 I/O를 사용하면 시스템 리소스를 최대한 활용하고 시스템 처리량을 향상시킬 수 있습니다. 코루틴 풀은 동시 작업 수를 제한하고 과도한 컨텍스트 전환을 방지하는 데 사용할 수 있습니다.

    1. 다음은 비동기 I/O 및 코루틴 풀 기반 메시지 큐 시스템에 최적화된 샘플 코드입니다.
    rrreee🎜최적화된 샘플 코드에서는 executor를 사용하여 코루틴 풀을 생성하고, 그리고 execute 함수를 통해 실행할 수 있도록 콜백 함수를 코루틴 풀에 넣습니다. 이를 통해 과도한 컨텍스트 전환을 방지하고 콜백 기능을 동시에 실행하며 메시지 처리 기능을 향상시킬 수 있습니다. 🎜🎜물론 실제 메시지 대기열 시스템에서는 메시지 지속성, 메시지 확인 메커니즘, 수평 확장 등을 도입하는 등 더욱 최적화하고 확장할 수 있습니다. 🎜🎜🎜요약🎜이 글에서는 고성능 메시지 큐 시스템 구축을 예로 들어 비동기 코루틴의 실제 개발을 소개하고 구체적인 코드 예제를 제공합니다. 비동기식 코루틴은 매우 낮은 오버헤드로 효율적인 작업 예약 및 처리를 달성할 수 있으며 시스템 성능과 확장성을 효과적으로 향상시킬 수 있습니다. 비동기 I/O 및 코루틴 풀과 같은 기술을 결합함으로써 메시지 대기열 시스템을 더욱 최적화하고 확장하여 다양한 애플리케이션 시나리오와 요구 사항에 적응할 수 있습니다. 🎜🎜

위 내용은 비동기 코루틴 개발 실습: 고성능 메시지 큐 시스템 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

golang 함수와 goroutine 간의 부모-자식 관계 golang 함수와 goroutine 간의 부모-자식 관계 Apr 25, 2024 pm 12:57 PM

Go에는 함수와 고루틴 사이에 부모-자식 관계가 있습니다. 부모 고루틴은 자식 고루틴을 생성하며, 자식 고루틴은 부모 고루틴의 변수에 액세스할 수 있지만 그 반대의 경우는 불가능합니다. go 키워드를 사용하여 하위 고루틴을 생성하고, 하위 고루틴은 익명 함수 또는 명명된 함수를 통해 실행됩니다. 상위 고루틴은 모든 하위 고루틴이 완료되기 전에 프로그램이 종료되지 않도록 하기 위해 sync.WaitGroup을 통해 하위 고루틴이 완료될 때까지 기다릴 수 있습니다.

Golang API 디자인에 동시성 및 코루틴 적용 Golang API 디자인에 동시성 및 코루틴 적용 May 07, 2024 pm 06:51 PM

동시성과 코루틴은 GoAPI 설계에서 다음을 위해 사용됩니다. 고성능 처리: 성능 향상을 위해 여러 요청을 동시에 처리합니다. 비동기 처리: 코루틴을 사용하여 작업(예: 이메일 보내기)을 비동기적으로 처리하고 메인 스레드를 해제합니다. 스트림 처리: 코루틴을 사용하여 데이터 스트림(예: 데이터베이스 읽기)을 효율적으로 처리합니다.

Golang 코루틴과 고루틴의 관계 Golang 코루틴과 고루틴의 관계 Apr 15, 2024 am 10:42 AM

코루틴은 작업을 동시에 실행하기 위한 추상적인 개념이고, 고루틴은 코루틴의 개념을 구현한 Go 언어의 경량 스레드 함수입니다. 둘은 밀접하게 관련되어 있지만 고루틴 리소스 소비가 적고 Go 스케줄러에 의해 관리됩니다. 고루틴은 웹 요청을 동시에 처리하고 프로그램 성능을 향상시키는 등 실제 전투에서 널리 사용됩니다.

Golang 코루틴의 수명주기를 제어하는 ​​방법은 무엇입니까? Golang 코루틴의 수명주기를 제어하는 ​​방법은 무엇입니까? May 31, 2024 pm 06:05 PM

Go 코루틴의 수명 주기는 다음과 같은 방법으로 제어할 수 있습니다. 코루틴 만들기: go 키워드를 사용하여 새 작업을 시작합니다. 코루틴 종료: 모든 코루틴이 완료될 때까지 기다리고 sync.WaitGroup을 사용합니다. 채널 폐쇄 신호를 사용하십시오. 컨텍스트 context.Context를 사용하십시오.

Python asyncio 고급 가이드: 초보자부터 전문가까지 Python asyncio 고급 가이드: 초보자부터 전문가까지 Mar 04, 2024 am 09:43 AM

동시 및 비동기 프로그래밍 동시 프로그래밍은 동시에 실행되는 여러 작업을 처리하며, 비동기 프로그래밍은 작업이 스레드를 차단하지 않는 일종의 동시 프로그래밍입니다. asyncio는 프로그램이 메인 스레드를 차단하지 않고 I/O 작업을 수행할 수 있도록 하는 Python의 비동기 프로그래밍용 라이브러리입니다. 이벤트 루프 asyncio의 핵심은 I/O 이벤트를 모니터링하고 해당 작업을 예약하는 이벤트 루프입니다. 코루틴이 준비되면 이벤트 루프는 I/O 작업을 기다릴 때까지 이를 실행합니다. 그런 다음 코루틴을 일시 중지하고 다른 코루틴을 계속 실행합니다. 코루틴 코루틴은 실행을 일시 중지하고 다시 시작할 수 있는 함수입니다. asyncdef 키워드는 코루틴을 만드는 데 사용됩니다. 코루틴은 I/O 작업이 완료될 때까지 기다리기 위해 wait 키워드를 사용합니다. 다음과 같은 asyncio의 기본 사항

Java 예외 처리의 비동기 및 비차단 기술 Java 예외 처리의 비동기 및 비차단 기술 May 01, 2024 pm 05:42 PM

비동기식 및 비차단 기술을 사용하여 전통적인 예외 처리를 보완하여 보다 응답성이 뛰어나고 효율적인 Java 애플리케이션을 생성할 수 있습니다. 비동기식 예외 처리: 다른 스레드나 프로세스에서 예외를 처리하여 기본 스레드가 계속 실행되도록 하고 차단을 방지합니다. 비차단 예외 처리: I/O 작업이 잘못되었을 때 이벤트 기반 예외 처리를 포함하여 스레드 차단을 방지하고 이벤트 루프가 예외를 처리하도록 허용합니다.

Golang 코루틴의 생성 및 수명 주기 Golang 코루틴의 생성 및 수명 주기 Apr 15, 2024 pm 05:06 PM

코루틴은 명시적으로 전환하여 동일한 호출 스택의 실행 단위를 재사용하는 경량 스레드입니다. 수명주기에는 생성, 실행, 일시 중지, 복구 및 완료가 포함됩니다. go 키워드를 사용하여 실제로 병렬 계산(예: 피보나치 수 계산)에 사용할 수 있는 코루틴을 만듭니다.

Go 코루틴을 사용하여 병렬 처리를 구현하는 방법은 무엇입니까? Go 코루틴을 사용하여 병렬 처리를 구현하는 방법은 무엇입니까? Jun 05, 2024 pm 06:07 PM

Go 코루틴을 사용하여 병렬 처리를 구현하는 방법은 무엇입니까? 피보나치 수열을 병렬로 계산하는 코루틴을 만듭니다. 코루틴은 병렬 컴퓨팅을 달성하기 위해 채널을 통해 데이터를 전송합니다. 메인 코루틴은 병렬 계산 결과를 수신하고 처리합니다.

See all articles