Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-01-2013, 11:26   #1
Mulder90
Senior Member
 
L'Avatar di Mulder90
 
Iscritto dal: Aug 2008
Città: Firenze
Messaggi: 317
[Python] Implementazione semplice Peer rete P2P

Salve,
Per un progetto universitario devo sviluppare un protocollo a livello applicativo che mi consenta di comunicare tra più peer in una rete locale. Il protocollo deve supportare due funzionalità che sono quelle di "discovery" e di "interact".
Nella fase di discovery, basata su UDP, devo poter scovare i possibili partecipanti nella rete locale. Nella fase di interact, basata du TCP, devo poter comunicare con uno o più partecipanti.
Sopra questo protocollo devo sviluppare una semplice chat.

Ho pensato subito ad un archiettura P2P e quindi ho scritto una semplice classe cercando di implementare un peer.
Posto il codice:

Codice:
import socket
import sys
import threading


def debug_message(string):
    print>>sys.stderr, "DEBUG MESSAGE: " + string


class Peer(object):

    def __init__(self, port, host=None, ID=None, max_peers=0):
        self.debug = True
        self.max_peers = int(max_peers)
        self.port = int(port)
        if host:
            self.host = host
        else:
            self.init_host()
        if ID:
            self.ID = ID
        else:
            self.ID = '%s:%s' % (self.host, self.port)
        if self.debug:
            debug_message(self.ID)
        self.shutdown = False
        self.peers = {}
        self.handlers = {"FIND": self.discovery, "QUIT":
                         self.quit_peer, "PRNT": self.print_peers, "WHO": self.who, "SEND": self.send_message}

    def init_host(self):
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.connect(("www.google.com", 80))
        self.host = sock.getsockname()[0]
        if self.debug:
            debug_message(self.host)
        sock.close()

    def who(self):
        print self.ID + ": (" + self.host + ":" + str(self.port) + ")"

    def init_sock(self):
        self.server_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        self.server_sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        self.server_sock.bind(('', self.port))
        self.clnt_sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        self.clnt_sock.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)

    def discovery(self):
        message = "ACK, %s" % (self.ID)
        self.clnt_sock.sendto(message, ('<broadcast>', self.port))

    def recive_message(self):
        while True:
            data, address = self.server_sock.recvfrom(1024)
            print data
            if data[:3] == 'ACK' and address not in self.peers:
                self.peers[address] = data[5:]
                #message = "ACK, %s" % (self.ID)
                self.discovery()

    def quit_peer(self):
        self.shutdown = True
        print "Exit"

    def main_loop(self):
        self.init_sock()
        r = threading.Thread(target=self.recive_message, args=[])
        r.daemon = True
        r.start()
        while not self.shutdown:
            try:
                self.msg = self.get_input()
                command = self.msg[:4]
                self.handle_peer(command)
            except KeyboardInterrupt:
                self.shutdown = True
                continue
        self.server_sock.close()
        self.clnt_sock.close()

    def handle_peer(self, command):
        if command in self.handlers:
            t = threading.Thread(target=self.handlers[command], args=[])
            t.start()
            t.join()
        else:
            print "no handler for this input"

    def get_input(self):
        print ">",
        return raw_input()

    def print_peers(self):
        for address, ID in self.peers.items():
            print address, ID

    def send_message(self):
        self.clnt_sock.sendto(self.msg[4:], ('<broadcast>', self.port))


if __name__ == '__main__':
    if len(sys.argv) == 4:
        p = Peer(port=sys.argv[1], ID=sys.argv[2], max_peers=sys.argv[3])
        p.main_loop()
    elif len(sys.argv) == 5:
        p = Peer(port=sys.argv[1], host=sys.argv[2], ID=sys.argv[
                 3], max_peers=sys.argv[4])
        p.main_loop()
I dubbi sono molti:
1)Consigli generali su Python per migliorare il codice?
2)Come posso implementare la fase di discovery? Ho pensato di mandare un messaggio in broadcast a tutti e, se si trovano partecipanti, aggiungerli ad un dizionario tramite il loro indirizzo e il loro identificativo.
Quando un Peer riceve un messaggio si salva il nome e l'indirizzo di chi l' ha mandato e risponde.
Il problema è che se faccio partire due programmi e faccio una FIND in uno dei due il dizionario non contiene entrambi gli indirizzi.
3)L'approccio di fare broadcast per trovare i possibili partecipanti è giusto?
4)Mi rendo conto che la classe Peer dovrebbe essere indipendente dalle varie funzioni del protocollo. Come potrei separare l'implementazione del protocollo da quella del Peer? Aggiungo i metodi del protocollo dentro il dizionario in un secondo momento?

