Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-05-2010, 15:16   #1
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
[Java EE - EJB3] ... i servizi della web application

Salve a tutti

Sto sviluppando una web application con la piattaforma java EE.L'archietettura è la seguente:

Presentation Layer: JSF
Business Layer: EJB + Spring
Persistence Layer: JPA

Il mio strato di dominio è composto da svariate entità,che sono state mappate con il database sottostante.

A livello persistenza i servizi sono offerti da apposte classi DAO,una per ogni entità che ho definito nel dominio:

Esempio:
Per l'entità FATTURA ho creato la classe FatturaDAO,che espone tutti i servizi di accesso ai dati che riguardano l'entità fattura ( inserisciFattura , eliminaFattura etc etc.)


A livello di business-logic ho deciso di implementare i servizi suddividendoli per in base ai ruoli con i quali è possibile accedere all'applicazione:

EJB : VenditoreIngrossoService

che esponde tutti i servizi dedicati a un venditore all'ingrosso.Questi servizi di "alto livello" espletano la loro funzione interfacciandosi con i vari DAO del livello sottostante.

I serivizi sono suddivisi in modo logico ? C'e' qualche aspetto che non ho valutato?

Mi piacerebbe sentire il parere di qualcuno con piu esperienza del sottoscritto....

Ultima modifica di javacomelava : 03-05-2010 alle 15:30.
javacomelava è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2010, 15:52   #2
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Sostanzialmente tu utilizzi nel layer di logica degli EJB facàde che incorporano diverse entità di persistenza ed è un approccio che francamente odio, anche se prestazionalmente può risultare migliori in alcune circostanze, quando ad esempio si opera su server distribuiti, al costo di appesantire il codice centralizzato.
Parlando invece del layer persistenza in sè, bisogna vedere se è veramente utile una gestione BMP quindi completamente programmatica, piuttosto che CMP quindi gestista dal container (parlando in termini familiari alla specifica 2).

Ultima modifica di nuovoUtente86 : 03-05-2010 alle 15:59.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2010, 16:27   #3
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
E' proprio cosi'. Da quello che hai detto confermi i miei dubbi. In questo modo ho pochi service EJB (centralizzando il codice),ma ogni service è bello corposo a livello di codice.La mia principale paura è quella di avere problemi di performance e affidabilità del sistema nel caso in cui molti client si connettessero all'applicazione.

Per quanto riguarda lo strato di persistenza ho deciso di gestirla da me con le mie manine,quindi BMP.

Posso chiederti come mai odi questo stile di strutturazione?
Quale metodo prediligi?

Io ho sviluppato in questo modo in quanto mi è sembrato molto naturale.
A lavoro finito mi sono ovviamente venuti i dubbi,che come ho detto ,riguardano soprattutto la performance e l'affidabilità.Il fatto che sia un pivelletto novizio con queste tecnologie poi mi fa far dei viaggi mentali...altro che film di star wars!
javacomelava è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2010, 17:23   #4
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Quote:
Originariamente inviato da javacomelava Guarda i messaggi
E' proprio cosi'. Da quello che hai detto confermi i miei dubbi. In questo modo ho pochi service EJB (centralizzando il codice),ma ogni service è bello corposo a livello di codice.La mia principale paura è quella di avere problemi di performance e affidabilità del sistema nel caso in cui molti client si connettessero all'applicazione.

Per quanto riguarda lo strato di persistenza ho deciso di gestirla da me con le mie manine,quindi BMP.

Posso chiederti come mai odi questo stile di strutturazione?
Quale metodo prediligi?

Io ho sviluppato in questo modo in quanto mi è sembrato molto naturale.
A lavoro finito mi sono ovviamente venuti i dubbi,che come ho detto ,riguardano soprattutto la performance e l'affidabilità.Il fatto che sia un pivelletto novizio con queste tecnologie poi mi fa far dei viaggi mentali...altro che film di star wars!
Il pattern facàde nasce come estensione del proxy, quindi l' intento è quello di esporre servizi celandone l' implementazione (le stesse classi DAO sono dei proxy, nascondendo di fatto i meccanismi di storage) mettendo in comunicazione tra loro oggetti affiatati. Spesso in letteratura è portato l' esempio di un client di posta con i vari moduli smtp, pop, correttore ortografico, ecc. In tale contesto l' utilizzo di un facàde trova una giustificazione, ma viceversa spessissimo si abusa di tale pattern accorpando anche entità logicamente scorrelate.
Quanto alla gestione programmatica, non la vedo affatto utile potendo sfruttare gli entity bean (quindi il meccanismo ORM) messi a disposizione dalla specifica 3 grazie alle api jpa.
La cosa più lineare è quella di mappare il dominio attraverso gli entity e spostare la logica (quindi ri-mappando il dominio nel livello applicativo)nei session, indipendentemente dal fatto che poi si opti per l' utilizzo dei session facàde o meno.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Windows 95: perché Microsoft non ...
Mappa degli amici su Instagram: i dubbi ...
SpaceX: eseguito lo static fire di Super...
Volkswagen sorprende all'IAA 2025: svela...
Rabbit R1, prove di rinascita dopo il fl...
Windows 11 porta l'intelligenza artifici...
Nilox svela la sua nuova gamma: ci sono ...
Juventus-Inter, novità storica: l...
SAP presenta il suo cloud sovrano per l'...
Google riduce i costi di Veo 3: i video ...
Signal introduce i backup in cloud: grat...
Pure Loop 3 FX, da be quiet! un modo sem...
Hollow Knight: Silksong, scoperto un cod...
AMD espande il supporto di FSR 4 a oltre...
Tesla lancia Megablock e Megapack 3: bat...
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: 14:17.


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