Jakarta Enterprise Beans - Jakarta Enterprise Beans
Jakarta Enterprise Beans (EJB; Enterprise JavaBeans) je jedním z několika Java API pro modulární konstrukci podnikový software. EJB je na straně serveru softwarová součást že zapouzdřuje obchodní logika aplikace. EJB webový kontejner poskytuje a běhové prostředí pro webové softwarové komponenty, včetně zabezpečení počítače, Správa životního cyklu servletu Java, zpracování transakcí, a další webové služby. Specifikace EJB je podmnožinou souboru Java EE Specifikace.[1]
Specifikace
Specifikace EJB byla původně vyvinuta v roce 1997 společností IBM a později přijato Sun Microsystems (EJB 1.0 a 1.1) v roce 1999[2] a vylepšené pod Proces komunity Java tak jako JSR 19 (EJB 2.0), JSR 153 (EJB 2.1), JSR 220 (EJB 3.0), JSR 318 (EJB 3.1) a JSR 345 (EJB 3.2).
Specifikace EJB poskytuje standardní způsob implementace na straně serveru (také nazývaný „back-end „)„ obchodní “software, který se obvykle nachází v podnikových aplikacích (na rozdíl od„ front-endu “) uživatelské rozhraní software). Takový software řeší stejné typy problémů a řešení těchto problémů jsou programátory často opakovaně znovu implementována. Společnost Jakarta Enterprise Beans je určena k řešení společných záležitostí jako vytrvalost, transakční integrita a bezpečnostní standardním způsobem a ponechává programátorům volnost soustředit se na konkrétní části podnikového softwaru.
Obecné povinnosti
Specifikace EJB podrobně popisuje, jak aplikační server poskytuje následující odpovědnosti:
- Zpracování transakce
- Integrace s vytrvalost služby nabízené Jakarta Persistence (JPA)
- Řízení souběžnosti
- Programování řízené událostmi použitím Jakarta Messaging (JMS) a Jakarta konektory (JCA)
- Vyvolání asynchronní metody
- Plánování úloh
- Pojmenování a adresářové služby přes Rozhraní Java Naming and Directory (JNDI)
- Meziprocesová komunikace použitím RMI-IIOP a webové služby
- Bezpečnostní (JCE a JAAS )
- Rozvinutí z softwarové komponenty na aplikačním serveru
Specifikace Jakarta Enterprise Beans dále definuje role, které hraje kontejner EJB a EJB, a také způsob nasazení EJB v kontejneru. Všimněte si, že specifikace EJB neuvádí podrobně, jak aplikační server poskytuje stálost (úkol delegovaný na specifikaci JPA), ale místo toho podrobně popisuje, jak se obchodní logika může snadno integrovat se službami stálosti nabízenými aplikačním serverem.
Dějiny
Podniky zjistily, že použití EJB k zapouzdření obchodní logiky přineslo výkonnostní trest. Důvodem je, že původní specifikace povolena pouze pro vzdálené vyvolání metody prostřednictvím CORBA (a volitelně další protokoly), i když to velká většina obchodních aplikací ve skutečnosti nevyžaduje distribuované výpočty funkčnost. Specifikace EJB 2.0 tento problém vyřešila přidáním konceptu lokálních rozhraní, která lze volat přímo bez penalizace výkonu aplikací, které nebyly distribuovány na více serverech.[3]
Specifikace EJB 3.0 (JSR 220) byl odklon od svých předchůdců po novém paradigmatu nízké hmotnosti. EJB 3.0 ukazuje vliv od Jaro v používání prostých objektů Java a jeho podpora pro injekce závislostí zjednodušit konfiguraci a integraci heterogenních systémů. Gavin King, tvůrce Hibernate, se účastnil procesu EJB 3.0 a je přímým zastáncem této technologie. Mnoho funkcí původně v režimu spánku bylo začleněno do Java Persistence API, náhrada za entita fazole v EJB 3.0. Specifikace EJB 3.0 do značné míry závisí na použití anotace (funkce přidaná do jazyka Java ve verzi 5.0) a konvence nad konfigurací umožnit mnohem méně podrobný styl kódování. Z praktického hlediska je tedy EJB 3.0 mnohem lehčí a téměř úplně nové API, které se málo podobá předchozím specifikacím EJB.[Citace je zapotřebí ]
Příklad
Následující příklad ukazuje základní příklad toho, jak EJB vypadá v kódu:
@ Bez státní příslušnosti veřejnost třída Služby zákazníkům { soukromé EntityManager entityManager; veřejnost prázdnota addCustomer(Zákazník zákazník) { entityManager.přetrvávat(zákazník); } }
Výše uvedené definuje třídu služby pro přetrvávání objektu zákazníka (přes O / R mapování ). EJB se stará o správu kontextu perzistence a metoda addCustomer () je ve výchozím nastavení transakční a bezpečná pro vlákna. Jak bylo prokázáno, EJB se zaměřuje pouze na obchodní logiku a vytrvalost a neví nic o konkrétní prezentaci.
Takový EJB může být použita třídou např. webovou vrstvu následujícím způsobem:
@ Jmenováno @RequestScopedveřejnost třída Zákaznická podpora { @EJB soukromé Služby zákazníkům služby zákazníkům; veřejnost Tětiva addCustomer(Zákazník zákazník) { služby zákazníkům.addCustomer(zákazník); kontext.addMessage(...); // zkráceno pro stručnost vrátit se „customer_overview“; }}
Výše uvedené definuje a Tváře JavaServeru (JSF) podpůrná fazole, do které je vložen EJB pomocí anotace @EJB. Jeho metoda addCustomer je obvykle vázána na nějakou komponentu uživatelského rozhraní, například na tlačítko. Na rozdíl od EJB podpůrná fazole neobsahuje žádný kód obchodní logiky nebo perzistence, ale deleguje tyto obavy na EJB. Podpůrná fazole ví o konkrétní prezentaci, o které EJB nevěděl.
Druhy Enterprise Beans
Kontejner EJB pojme dva hlavní druhy fazolí:
- Fazole relace[4] které mohou být buď „stavové“, „bez státní příslušnosti“ nebo „singleton“ a lze k nim přistupovat prostřednictvím a Místní (stejný JVM) nebo Dálkový (jiné JVM) rozhraní nebo přímo bez rozhraní,[5] v takovém případě platí místní sémantika. Všechny fazole relace podporují asynchronní provádění[6] pro všechna zobrazení (místní / vzdálená / bez rozhraní).
- Fazole řízené zprávami (MDBs, also known as Message Beans). MDB také podporují asynchronní provádění, ale prostřednictvím paradigmatu zasílání zpráv.
Fazole relace
Stavové fazole
Stavové fazole[7] mají obchodní objekty Stát: to znamená, že během celé relace sledují, s kterým volajícím klientem jednají, a proto je přístup k instanci fazole přísně omezen pouze na jednoho klienta najednou.[8] Pokud se přesto pokusí o souběžný přístup k jedné fazole, kontejner tyto požadavky serializuje, ale pomocí anotace @AccessTimeout může kontejner místo toho vyvolat výjimku.[9] Stav stavových fazolí relace může být kontejnerem přetrváván (pasivován), aby se uvolnilo paměť poté, co klient po určitou dobu k fazole nepřistoupil. Kontext rozšířené perzistence JPA je výslovně podporován nástrojem Stateful Session Beans.[10]
- Příklady
- Odhlášení v internetovém obchodě může být provedeno stavovým fazolím relace, které by pomocí svého stavu sledovalo, kde se zákazník nachází v procesu platby, případně může blokovat položky, které zákazník kupuje (z pohledu architektury systému , bylo by méně ideální nechat klienta spravovat tyto zámky).
Fazole bez státní příslušnosti
Fazole bez státní příslušnosti[11] jsou obchodní objekty, které k nim nemají přidružený stav. Přístup k jedné instanci objektu bean je však stále omezen pouze na jednoho klienta najednou, souběžně přístup k fazoli je zakázán.[8] Pokud se pokusíte o souběžný přístup k jedné fazole, kontejner jednoduše směruje každý požadavek do jiné instance.[12] Díky tomu je fazole relace bez státní příslušnosti automaticky bezpečná pro vlákna. Proměnné instance lze použít během jednoho volání metody z klienta do objektu bean, ale není zaručeno, že obsah těchto proměnných instance bude zachován napříč různými klienty metoda hovory. Instance fazolí bezstavové relace se obvykle sdružují. Pokud druhý klient přistupuje ke konkrétní fazole hned po dokončení volání metody provedeného prvním klientem, může získat stejnou instanci. Nedostatek režijních nákladů na udržování konverzace s volajícím klientem je činí méně náročnými na zdroje než stavové fazole.
- Příklady
- Odeslání e-mailu na zákaznickou podporu může zpracovat bezstavová fazole, protože se jedná o jednorázovou operaci a není součástí vícestupňového procesu.
- Uživatel webu, který klikne na políčko „informovat mě o budoucích aktualizacích“, může spustit volání asynchronní metody fazole relace a přidat uživatele do seznamu v databázi společnosti (toto volání je asynchronní, protože uživatel musíte počkat, až budete informováni o jeho úspěchu nebo neúspěchu).
- Načítání více nezávislých dat pro web, jako je seznam produktů a historie aktuálního uživatele, může být zpracováno také asynchronními metodami fazole relace (tato volání jsou asynchronní, protože je lze spustit v paralelní tímto způsobem, což potenciálně zvyšuje výkon). V tomto případě asynchronní metoda vrátí a Budoucnost instance.
Fazole Singleton Session
Fazole Singleton Session Beans[13][14] jsou obchodní objekty mající globální sdílený stav v rámci JVM. Souběžný přístup k jediné instanci objektu bean lze ovládat kontejnerem (Container-managed concurrency, CMC) nebo samotným objektem bean (Bean-managed concurrency, BMC). CMC lze vyladit pomocí poznámky @Lock, která určuje, zda se pro volání metody použije zámek pro čtení nebo zámek pro zápis. Kromě toho mohou Singleton Session Beans explicitně požadovat vytvoření instance při spuštění kontejneru EJB pomocí poznámky @Startup.
- Příklady
- Načtení globálního denního ceníku, který bude stejný pro každého uživatele, lze provést pomocí fazole singleton session, protože to zabrání tomu, aby aplikace musela do databáze opakovat stejný dotaz znovu a znovu ...
Fazole řízené zprávami
Fazole řízené zprávami[15] jsou obchodní objekty, jejichž provádění je spouštěno zprávami namísto volání metod. Message Driven Bean se mimo jiné používá k zajištění abstrakce na vysoké úrovni pro snadné použití pro nižší úroveň JMS (Služba zpráv Java ) Specifikace. Může se přihlásit k odběru front zpráv JMS nebo témat zpráv, k čemuž obvykle dochází prostřednictvím atributu activationConfig anotace @MessageDriven. Byly přidány do EJB, aby bylo umožněno zpracování řízené událostmi. Na rozdíl od fazolí relace nemá MDB pohled klienta (lokální / vzdálený / bez rozhraní), tj. E. klienti nemohou vyhledat instanci MDB. MDB pouze naslouchá jakékoli příchozí zprávě například ve frontě nebo tématu JMS a automaticky je zpracovává. Specifikace Java EE vyžaduje pouze podporu JMS,[16] ale Message Driven Beans může podporovat další protokoly zasílání zpráv.[17][18] Takové protokoly mohou být asynchronní, ale mohou být také synchronní. Vzhledem k tomu, že fazole relace mohou být také synchronní nebo asynchronní, není hlavním rozdílem mezi fazemi relace a zprávami synchronizace, ale rozdíl mezi (objektově orientovaný) metoda povolání a zasílání zpráv.
- Příklady
- Odeslání aktualizace konfigurace do více uzlů může být provedeno odesláním zprávy JMS do 'tématu zprávy' a může být zpracováno Beanem typu Message Driven, který poslouchá toto téma (zde se používá paradigma zprávy, protože odesílatel nemusí znát počet spotřebitelů, jejich umístění nebo dokonce jejich přesný typ).
- Odeslání úlohy do pracovního klastru může být provedeno odesláním zprávy JMS do 'fronty zpráv' a může být také zpracováno Beanem typu Message Driven Bean, ale tentokrát poslech fronty (používá se paradigma zprávy a fronta, protože odesílatele nemusí zajímat, který pracovník úlohu vykonává, ale potřebuje ujištění, že se úloha provede pouze jednou).
- Zpracování časových událostí z Plánovač křemene může být zpracován pomocí zprávy řízené fazolí; když křemen spoušť požáry, MDB je automaticky vyvolána. Jelikož Java EE ve výchozím nastavení o Quartzu neví, a JCA potřeboval by zdrojový adaptér a MDB by byl anotován s odkazem na toto.[19]
Provedení
EJB jsou nasazeny v kontejneru EJB, obvykle v rámci aplikační server. Specifikace popisuje, jak EJB interaguje s jeho kontejnerem a jak klientský kód interaguje s kombinací kontejner / EJB. Třídy EJB používané aplikacemi jsou součástí javax.ejb
balík. (The javax.ejb.spi
balíček je rozhraní poskytovatele služeb používá pouze implementace kontejneru EJB.)
Klienti EJB neprovádějí instanci těchto fazolí přímo přes nový operátor Javy, ale místo toho musí získat odkaz prostřednictvím kontejneru EJB. Tento odkaz obvykle není odkazem na samotný implementační objekt, ale na a proxy, který buď dynamicky implementuje místní nebo vzdálené obchodní rozhraní, které klient požadoval, nebo dynamicky implementuje podtyp skutečné fazole. Proxy pak lze přímo přenést do rozhraní nebo fazole. Říká se, že klient má „pohled“ na EJB a místní rozhraní, vzdálené rozhraní a samotný typ fazole odpovídají místnímu zobrazení, vzdálenému zobrazení a zobrazení bez rozhraní.
Tento proxy je potřebný, aby měl kontejner EJB příležitost transparentně poskytovat průřezové (AOP služby podobné fazole, jako jsou transakce, zabezpečení, odposlechy, injekce a vzdálená komunikace. Jako příklad klient vyvolá metodu na serveru proxy, který nejprve zahájí transakci pomocí kontejneru EJB a poté zavolá metodu skutečné fazole. Když se vrátí metoda bean, proxy ukončí transakci (tj. Spácháním nebo provedením vrácení zpět) a předá kontrolu zpět klientovi.
Kontejner EJB je odpovědný za zajištění toho, aby kód klienta měl dostatečná přístupová práva k EJB.[20] Bezpečnostní aspekty lze deklarativně aplikovat na EJB prostřednictvím anotací.[21]
Transakce
Kontejnery EJB musí podporovat oba spravované kontejnery KYSELINA transakce a transakce spravované fazolí.[22]
Transakce spravované kontejnerem (CMT) jsou ve výchozím nastavení aktivní pro volání fazolí relace. To znamená, že není nutná žádná explicitní konfigurace. Toto chování může fazole deklarativně vyladit pomocí anotací a v případě potřeby může být taková konfigurace později přepsána v deskriptoru nasazení. Ladění zahrnuje vypnutí transakcí pro celou fazole nebo specifické metody nebo požadavek na alternativní strategie pro šíření transakcí a zahájení nebo připojení k transakci. Tyto strategie se zabývají hlavně tím, co by se mělo stát, pokud transakce v době volání fazole již probíhá nebo neprobíhá. Podporovány jsou následující varianty:[23][24]
Typ | Vysvětlení |
---|---|
POVINNÉ | Pokud klient nezačal transakci, je vyvolána výjimka. Jinak se použije transakce klienta. |
POŽADOVANÉ | Pokud klient zahájil transakci, použije se. Jinak je zahájena nová transakce. (toto je výchozí nastavení, pokud nebyl zadán žádný explicitní typ) |
REQUIRES_NEW | Pokud klient zahájil transakci, je pozastavena. Nová transakce je vždy spuštěna. |
PODPORUJE | Pokud klient zahájil transakci, použije se. Jinak se nepoužije žádná transakce. |
NENÍ PODPOROVÁNO | Pokud klient zahájil transakci, je pozastavena. Není zahájena žádná nová transakce. |
NIKDY | Pokud klient zahájil transakci, je vyvolána výjimka. Není zahájena žádná nová transakce. |
Alternativně může fazole také deklarovat prostřednictvím anotace, že chce zpracovat transakce programově prostřednictvím JTA API. Tento režim provozu se nazývá Bean Managed Transactions (BMT), protože bean sám zpracovává transakci namísto kontejneru.[25]
Události
JMS (Služba zpráv Java ) slouží k odesílání zpráv z fazolí klientům, aby klienti mohli přijímat asynchronní zprávy z těchto fazolí. MDB lze použít k přijímání zpráv od klientů asynchronně pomocí buď a JMS Fronta nebo téma.
Pojmenování a adresářové služby
Jako alternativu k injekci mohou klienti EJB získat odkaz na objekt proxy fazole relace (útržek EJB) pomocí Java Naming and Directory Interface (JNDI). Tuto alternativu lze použít v případech, kdy není k dispozici injekce, například v nespravovaném kódu nebo samostatných vzdálených klientech Java SE, nebo když je nutné programově určit, kterou fazoli získat.
Názvy JNDI pro fazole relace EJB jsou přiřazeny kontejneru EJB pomocí následujícího schématu:[26][27][28]
Rozsah | Vzor jména |
---|---|
Globální | java: global [/ |
aplikace | java: app / |
Modul | java: module / |
(položky v hranatých závorkách označují volitelné části)
Jedno fazole lze získat jakýmkoli jménem odpovídajícím výše uvedeným vzorům, v závislosti na „umístění“ klienta. Klienti ve stejném modulu jako požadovaná fazole mohou používat rozsah modulu a větší rozsahy, klienti ve stejné aplikaci jako požadovaná fazole mohou používat rozsah aplikace a vyšší atd.
Např. kód běžící ve stejném modulu jako fazole CustomerService (jak je uvedeno v příkladu ukázaném dříve v tomto článku) mohl použít následující kód k získání (místního) odkazu na něj:
CustomerServiceLocal služby zákazníkům = (CustomerServiceLocal) Nový InitialContext().vzhlédnout(„java: module / CustomerService“);
Vzdálená komunikace / distribuované spuštění
Pro komunikaci s klientem, který je napsán v programovacím jazyce Java, může relační fazole vystavit vzdálené zobrazení prostřednictvím anotovaného rozhraní @Remote.[29] To umožňuje volání těchto fazolí od klientů v jiných JVM které samy o sobě mohou být umístěny na jiných (vzdálených) systémech. Z pohledu kontejneru EJB je jakýkoli kód v jiném JVM vzdálený.
Fazole relace bez státní příslušnosti a Singleton mohou také vystavovat „pohled klienta webové služby“ pro vzdálenou komunikaci prostřednictvím WSDL a MÝDLO nebo prostý XML.[30][31][32] Toto následuje JAX-RPC a JAX-WS Specifikace. Pro budoucí odebrání je však navržena podpora JAX-RPC.[33] Pro podporu JAX-WS je fazole relace anotována anotací @WebService a metodami, které mají být vystaveny vzdáleně s anotací @WebMethod.
Ačkoli specifikace EJB nijak nezmiňuje vystavení jako webové služby RESTful a nemá žádnou výslovnou podporu pro tuto formu komunikace, JAX-RS specifikace výslovně podporuje EJB.[34] V návaznosti na specifikaci JAX-RS mohou být fazole relace Stateless a Singleton kořenovými prostředky prostřednictvím anotace @Path a obchodní metody EJB lze mapovat na metody prostředků prostřednictvím anotací @GET, @PUT, @POST a @DELETE. To se však nepočítá jako „zobrazení klienta webové služby“, které se používá výhradně pro JAX-WS a JAX-RPC.
Komunikace prostřednictvím webových služeb je typická pro klienty, kteří nejsou napsáni v programovacím jazyce Java, ale je také vhodná pro klienty Java, kteří mají potíže s dosažením serveru EJB prostřednictvím brány firewall. Komunikaci založenou na webových službách mohou klienti Java dále používat k obcházení tajemných a nedefinovaných požadavků na takzvané „klientské knihovny“; sada souborů jar, které musí mít klient Java na své cestě ke třídě, aby mohl komunikovat se vzdáleným serverem EJB. Tyto klientské knihovny potenciálně konfliktují s knihovnami, které klient již může mít (například pokud je klient sám také úplným serverem Java EE) a takový konflikt je považován za velmi těžký nebo nemožný k vyřešení.[35]
Dědictví
Domácí rozhraní a požadované obchodní rozhraní
S EJB 2.1 a staršími musel každý EJB zajistit implementaci Java třída a dvě rozhraní Java. Kontejner EJB vytvořil instance třídy implementace Java, aby poskytl implementaci EJB. Rozhraní Java byla používána kódem klienta EJB.
Požadovaný deskriptor nasazení
S EJB 2.1 a dřívějšími specifikacemi EJB vyžadoval přítomnost deskriptoru nasazení. To bylo nutné k implementaci mechanismu, který umožňoval existenci EJB nasazen konzistentním způsobem bez ohledu na konkrétní platformu EJB, která byla vybrána. V deskriptoru implementace musely být uvedeny informace o tom, jak by měl být bean nasazen (například název domovského nebo vzdáleného rozhraní, zda a jak uložit bean v databázi atd.).
The deskriptor nasazení je XML dokument obsahující záznam pro každý EJB, který má být nasazen. Tento dokument XML specifikuje následující informace pro každý EJB:
- Název domovského rozhraní
- Třída Java pro Bean (obchodní objekt)
- Rozhraní Java pro domácí rozhraní
- Rozhraní Java pro obchodní objekt
- Trvalé úložiště (pouze pro Entity Beans)
- Role zabezpečení a oprávnění
- Stavové nebo bez státní příslušnosti (pro relační fazole)
Staré kontejnery EJB od mnoha dodavatelů vyžadovaly více informací o nasazení než ve specifikaci EJB. Vyžadovali by další informace jako samostatné soubory XML nebo jiný formát konfiguračních souborů. Dodavatel platformy EJB obecně poskytl své vlastní nástroje, které by četly tento deskriptor nasazení, a případně vygeneroval sadu tříd, které by implementovaly nyní zastaralé rozhraní Home a Remote.
Od EJB 3.0 (JSR 220 ), deskriptor XML je nahrazen Anotace Java nastaveno v implementaci Enterprise Bean (na úrovni zdroje), i když je stále možné použít deskriptor XML namísto (nebo navíc) anotací. Pokud jsou deskriptor XML a anotace aplikovány na stejný atribut v Enterprise Bean, definice XML přepíše odpovídající anotaci na úrovni zdroje, i když některé prvky XML mohou být také aditivní (např. Aktivace-konfigurace-vlastnost v XML s místo nahrazení všech existujících vlastností bude přidán jiný název než již definovaný prostřednictvím anotace @ActivationConfigProperty).
Varianty kontejnerů
Počínaje EJB 3.1 specifikace EJB definuje dvě varianty kontejneru EJB; plná verze a omezená verze. Omezená verze dodržuje a správná podmnožina specifikace s názvem EJB 3.1 Lite [36][37] a je součástí Webový profil Java EE 6 (což je samo o sobě podmnožinou úplné specifikace Java EE 6).
EJB 3.1 Lite vylučuje podporu následujících funkcí:[38]
- Vzdálená rozhraní
- Interoperabilita RMI-IIOP
- Koncové body webové služby JAX-WS
- Služba časovače EJB (@Schedule, @Timeout)
- Asynchronní vyvolání fazole relace (@Ansynchronní)
- Fazole založené na zprávách
EJB 3.2 Lite vylučuje méně funkcí. Zejména již nevylučuje @Asynchronous a @ Schedule / @ Timeout, ale pro @Schedule nepodporuje atribut „persistent“, který podporuje plný EJB 3.2. Úplný seznam vyloučených pro EJB 3.2 Lite je:
- Vzdálená rozhraní
- Interoperabilita RMI-IIOP
- Koncové body webové služby JAX-WS
- Trvalé časovače (atribut „persistent“ ve službě @Schedule)
- Fazole založené na zprávách
Historie verzí
EJB 4.0, finální vydání (22.2.2020)
Jakarta Enterprise Beans 4.0, jako součást Jakarta EE 9, bylo vydání nástrojů, které převážilo názvy balíčků API z nejvyšší úrovně javax.ejb
balíček na nejvyšší úroveň jakarta.ejb
balík.[39]
Mezi další změny patřilo odebrání zastaralých API, které neměly smysl přecházet na nový balíček nejvyšší úrovně, a odstranění funkcí, které závisely na funkcích, které byly odebrány z Javy nebo jinde v Jakartě EE 9. Byly odstraněny následující API:
- metody, na které se spoléhat
java.security.Identity
který byl odstraněn z prostředí Java 14. - metody, na které se spoléhat Jakarta XML RPC odráží odstranění XML RPC z platformy Jakarta EE 9.
- zastaralé
EJBContext.getEnvironment ()
metoda. - „Podpora distribuované interoperability“, aby odrážela odstranění CORBA z Java 11 a platformy Jakarta EE 9.
Mezi další drobné změny patří označení skupiny API Enterprise Beans 2.x jako „volitelné“ a provedení Plán
anotace opakovatelná.
EJB 3.2.6, konečné vydání (2019-08-23)
Jakarta Enterprise Beans 3.2, jako součást Jakarta EE 8, a přestože stále používá zkratku „EJB“, byla tato sada API oficiálně přejmenována na „Jakarta Enterprise Beans“ Eclipse Foundation aby nešlapal na ochrannou známku Oracle „Java“.
EJB 3.2, finální vydání (2013-05-28)
JSR 345. Enterprise JavaBeans 3.2 bylo relativně malé vydání, které obsahovalo hlavně vysvětlení specifikací a zrušilo některá omezení, která byla uložena specifikací, ale postupem času se zdálo, že neslouží žádnému skutečnému účelu. Několik stávajících plných funkcí EJB bylo také požadováno, aby byly v EJB 3 lite, a funkčnost, která byla navržena k prořezávání v EJB 3.1, byla skutečně prořezána (volitelná).[40][41]
Byly přidány následující funkce:
- Pasivaci stavového fazole relace lze deaktivovat pomocí atributu v anotaci @Stateful (passivationCapable = false)
- TimerService může načíst všechny aktivní časovače ve stejném modulu EJB (dříve mohl načíst pouze časovače pro fazole, ve které byl TimerService volán)
- Metody životního cyklu (např. @PostConstruct) mohou být transakční pro stavové fazole relace pomocí existující anotace @TransactionAttribute
- Automaticky uzavíratelné rozhraní implementováno vložitelným kontejnerem
EJB 3.1, konečné vydání (10.12.2009)
JSR 318. Účelem specifikace Enterprise JavaBeans 3.1 je dále zjednodušit architekturu EJB snížením její složitosti z pohledu vývojáře a přidáním nových funkcí v reakci na potřeby komunity:
- Místní zobrazení bez rozhraní (zobrazení bez rozhraní)
- .válka balení komponentů EJB
- EJB Lite: definice podmnožiny EJB
- Přenosný EJB Global JNDI Jména
- Singletons (Singleton Session Beans)
- Události inicializace a vypnutí aplikace
- Vylepšení služby časovače EJB
- Jednoduchý Asynchrony (@Asynchronous pro fazole relace)
EJB 3.0, finální vydání (2006-05-11)
JSR 220 - Hlavní změny: Toto vydání výrazně usnadnilo psaní EJB pomocí „anotací“ namísto komplexních „deskriptorů nasazení“ použitých ve verzi 2.x. V této verzi již také nebylo nutné používat domácí a vzdálená rozhraní a soubor ejb-jar.xml, protože byly nahrazeny obchodním rozhraním a fazolí, která rozhraní implementuje.
EJB 2.1, konečné vydání (2003-11-24)
JSR 153 - Hlavní změny:
- webová služba podpora (nová): lze vyvolat fazole relace bez státní příslušnosti MÝDLO /HTTP. EJB může také snadno přistupovat k webové službě pomocí nového odkazu na službu.
- Služba časovače EJB (nová): Mechanismus založený na událostech pro vyvolání EJB v určitých časech.
- Fazole řízené zprávami přijímají zprávy z jiných zdrojů než JMS.
- Byly přidány cíle zpráv (stejný nápad jako odkazy EJB, odkazy na zdroje atd.).
- Přidání dotazovacího jazyka EJB (EJB-QL): OBJEDNAT PODLE, AVG, MIN, MAX, SUM, POČET a MOD.
- Schéma XML se používá k určení deskriptorů nasazení, nahrazuje DTD
EJB 2.0, konečné vydání (2001-08-22)
JSR 19 - Hlavní změny:Celkové cíle:
- Standardní architektura komponent pro stavbu distribuováno objektově orientované obchodní aplikace v Jáva.
- Umožněte vytváření distribuovaných aplikací kombinací komponent vyvinutých pomocí nástrojů z různých prodejců.
- Usnadněte si psaní (podnikových) aplikací: Vývojáři aplikací nebudou muset rozumět podrobnostem transakcí a správy stavu na nízké úrovni, vícevláknovému zpracování, sdružování připojení a dalším složitým nízkoúrovňovým API.
- Bude se řídit filozofií „Write Once, Run Anywhere“ z Jáva. Enterprise Bean lze vyvinout jednou a poté nasadit na více platforem bez rekompilace nebo úpravy zdrojového kódu.
- Řešte aspekty vývoje, nasazení a běhu životního cyklu podnikové aplikace.
- Definujte smlouvy, které umožňují nástrojům od více dodavatelů vyvíjet a nasazovat komponenty, které mohou spolupracovat za běhu.
- Buďte kompatibilní se stávajícími serverovými platformami. Prodejci budou moci rozšířit své stávající produkty o podporu EJB.
- Buďte kompatibilní s ostatními Jáva API.
- Poskytují interoperabilitu mezi podnikovými fazolemi a komponentami Java EE i aplikacemi v jiném než Java programovacím jazyce.
- Buďte kompatibilní s protokoly CORBA (RMI-IIOP).
EJB 1.1, konečné vydání (1999-12-17)
Hlavní změny:
- Deskriptory nasazení XML
- Výchozí kontexty JNDI
- RMI přes IIOP
- Zabezpečení - řízeno rolemi, nikoli metodami
- Podpora Entity Bean - povinná, není volitelná
Cíle pro verzi 1.1:
- Poskytují lepší podporu pro sestavování a nasazování aplikací.
- Podrobněji upřesněte odpovědnosti jednotlivých rolí EJB.
EJB 1.0 (1998-03-24)
Oznámeno v JavaOne 1998,[42] Třetí konference vývojářů Java v Sunu (24. až 27. března)Cíle pro vydání 1.0:
- Definoval odlišné „role EJB“, které předpokládá architektura komponent.
- Definoval pohled klienta na podnikové fazole.
- Definoval pohled vývojáře Enterprise Bean.
- Definoval odpovědnosti poskytovatele kontejneru EJB a poskytovatele serveru; společně tvoří systém, který podporuje nasazení a provádění podnikových fazolí.
Reference
- ^ „Enterprise JavaBeans Technology“. www.oracle.com. Citováno 2016-12-15.
- ^ Návrh a vývoj J2EE, © 2002 Wrox Press Ltd., s. 5.
- ^ Návrh a vývoj J2EE2002, Wrox Press Ltd., s. 19.
- ^ JSR 318, 4.1, http://jcp.org/en/jsr/detail?id=318
- ^ „Volitelná místní obchodní rozhraní (blog Kena Sakse)“. Archivovány od originál dne 19. listopadu 2015. Citováno 1. června 2016.
- ^ JSR 318, 4.5, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.6, http://jcp.org/en/jsr/detail?id=318
- ^ A b JSR 318, 4.10.3, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.3.14, 21.4.2, http://jcp.org/en/jsr/detail?id=318
- ^ „Persistence Context in Stateful“. Archivovány od originál dne 16. března 2008. Citováno 1. června 2016.
- ^ JSR 318, 4.7, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.3.14, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.8, http://jcp.org/en/jsr/detail?id=318
- ^ „Singleton EJB“. Openejb.apache.org. Citováno 2012-06-17.
- ^ JSR 318, 5.1, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 5.7.2, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 5.4.2, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 5.6.2, http://jcp.org/en/jsr/detail?id=318
- ^ Vývoj křemenné MDB. „Developing Quartz MDB“. Mastertheboss.com. Citováno 2012-06-17.
- ^ JSR 318, kapitola 17, http://jcp.org/en/jsr/detail?id=318
- ^ „Bezpečnostní poznámky“. Openejb.apache.org. Citováno 2012-06-17.
- ^ JSR 318, kapitola 13, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 13.6.2, http://jcp.org/en/jsr/detail?id=318
- ^ „Transaction Annotations“. Openejb.apache.org. Citováno 2012-06-17.
- ^ JSR 318, 13.3.6, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.4, http://jcp.org/en/jsr/detail?id=318
- ^ „Přenosná globální jména JNDI (MaheshKannan)“. Blogs.oracle.com. Archivovány od originál dne 20.06.2011. Citováno 2012-06-17.
- ^ „Přenosná globální jména JNDI (blog Kena Sakse)“. Blogs.oracle.com. Archivovány od originál dne 29. 12. 2011. Citováno 2012-06-17.
- ^ JSR 318, kapitola 15, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 2.6, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 3.2.4, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 4.3.6, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, 2,7, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 311, kapitola 6.2, http://jcp.org/en/jsr/detail?id=311
- ^ „Komunikace mezi JBoss AS 5 a JBoss AS 6 | JBoss AS | Komunita JBoss“. Community.jboss.org. Citováno 2012-06-17.
- ^ „Resin Java EE 6 Web Profile - Resin 3.0“. Wiki.caucho.com. 12. 2. 2010. Archivovány od originál dne 23. 3. 2012. Citováno 2012-06-17.
- ^ JSR 318, 21.1 EJB 3.1 Lite, http://jcp.org/en/jsr/detail?id=318
- ^ JSR 318, tabulka 27 - požadovaný obsah EJB 3.1 Lite a Full EJB 3.1 API, http://jcp.org/en/jsr/detail?id=318
- ^ „Co je nového v této verzi“. Jakarta Enterprise Beans, základní funkce. Jakarta Enterprise Beans 4.0. Jakarta EE. 5. listopadu 2020. Citováno 2020-12-05.
- ^ „Co je nového v EJB 3.2? - Java EE 7 chugging along! (Arun Gupta, Miles to go ...)“. Citováno 1. června 2016.
- ^ „Pokud jste nevěděli, co přijde v EJB 3.2 ... (Weblog Marina Vatkina)“. Archivovány od originál dne 4. března 2016. Citováno 1. června 2016.
- ^ „Zpráva o konferenci JavaOne: Enterprise JavaBeans Technology: Vývoj a nasazení podnikových aplikací jako komponent“. Alephnaught.com. Citováno 2012-06-17.
externí odkazy
- Oficiální webové stránky
- Javadocs API Java EE 8
- Javadocs API EJB 3.0
- Specifikace EJB 3.0
- Výukový program Sun EJB 3.0
- Glosář EJB (3.0)
- EJB FAQ
- JSR 345 (EJB 3.2)
- JSR 318 (EJB 3.1)
- JSR 220 (EJB 3.0)
- JSR 153 (EJB 2.1)
- JSR 19 (EJB 2.0)
- „Práce s fazolemi řízenými zprávami“ z EJB3 v akci, druhé vydání
- Klient vyvolá EJB