Scusate per la poca chiarezza nella spiegazione.
Ah, non posso usare Twisted o altro...

Vi ringraziooooo

Ultima modifica di Mulder90 : 29-01-2013 alle 14:55. Motivo: improve PEP8
Mulder90 è offline   Rispondi citando il messaggio o parte di esso
Old 31-01-2013, 08:57   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da Mulder90 Guarda i messaggi
Salve,
Per un progetto universitario devo sviluppare un protocollo a livello applicativo che mi consenta di comunicare tra più peer in una rete locale. Il protocollo deve supportare due funzionalità che sono quelle di "discovery" e di "interact".
Nella fase di discovery, basata su UDP, devo poter scovare i possibili partecipanti nella rete locale. Nella fase di interact, basata du TCP, devo poter comunicare con uno o più partecipanti.
Sopra questo protocollo devo sviluppare una semplice chat.

Ho pensato subito ad un archiettura P2P e quindi ho scritto una semplice classe cercando di implementare un peer.
Posto il codice:

[...]

I dubbi sono molti:
1)Consigli generali su Python per migliorare il codice?
Ce ne sarebbero diversi, perché di Python usi lo stretto indispensabile.

Però è una cosa che puoi fare dopo, con comodo, quando il codice sarà funzionante.
Quote:
2)Come posso implementare la fase di discovery? Ho pensato di mandare un messaggio in broadcast a tutti e, se si trovano partecipanti, aggiungerli ad un dizionario tramite il loro indirizzo e il loro identificativo.
Quando un Peer riceve un messaggio si salva il nome e l'indirizzo di chi l' ha mandato e risponde.
Mi pare corretto.
Quote:
Il problema è che se faccio partire due programmi e faccio una FIND in uno dei due il dizionario non contiene entrambi gli indirizzi.
Potresti fare un dump di cosa trovano i due peer?
Quote:
3)L'approccio di fare broadcast per trovare i possibili partecipanti è giusto?
Sì, ma non ricordo adesso se con IPv6 sia possibile. Sono passati parecchi anni da quando l'ho studiato, ma mi sembra che non abbia il broadcast.

Quindi il tuo codice funzionerebbe soltanto con IPv4. Ma potrebbe andare bene, per un esercizio.
Quote:
4)Mi rendo conto che la classe Peer dovrebbe essere indipendente dalle varie funzioni del protocollo. Come potrei separare l'implementazione del protocollo da quella del Peer? Aggiungo i metodi del protocollo dentro il dizionario in un secondo momento?
Dipende dalle funzionalità che deve avere il Peer. Cosa permette di fare? Cioè di quale responsabilità si deve far carico?

Elenca un po' di requisiti, così verrà fuori il modello di Peer e di eventuali altre classi.
Quote:
Scusate per la poca chiarezza nella spiegazione.
Ah, non posso usare Twisted o altro...

Vi ringraziooooo
Di nulla, comunque cerca di fissare bene i requisiti, e vedrai che un po' alla volta ne uscirai fuori.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
La Cina impone requisiti anche per lo st...
Apple lancia AirTag aggiornato: range es...
Microsoft risolve i blocchi di Outlook: ...
OpenAI verso il disastro finanziario? L’...
X nei guai: l'UE indaga sui pericoli del...
Caso Corona-Signorini: il giudice blocca...
470 petaFLOPS con una frequenza di 56 GH...
WhatsApp: abbonamento per rimuovere la p...
Xiaomi Redmi Note 15 in promozione: smar...
NVIDIA investe 2 miliardi in CoreWeave: ...
Chery lancia con Lepas la piattaforma LE...
Xiaomi, nuovi sconti sui grandi elettrod...
Google AI Overviews preferisce YouTube a...
200 droni capaci di pianificare attacchi...
I food truck a New York ora si alimentan...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:52.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v