이벤트 기반 프로그래밍

이벤트 중심 프로그래밍은 이벤트에 중점을 둡니다. 결국 프로그램의 흐름은 이벤트에 따라 달라집니다. 지금까지 우리는 순차 또는 병렬 실행 모델을 다루었지만 이벤트 중심 프로그래밍의 개념을 가진 모델을 비동기 모델이라고합니다. 이벤트 중심 프로그래밍은 항상 새로 들어오는 이벤트를 수신하는 이벤트 루프에 의존합니다. 이벤트 중심 프로그래밍의 작동은 이벤트에 따라 다릅니다. 이벤트가 반복되면 이벤트는 실행할 항목과 순서를 결정합니다. 다음 순서도는 이것이 어떻게 작동하는지 이해하는 데 도움이 될 것입니다.

Python 모듈 – Asyncio

Asyncio 모듈은 Python 3.4에 추가되었으며 코 루틴을 사용하여 단일 스레드 동시 코드를 작성하기위한 인프라를 제공합니다. 다음은 Asyncio 모듈에서 사용하는 다른 개념입니다.

이벤트 루프

이벤트 루프는 계산 코드의 모든 이벤트를 처리하는 기능입니다. 전체 프로그램을 실행하는 동안 내내 작동하며 이벤트의 수신 및 실행을 추적합니다. Asyncio 모듈은 프로세스 당 단일 이벤트 루프를 허용합니다. 다음은 이벤트 루프를 관리하기 위해 Asyncio 모듈에서 제공하는 몇 가지 방법입니다.

  • loop = get_event_loop() −이 방법은 현재 컨텍스트에 대한 이벤트 루프를 제공합니다.

  • loop.call_later(time_delay,callback,argument) −이 메서드는 주어진 time_delay 초 후에 호출 될 콜백을 정렬합니다.

  • loop.call_soon(callback,argument)−이 메서드는 가능한 한 빨리 호출 할 콜백을 준비합니다. 콜백은 call_soon ()이 반환 된 후 및 컨트롤이 이벤트 루프로 반환 될 때 호출됩니다.

  • loop.time() −이 방법은 이벤트 루프의 내부 시계에 따라 현재 시간을 반환하는 데 사용됩니다.

  • asyncio.set_event_loop() −이 방법은 현재 컨텍스트에 대한 이벤트 루프를 루프로 설정합니다.

  • asyncio.new_event_loop() −이 메서드는 새로운 이벤트 루프 객체를 생성하고 반환합니다.

  • loop.run_forever() −이 메서드는 stop () 메서드가 호출 될 때까지 실행됩니다.

다음 이벤트 루프 예제는 인쇄에 도움이됩니다. hello worldget_event_loop () 메서드를 사용합니다. 이 예제는 Python 공식 문서에서 가져온 것입니다.

import asyncio

def hello_world(loop):
   print('Hello World')
   loop.stop()

loop = asyncio.get_event_loop()

loop.call_soon(hello_world, loop)

loop.run_forever()
loop.close()

산출

Hello World

선물

이는 아직 수행되지 않은 계산을 나타내는 concurrent.futures.Future 클래스와 호환됩니다. asyncio.futures.Future와 concurrent.futures.Future 사이에는 다음과 같은 차이점이 있습니다.

  • result () 및 exception () 메서드는 시간 초과 인수를받지 않고 미래가 아직 완료되지 않은 경우 예외를 발생시킵니다.

  • add_done_callback ()에 등록 된 콜백은 항상 이벤트 루프의 call_soon ()을 통해 호출됩니다.

  • asyncio.futures.Future 클래스는 concurrent.futures 패키지의 wait () 및 as_completed () 함수와 호환되지 않습니다.

다음은 asyncio.futures.future 클래스 사용 방법을 이해하는 데 도움이되는 예제입니다.

import asyncio

async def Myoperation(future):
   await asyncio.sleep(2)
   future.set_result('Future Completed')

loop = asyncio.get_event_loop()
future = asyncio.Future()
asyncio.ensure_future(Myoperation(future))
try:
   loop.run_until_complete(future)
   print(future.result())
finally:
   loop.close()

산출

Future Completed

코 루틴

