Bagaimana untuk melaksanakan rangka kerja panggilan prosedur jauh RPC yang mudah dalam Python

WBOY
Lepaskan: 2023-10-27 09:57:49
asal
1618 orang telah melayarinya

Bagaimana untuk melaksanakan rangka kerja panggilan prosedur jauh RPC yang mudah dalam Python

Cara melaksanakan rangka kerja panggilan prosedur jauh RPC yang ringkas dalam Python

Dalam sistem teragih, mekanisme komunikasi biasa adalah melalui RPC (Panggilan Prosedur Jauh, panggilan prosedur jauh) untuk mencapai komunikasi antara panggilan fungsi proses yang berbeza. RPC membenarkan pembangun memanggil fungsi jauh sama seperti memanggil fungsi tempatan, menjadikan pembangunan sistem teragih lebih mudah.

Artikel ini akan memperkenalkan cara menggunakan Python untuk melaksanakan rangka kerja RPC yang mudah dan memberikan contoh kod terperinci.

1. Tentukan antara muka RPC
Pertama, kita perlu menentukan antara muka RPC, iaitu fungsi yang boleh dipanggil oleh pelanggan dari jauh. Katakan kita ingin melaksanakan antara muka RPC untuk operasi penambahan.

class Calculator:
    def add(self, x: int, y: int) -> int:
        return x + y
Salin selepas log masuk

2 Gunakan pengaturcaraan soket Python untuk melaksanakan rangka kerja RPC
Dalam Python, kita boleh menggunakan modul soket untuk komunikasi rangkaian. Berikut ialah contoh pelaksanaan rangka kerja RPC yang dipermudahkan:

import socket
import pickle

class RPCServer:
    def __init__(self, host: str, port: int):
        self.host = host
        self.port = port
        self.socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        self.socket.bind((host, port))
        self.socket.listen(1)
        
    def start(self):
        while True:
            conn, addr = self.socket.accept()
            data = conn.recv(4096)
            request = pickle.loads(data)
            result = self.process_request(request)
            conn.sendall(pickle.dumps(result))
            conn.close()
            
    def process_request(self, request):
        obj, method, args, kwargs = request
        cls = globals()[obj]
        instance = cls()
        func = getattr(instance, method)
        return func(*args, **kwargs)


class RPCClient:
    def __init__(self, host: str, port: int):
        self.host = host
        self.port = port
        
    def call(self, obj: str, method: str, *args, **kwargs):
        request = (obj, method, args, kwargs)
        data = pickle.dumps(request)
        socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        socket.connect((self.host, self.port))
        socket.sendall(data)
        data = socket.recv(4096)
        response = pickle.loads(data)
        socket.close()
        return response
Salin selepas log masuk

3. Segerakkan pelayan dan pelanggan RPC, dan buat panggilan jauh
Kini, kami boleh membuat seketika pelayan dan pelanggan RPC, serta membuat panggilan jauh.

if __name__ == '__main__':
    server = RPCServer('localhost', 8000)
    server.start()
Salin selepas log masuk
if __name__ == '__main__':
    client = RPCClient('localhost', 8000)
    result = client.call('Calculator', 'add', 2, 3)
    print(result)  # Output: 5
Salin selepas log masuk

Ringkasnya, kami telah melaksanakan rangka kerja panggilan prosedur jauh RPC yang mudah menggunakan Python. Dengan mentakrifkan antara muka RPC dan menggunakan pengaturcaraan soket Python untuk komunikasi rangkaian, kami boleh membuat panggilan fungsi jauh dengan mudah dalam sistem teragih. Sudah tentu, contoh yang diberikan dalam artikel ini hanyalah pelaksanaan yang dipermudahkan, dan rangka kerja RPC sebenar mungkin perlu mengendalikan lebih banyak butiran komunikasi rangkaian dan kes tepi, tetapi idea asasnya adalah sama.

Saya harap artikel ini akan membantu anda memahami pelaksanaan rangka kerja RPC!

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan rangka kerja panggilan prosedur jauh RPC yang mudah dalam Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan