Python-원격 프로 시저 호출
원격 프로 시저 호출 (RPC) 시스템을 사용하면 로컬 라이브러리에서 함수를 호출 할 때 사용되는 것과 동일한 구문을 사용하여 원격 서버에서 사용할 수있는 함수를 호출 할 수 있습니다. 이것은 두 가지 상황에서 유용합니다.
- 원격 시스템에있는 프로그램을 호출하기위한 코드를 변경하지 않고 rpc를 사용하여 여러 시스템의 처리 능력을 활용할 수 있습니다.
- 처리에 필요한 데이터는 원격 시스템에서만 사용할 수 있습니다.
그래서 파이썬에서 우리는 하나의 머신을 서버로, 다른 머신은 원격 프로 시저를 실행하기 위해 서버를 호출하는 클라이언트로 취급 할 수 있습니다. 이 예에서는 localhost를 가져 와서 서버와 클라이언트로 사용합니다.
서버 실행
파이썬 언어는 로컬 서버로 실행할 수있는 내장 서버와 함께 제공됩니다. 이 서버를 실행하는 스크립트는 Python 설치의 bin 폴더 아래에 있으며 이름은 classic.py입니다. 파이썬 프롬프트에서 실행하고 로컬 서버로 실행 중인지 확인할 수 있습니다.
python bin/classic.py
위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
INFO:SLAVE/18812:server started on [127.0.0.1]:18812
클라이언트 실행
다음으로 rpyc 모듈을 사용하여 클라이언트를 실행하여 원격 프로 시저 호출을 실행합니다. 아래 예에서는 원격 서버에서 인쇄 기능을 실행합니다.
import rpyc
conn = rpyc.classic.connect("localhost")
conn.execute("print('Hello from Tutorialspoint')")
위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
Hello from Tutorialspoint
RPC를 통한 식 평가
위의 코드 예제를 사용하여 rpc를 통한 표현식의 실행 및 평가를 위해 Python의 내장 함수를 사용할 수 있습니다.
import rpyc
conn = rpyc.classic.connect("localhost")
conn.execute('import math')
conn.eval('2*math.pi')
위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
6.283185307179586