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