Asyncio의 코 루틴 개념은 스레딩 모듈 아래의 표준 Thread 개체 개념과 유사합니다. 이것은 서브 루틴 개념의 일반화입니다. 코 루틴은 실행 중에 일시 중단 될 수 있으므로 외부 처리를 기다렸다가 외부 처리가 완료되었을 때 중지 된 지점에서 돌아옵니다. 다음 두 가지 방법은 코 루틴을 구현하는 데 도움이됩니다.

비동기 def function ()

Asyncio 모듈에서 코 루틴을 구현하는 방법입니다. 다음은 동일한 Python 스크립트입니다.

import asyncio

async def Myoperation():
   print("First Coroutine")

loop = asyncio.get_event_loop()
try:
   loop.run_until_complete(Myoperation())

finally:
   loop.close()

산출

First Coroutine

@ asyncio.coroutine 데코레이터

코 루틴을 구현하는 또 다른 방법은 @ asyncio.coroutine 데코레이터와 함께 생성기를 활용하는 것입니다. 다음은 동일한 Python 스크립트입니다.

import asyncio

@asyncio.coroutine
def Myoperation():
   print("First Coroutine")

loop = asyncio.get_event_loop()
try:
   loop.run_until_complete(Myoperation())

finally:
   loop.close()

산출

First Coroutine

과제

Asyncio 모듈의이 하위 클래스는 이벤트 루프 내에서 병렬 방식으로 코 루틴을 실행합니다. 다음 Python 스크립트는 일부 작업을 병렬로 처리하는 예입니다.

import asyncio
import time
async def Task_ex(n):
   time.sleep(1)
   print("Processing {}".format(n))
async def Generator_task():
   for i in range(10):
      asyncio.ensure_future(Task_ex(i))
   int("Tasks Completed")
   asyncio.sleep(2)

loop = asyncio.get_event_loop()
loop.run_until_complete(Generator_task())
loop.close()

산출

Tasks Completed
Processing 0
Processing 1
Processing 2
Processing 3
Processing 4
Processing 5
Processing 6
Processing 7
Processing 8
Processing 9

수송

Asyncio 모듈은 다양한 유형의 통신을 구현하기위한 전송 클래스를 제공합니다. 이러한 클래스는 스레드로부터 안전하지 않으며 통신 채널을 설정 한 후 항상 프로토콜 인스턴스와 쌍을 이룹니다.

다음은 BaseTransport에서 상속 된 고유 한 전송 유형입니다.

  • ReadTransport − 이것은 읽기 전용 전송을위한 인터페이스입니다.

  • WriteTransport − 이것은 쓰기 전용 전송을위한 인터페이스입니다.

  • DatagramTransport − 데이터 전송을위한 인터페이스입니다.

  • BaseSubprocessTransport − BaseTransport 클래스와 유사합니다.

다음은 네 가지 전송 유형에 걸쳐 일시적인 BaseTransport 클래스의 다섯 가지 고유 한 방법입니다.

  • close() − 트랜스 포트를 닫습니다.

  • is_closing() −이 메서드는 트랜스 포트가 닫히거나 이미 닫혀 있으면 참을 반환합니다.

  • get_extra_info(name, default = none) − 이는 운송에 대한 추가 정보를 제공합니다.

  • get_protocol() −이 방법은 현재 프로토콜을 반환합니다.

프로토콜

Asyncio 모듈은 네트워크 프로토콜을 구현하기 위해 서브 클래스 할 수있는 기본 클래스를 제공합니다. 이러한 클래스는 전송과 함께 사용됩니다. 프로토콜은 들어오는 데이터를 구문 분석하고 나가는 데이터의 쓰기를 요청하는 반면 전송은 실제 I / O 및 버퍼링을 담당합니다. 다음은 프로토콜의 세 가지 클래스입니다-

  • Protocol − 이것은 TCP 및 SSL 전송에 사용할 스트리밍 프로토콜을 구현하기위한 기본 클래스입니다.

  • DatagramProtocol − UDP 전송에 사용할 데이터 그램 프로토콜을 구현하기위한 기본 클래스입니다.

  • SubprocessProtocol − 이것은 일련의 단방향 파이프를 통해 자식 프로세스와 통신하는 프로토콜을 구현하기위한 기본 클래스입니다.