Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-11-2010, 13:08   #1
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
[VB.NET] Consiglio sviluppo applicazione client/server

Buongiorno,
dovrei sviluppare un'applicazione client/server con più client che operano tramite rete LAN.
Come database ho scelto MYSQL Server Express 2005 e questo risiede su un pc in modo che funziona da server.
Ora vorrei alcuni consigli prima di sviluppare la mia applicazione sapendo che vorrei svilupparla in MDI Client quindi:
  • Come faccio per evitare problemi di concorrenza dei dati quando 2 client effettuano contemporaneamente le operazioni?
  • Essendo un'applicazione con possibilità di aprire più form contemporaneamente, se per esempio un client ha aperto la form di visualizzazione dei dati e un'altro client va a modificare quella tabella, come si può gestire l'aggiornamento della tabella sull'altro client?

Qualsiasi altro commento, critica o consiglio e sempre ben gradito

Grazie
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 14:27   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da jackk87 Guarda i messaggi
  • Come faccio per evitare problemi di concorrenza dei dati quando 2 client effettuano contemporaneamente le operazioni?
  • Essendo un'applicazione con possibilità di aprire più form contemporaneamente, se per esempio un client ha aperto la form di visualizzazione dei dati e un'altro client va a modificare quella tabella, come si può gestire l'aggiornamento della tabella sull'altro client?
Molto "grossolanamente" :

- Della concorrenza se ne occupa MySQL, in quanto server...

- In generale, per avere maggior controllo sul comportamento dei singoli client, può essere utile avere sul server un servizio ( che ovviamente puoi sempre scrivere in VB.NET ) che fa da intermediario.
I client parlano con il Service, che gira le richieste al DB, e quindi può tenere traccia con esattezza e in ogni momento del "chi-sta-facendo-cosa"...

E' un bel progettino, insomma...
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2010, 16:10   #3
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Molto "grossolanamente" :

- Della concorrenza se ne occupa MySQL, in quanto server...

- In generale, per avere maggior controllo sul comportamento dei singoli client, può essere utile avere sul server un servizio ( che ovviamente puoi sempre scrivere in VB.NET ) che fa da intermediario.
I client parlano con il Service, che gira le richieste al DB, e quindi può tenere traccia con esattezza e in ogni momento del "chi-sta-facendo-cosa"...

E' un bel progettino, insomma...
Sisi è un bel progettino..

diciamo che cmq la concorrenza se ne occupa MySQL però per esempio un client sta modificato un record e un'altro client lo cancella questo tipo di concorrenza se ne occupa ugualmente MySQL?
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 09:30   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da jackk87 Guarda i messaggi
Sisi è un bel progettino..

diciamo che cmq la concorrenza se ne occupa MySQL però per esempio un client sta modificato un record e un'altro client lo cancella questo tipo di concorrenza se ne occupa ugualmente MySQL?
Detta così, NO.
Se il client A apre una connessione / carica il record X / chiude la connessione e mentre l'utente lavora in modalità disconnessa su quei dati, arriva l'utente B che, mettiamo con un semplice Command, dice "DELETE X", l'utente A avrà una brutta sorpresa quando farà il suo "UPDATE X".

Inoltre avere un Service aumenta notevolmente il livello di sicurezza.
Le stringhe di connessione di norma non andrebbero incluse nel client...
Solo chi "ha le chiavi" del server in teoria dovrebbe poter amministrare tutto.
Infine, prima di iniziare, studiati bene gli oggetti messi a disposizione dal provider di dati .NET per MySql...

Personalmente ho usato MySql solo per qualche sito, anche perchè restando su Microsoft in ambiente LAN, preferirei sicuramente avere a che fare con un Sql Server Express...
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 15:42   #5
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Detta così, NO.
Se il client A apre una connessione / carica il record X / chiude la connessione e mentre l'utente lavora in modalità disconnessa su quei dati, arriva l'utente B che, mettiamo con un semplice Command, dice "DELETE X", l'utente A avrà una brutta sorpresa quando farà il suo "UPDATE X".

Inoltre avere un Service aumenta notevolmente il livello di sicurezza.
Le stringhe di connessione di norma non andrebbero incluse nel client...
Solo chi "ha le chiavi" del server in teoria dovrebbe poter amministrare tutto.
Infine, prima di iniziare, studiati bene gli oggetti messi a disposizione dal provider di dati .NET per MySql...

Personalmente ho usato MySql solo per qualche sito, anche perchè restando su Microsoft in ambiente LAN, preferirei sicuramente avere a che fare con un Sql Server Express...
Scusa ma con MySQL intendevo Sql Server Express cmq i tuoi consigli sono di crearmi un service come per esempio una chat dove il service sarebbe il server e il client quando deve effettuare un'operazione invia un testo al server tipo "ciao" e il server gli invia la risposta.

Ho capito oppure sono fuori strada?

grazie ancora
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 17:50   #6
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da jackk87 Guarda i messaggi
Scusa ma con MySQL intendevo Sql Server Express cmq i tuoi consigli sono di crearmi un service come per esempio una chat dove il service sarebbe il server e il client quando deve effettuare un'operazione invia un testo al server tipo "ciao" e il server gli invia la risposta.

Ho capito oppure sono fuori strada?

