Bingehên xebata bi zmq di python de, afirandina dikanek mifteyek / nirxek hêsan

Pîrozbahiyê

Werin em li mînakek hilanînek kilît/nirxek hêsan, wek memcache, binêrin. Ew bi hêsanî hatî sêwirandin - dane di bîranînê de, di avahiyek hashmap de têne hilanîn. Ew bi riya soketek tcp têne gihîştin. Di Python de, hashmap fermanek birêkûpêk e. Ji bo gihîştinê em ê zeromq bikar bînin.

ligorî

Ji bo sazkirina vê pakêtê di debian/ubuntu de, tenê têkevin konsolê
sudo apt-get install libzmq-dev
sudo pip install zmq

code

Ka em dersek binivîsin ku bi servera xwe re bixebitin:
Cûreya soketa zmqê ya ku tê bikar anîn REQ (Daxwazîn, daxwaz) e, em daxwazek dişînin û li benda bersivê ne.
Ji bo hilanîn û veguheztina her cûre daneyê li ser torê, em modulê standarda pickle bikar tînin. Xebata "protokola" ji sê nirxan pêk tê: (ferman, key, dane)

import zmq
import pickle

class SuperCacher:
    def __init__(self):
        context = zmq.Context()
        self.socket = context.socket(zmq.REQ)
        self.socket.connect('tcp://127.0.0.1:43000')

    def get(self, key):
        self.socket.send(pickle.dumps(('get', key, None)))
        return pickle.loads(self.socket.recv())

    def set(self, key, data):
        self.socket.send(pickle.dumps(('set', key, data)))
        return self.socket.recv() == b'ok'
Bikar bînin

cache = SuperCacher ()
cache.set('key', 'nirx')
cache.get('key')

Wekî karê malê, bi lêzêdekirina kapasîteya diyarkirina navnîşanek / portê dema ku mînakek polê çêbike, pêkanînê baştir bikin.

Naha em serverê bixwe binivîsin.
Vê carê soketa REP (REPly, bersiv) tê bikar anîn - em li benda daxwazê ​​ne, bersivek dişînin. Em daxwazê ​​pars dikin û di warê nivîsandinê de bi 'ok', an di rewşa xwendinê de bi daneyan / Nabe bersiv didin.

import pickle
import json
import zmq

def run_daemon():
    memory = {}

    context = zmq.Context()
    socket = context.socket(zmq.REP)
    socket.bind('tcp://127.0.0.1:43000')

    while True:
        try:
            command, key, data = pickle.loads(socket.recv())
            if command == 'set':
                memory[key] = data
                socket.send(b'ok')
            elif command == 'get':
                result = memory.get(key, None)
                socket.send(pickle.dumps(result))
        except Exception as e:
            print(e)

if __name__ == '__main__':
    run_daemon()

Ji bo ceribandina her tiştî bi hev re, em serverê bi fermanê dest pê dikin
python daemon.py

Di tabloya paşîn de, python di moda înteraktîf de bidin destpêkirin.

>>> from lib import SuperCacher
>>> cache=SuperCacher()
>>> cache.set('key', 'value')
True
>>> cache.get('key')
'value'

Oh mûcîze, ew dixebite! Naha hûn dikarin bi ewlehî di reseniya xwe de binivîsin "pêşxistina hilanînê-nirxa sereke bi karanîna protokola zmq"

Source: www.habr.com

Add a comment