Bazat e punës me zmq në python, duke krijuar një dyqan të thjeshtë çelësi/vlere

Paraqitje

Le të shohim një shembull të një ruajtjeje të thjeshtë çelësi/vlere, siç është memcache. Është projektuar thjesht - të dhënat ruhen në memorie, në një strukturë hashmap. Ato aksesohen nëpërmjet një prize tcp. Në Python, hashmap është një diktim i rregullt. Për akses do të përdorim zeromq.

rregullim

Për të instaluar këtë paketë në debian/ubuntu, thjesht futeni në tastierë
sudo apt-get install libzmq-dev
sudo pip install zmq

Kod

Le të shkruajmë një klasë për të punuar me serverin tonë:
Lloji i folesë zmq i përdorur është REQ(KËRKESË, kërkesë), ne dërgojmë një kërkesë dhe presim një përgjigje.
Për të ruajtur dhe transmetuar çdo lloj të dhënash përmes rrjetit, ne përdorim modulin standard të turshive. "Protokolli" i punës është një tufë me tre vlera: (komandë, çelës, të dhëna)

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'
Përdorim

cache = SuperCacher()
cache.set('çelësi', 'vlera')
cache.get ('çelës')

Si detyrë shtëpie, përmirësoni zbatimin duke shtuar aftësinë për të specifikuar një adresë/port kur krijoni një shembull të një klase.

Tani le të shkruajmë vetë serverin.
Këtë herë përdoret foleja REP(REPly, përgjigje) - ne jemi duke pritur për kërkesën, duke dërguar një përgjigje. Ne analizojmë kërkesën dhe përgjigjemi ose me 'ok' në rastin e shkrimit, ose me të dhëna / Asnjë në rastin e leximit.

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()

Për të testuar gjithçka së bashku, ne e nisim serverin me komandën
python daemon.py

Në skedën tjetër, nisni python në modalitetin interaktiv.

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

Oh mrekulli, funksionon! Tani mund të shkruani me siguri në CV tuaj "zhvillimi i ruajtjes së vlerave kryesore duke përdorur protokollin zmq"

Burimi: www.habr.com

Shto një koment