grazie ancora
Ah.
C'è una bella differenza tra MySql e Sql Server... Comunque un Win Service NON è una chat. Anche se ho capito cosa intendi : sì, in soldoni il client A passa un comando al service, che opera sul DB e restituisce i risultati, oppure sa che la tabella X è sotto modifica da B e informa A che deve attendere...
Ma, ripeto, sono indicazioni di massima che devi prendere con le pinze : se hai un ufficio con una LAN e 3 client potrebbe benissimo essere superfluo avere un Win Service ( e a questo punto forse basterebbe un file Access in condivisione... ).
Se i client sono 30, sicuramente Sql Server, e poi devi valutare tu.
In ogni caso imparerai a fare un Win Service e ad usarlo : tutorial su VB.NET ce ne sono a centinaia, basta googlare un po'.
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 17:54   #7
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
grazie ancora marcoGG stavo googlando un pò infatti e ho trovato le transazioni,i trigger con i vari blocchi ecc...che si possono fare con sql server express secondo te qual'è la strada più semplice tra creare un win service oppure trigger,transazioni ecc..?

Se dovrei creare un windows service va bene questo concetto?:
client invia la richiesta al service
il service gli risponde se può procedere oppure se un'altro client sta utilizzando quel record

questo scambio di informazioni dovrei farlo utilizzando i thread?o non si possono utilizzare con nei windows service?

Ultima modifica di jackk87 : 28-11-2010 alle 18:17.
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 22:49   #8
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
Ciao MarcoGG in attesa della tua risposta sulle domande precedente ho provato a scrivere un windows service e allego i due file del progetto..
Ti chiedo cortesemente se puoi dare un'occhiata ai file in modo da sapere se sono sulla strada giusta o no..in precedenza avevo utilizzato lo stesso codice dei thread per un programma adesso l'ho adattato per un windows service..Se ti serve tutto il progetto fammi sapere grazie ancora
Allegati
File Type: zip WinService.zip (1.8 KB, 16 visite)
jackk87 è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 22:55   #9
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da jackk87 Guarda i messaggi
grazie ancora marcoGG stavo googlando un pò infatti e ho trovato le transazioni,i trigger con i vari blocchi ecc...che si possono fare con sql server express secondo te qual'è la strada più semplice tra creare un win service oppure trigger,transazioni ecc..?
Direi che forse hai le idee un po' confuse. Non sono cose che si escludono a vicenda. Avere un service serve a gestire meglio la concorrenza e la sicurezza. Stored Procedures e Triggers sono propri di Sql Server.
Tornando al discorso di prima ( utente A che modifica record X mentre utente B lo cancella ), un Trigger non risolve niente... Se B cancella X con una DELETE diretta da Command o se chiama una SP che fa la DELETE, il problema è lo stesso.

Quote:
Originariamente inviato da jackk87 Guarda i messaggi
Se dovrei creare un windows service va bene questo concetto?:
client invia la richiesta al service
il service gli risponde se può procedere oppure se un'altro client sta utilizzando quel record
Era quello che consigliavo. Perchè mi pare di capire che non sei molto addentro nell'Sql avanzato, perciò forse è meglio che, almeno inizialmente, ti impari per bene i Service, e mantieni il DB più pulito e semplice che puoi...

Quote:
Originariamente inviato da jackk87 Guarda i messaggi
questo scambio di informazioni dovrei farlo utilizzando i thread?o non si possono utilizzare con nei windows service?
Non necessariamente. Stai mettendo troppa carne al fuoco tutta insieme.
Inizia con gli elementi di base, il DB, un semplice Service, alcuni Client.
E prova da subito a fare operazioni semplici in concorrenza. Non aspettare di aver finito tutto prima di fare il primo test.
Fai un DB di prova monotabella, e poi vedi come va.
Ma non c'è un consiglio definitivo che posso darti tipo "fai sicuramente così".
Tieni presente che un'applicazione LAN ha molte soluzioni possibili, e che quello che stai per realizzare è "tosto".

Se sei agli inizi, parti dal semplice.
Devi trovare il giusto compromesso tra semplicità e funzionalità : se il grado di semplicità ti garantisce che arriverai a completare al 100% il tuo progetto, e la funzionalità ti da risultati accettabili ( e questo puoi testarlo solo tu ), quella sarà la tua soluzione.
Maggior complessità ( Service Multithreaded ecc... ) può significare maggior prestazione, ma con quali garanzie sui tempi e sul fatto che sarai in grado di completare l'applicazione ?
Non sono rare le discussioni sul web in cui c'è gente che si butta a testa bassa a scrivere codice multithread, e poi non sa più come andare avanti.
E' l'unica indicazione di buon senso che posso darti, dato che non so nulla del tuo progetto, e sinceramente non vorrei che questo thread sfociasse nella classica "consulenza" a spizzichi & bocconi...
__________________
Contattami su FaceBook --> [ ::: MarcoGG su FaceBook ::: ]
Visita il mio Blog --> [ ::: Il Blog di MarcoGG ::: ]
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2010, 22:58   #10
jackk87
Senior Member
 
Iscritto dal: Jan 2007
Messaggi: 404
ok MarcoGG grazie come sempre inizio a fare qualcosa di pratico
jackk87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Grazie a VLT è stata misurata dir...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
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: 05:07.


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