java ee, czy warto?

java ee, czy warto?
K6
  • Rejestracja:prawie 9 lat
  • Ostatnio:ponad 6 lat
  • Postów:46
0

Czy muszę uczyć się javy EE, czy wysatrczy znajomość samego springa mvc?

Polecicie jakiś tutorial, książkę do Javy ee, gdzie buduje się jakiś projekt step by step... są takie fajne książki do asp.net, springa. Mam wrażenie, że ta literatura dla javy ee jest bardzo uboga i ta technologia staje się coraz mniej popularna.

Czy waszym zdaniem java ee to przeżytek?

Shalom
  • Rejestracja:ponad 21 lat
  • Ostatnio:około 3 lata
  • Lokalizacja:Space: the final frontier
  • Postów:26433
0

Czy muszę uczyć sie jazdy na nartach, czy wstarczy sama jazda na rowerze?


"Nie brookliński most, ale przemienić w jasny, nowy dzień najsmutniejszą noc - to jest dopiero coś!"
K6
A co polecisz do nauki na początek? Znasz jakieś książki, gdzie tworzy się jakiś projekt step by step jak np: w spring mvc - przewodnik dla początkujących?
insectoman
Nie pytaj Shaloma o to, bo skończysz jako piekarz...
K6
insectoman, czemu?
azalut
:D przekonasz się jak z nim podyskutujesz zadając drażliwe pytania; albo poczytaj forum :D
datdata
  • Rejestracja:prawie 11 lat
  • Ostatnio:około 7 lat
  • Postów:957
0

Java EE i Spring MVC to technologie konkurujące ze sobą, realizujące mniej więcej te same potrzeby. Historycznie Java EE była bardziej toporna niż Spring, aczkolwiek ostatnio jest całkiem dobrze. Zdecydowanie nie jest przeżytkiem i jeszcze sporo projektów w tym powstaje i powstanie.


"A human being should be able to change a diaper, plan an invasion, butcher a hog, conn a ship, design a building, write a sonnet, balance accounts, build a wall, set a bone, comfort the dying, take orders, give orders, cooperate, act alone, solve equations, analyze a new problem, pitch manure, program a computer, cook a tasty meal, fight efficiently, die gallantly. Specialization is for insects." Robert Heinlein.
K6
A co polecisz do nauki na początek? Znasz jakieś książki, gdzie tworzy się jakiś projekt step by step jak np: w spring mvc - przewodnik dla początkujących?
datdata
Nie pracuję w tej technologii, ale zacząłbym od oficjalnego tutoriala: http://docs.oracle.com/javaee/7/tutorial/
K6
A w czym pracujesz? Pytam z ciekawości :)
KA
KA
  • Rejestracja:prawie 12 lat
  • Ostatnio:prawie 5 lat
  • Lokalizacja:Warszawa
  • Postów:1683
0

Warto. A jeżeli masz jeszcze jakieś obiekcje czy warto to sobie możesz posłuchać:


PROGRAMY NA ZAMÓWIENIE, ZALICZENIA STUDENCKIE, KONFIGURACJA SERWERÓW, SYSTEMÓW I BAZ DANYCH, STRONY INTERNETOWE, POMOC W PROGRAMOWANIU, POPRAWIENIE I OPTYMALIZACJA APLIKACJI
JAVA, C++, LINUX, WWW, SQL, PYTHON
POSIADAM KOMERCYJNE DOŚWIADCZENIE
TANIO, SZYBKO I PORZĄDNIE
Z KOMENTARZAMI OBJAŚNIAJĄCYMI KOD
PISZ NA PRYWATNĄ WIADOMOŚĆ
CENY JUŻ OD 49,99ZŁ ZA PROGRAM
ZAJMIJ SIĘ TYM CO CIĘ NAPRAWDĘ INTERESUJE!
0
datdata napisał(a):

Java EE i Spring MVC to technologie konkurujące ze sobą, realizujące mniej więcej te same potrzeby. Historycznie Java EE była bardziej toporna niż Spring, aczkolwiek ostatnio jest całkiem dobrze. Zdecydowanie nie jest przeżytkiem i jeszcze sporo projektów w tym powstaje i powstanie.

wiele projektów to mix springa i java ee.

M9
  • Rejestracja:prawie 10 lat
  • Ostatnio:około 6 lat
1

Warto znać Spring i JEE są bardzo podobne, ale najpierw skup się na samym Springu lub JEE (nie wszystko na raz).

w JEE 8 też będzie ustandaryzowane MVC wzorowane na JAX-RS: Ozark.
https://ozark.java.net/

edytowany 1x, ostatnio: margor90
K6
  • Rejestracja:prawie 9 lat
  • Ostatnio:ponad 6 lat
  • Postów:46
0

Dużo ostatnio mówi się o tej nowej wersji javy ee. Weźmy np. taki artykuł https://www.infoq.com/news/2016/07/Java-EE-8-Stagnating. Nie wiem czy to działania konkurencji, czy faktycznie oracle nie chce już tak rozwijać javy ee, kiedy do gry zaczęły wchodzić inne technologie jak np: asp.net

Wibowit
  • Rejestracja:około 20 lat
  • Ostatnio:około 7 godzin
1

kiedy do gry zaczęły wchodzić inne technologie jak np: asp.net

A asp.net to jakaś świeżynka?


"Programs must be written for people to read, and only incidentally for machines to execute." - Abelson & Sussman, SICP, preface to the first edition
"Ci, co najbardziej pragną planować życie społeczne, gdyby im na to pozwolić, staliby się w najwyższym stopniu niebezpieczni i nietolerancyjni wobec planów życiowych innych ludzi. Często, tchnącego dobrocią i oddanego jakiejś sprawie idealistę, dzieli od fanatyka tylko mały krok."
Demokracja jest fajna, dopóki wygrywa twoja ulubiona partia.
K6
Nie jest to świeżynka, ale u mnie w mieście asp.net mvc strasznie popularny się zrobił. Te wszystkie .NET-owe konferencje, jakieś koła z .NET dla licealistów na uczelniach. Sam ostatnio byłem na testach o pracę i na sali na 10 osób, tylko dwie pisały Jave :). Jak dla mnie to super - mam mnie konkurencji w mojej technologii. Tylko zastanawiam się, czy to po prostu moda, czy ta platforma jest lepsza, czy co? Micro$oft sporo hajsu wylewa na tą propagandę, bo potrafią zrobić nawet szkolenie z asp.net mvc za darmochę(6 godzinne)...
Wibowit
Sam sobie odpowiedziałeś - MS robi szkolenia za free to cebulacy się na to łapią :)
JavaDevv
  • Rejestracja:około 9 lat
  • Ostatnio:ponad 8 lat
  • Postów:24
0

Jeżeli znasz podstawy Java SE to polecam http://javastart.pl/enrol/index.php?id=10

M9
  • Rejestracja:prawie 10 lat
  • Ostatnio:około 6 lat
0
kolo625 napisał(a):

Dużo ostatnio mówi się o tej nowej wersji javy ee. Weźmy np. taki artykuł https://www.infoq.com/news/2016/07/Java-EE-8-Stagnating. Nie wiem czy to działania konkurencji, czy faktycznie oracle nie chce już tak rozwijać javy ee, kiedy do gry zaczęły wchodzić inne technologie jak np: asp.net

Java EE poradzi sobie bez Oracle. Ale milczenie ze strony Oracle zostało przerwane i będą mieli swój komentarz w JCP: wezmą udział w tworzeniu następnego standardu. Szczegóły zostaną przedstawione na konfie JavaOne na jesień.

Poza tym powstają ciekawostki jak standaryzacja takich rzeczy jak UberJar czy micro profile na potrzeby cloud.

0

Tylko nie siedź za długo nad EJB, bo to długa i skomplikowana specyfikacja, a w praktyce wykorzystuje się może 10% z tego i ze względu na rozwój CDI i tak średnio ma rację bytu.

M9
EJB i CDI się uzupełniają, nie konkurują.
1

...albo odpowiadając stricte na pytanie- żeby programować w Spring Mvc, to z JavyEE powinieneś znać Servlety

M9
  • Rejestracja:prawie 10 lat
  • Ostatnio:około 6 lat
1
Pijany Zając napisał(a):

Tylko nie siedź za długo nad EJB, bo to długa i skomplikowana specyfikacja, a w praktyce wykorzystuje się może 10% z tego i ze względu na rozwój CDI i tak średnio ma rację bytu.

EJB ma znacznie więcej opcji niż trzeba. Pisze się w tym prosto, ale trzeba wiedzieć czego używać czego nie.

Co do EJB moje przemyślenia są takie:

  1. Używać adnotacji @stateless (POJO na logikę biznesową transakcyjne domyślnie). Może się też przydać @Singleton (np. na schedulery). Raczej nie będziesz zbyt często chciał używać komponentów @Statelful, ale warto wiedzieć, że jest taka opcja.
  2. Zamiast @ejb używaj @Inject (CDI). Do prostych case'ów wystarcza.
  3. Nie używaj interfejsów przy pojedynczej implementacji (od JEE7 wystarcza samo @stateless na POJO). @LocalBean w JEE7 jest redundantne.
  4. Sporadycznie możesz chcieć używać metod asynchronicznych @Asynchronous.
  5. Timer service dość często się używa i warto poznać (scheduler / cron).
  6. Jak będziesz potrzebował JMS możesz zainteresować się MDB. Uważaj na toksyczne komunikaty i pilnuj zasięgu transakcji (transaction attribute RequiresNew w MDB).
  7. Jeśli chodzi o interceptory i dekoratory nie używaj tych z EJB tylko tych z CDI.
  8. Zapomnij o zdalnych interfejsach: szkoda czasu. Lepsze są WebServices.
  9. Warto wiedzieć, że masz 2 rodzaje transakcji:
    a) zarządzane przez kontener CMT, domyślne, (nic nie musisz z nimi robić), ale nie masz kontroli nad zasięgiem transakcji
    b) zarządzanie ręcznie BMT, przydają się bardzo rzadko, gdy potrzebujesz bardziej precyzyjny zasięg transakcji jak metoda (wiele transakcji w 1 metodzie)

Z punktu widzenia kodera nie ma większej różnicy czy pisze się POJO w EJB/CDI czy Springu. Bardziej wewnętrzna specyfikacja serwera aplikacyjnego jest różna (Spring go nie wymaga).

Moim zdaniem znacznie mniej przyjazną specyfikacją niż EJB jest JPA (Hibernate itp.). Problem w tym, że jest bardzo rozpowszechniona, również w Springu. EJB to zwykłe POJO.

edytowany 5x, ostatnio: margor90
0
margor90 napisał(a):

EJB ma znacznie więcej opcji niż trzeba. Pisze się w tym prosto, ale trzeba wiedzieć czego używać czego nie.

No właśnie, tylko skąd nowe osoby mają to wiedzieć. Lista którą podałeś wygląda jak lista haków i świadczy o braku spójności platformy. Dlatego uważam, że lepiej gdyby EJB wywalono z JEE. W EJB jest może kilka ficzerów, ale one nie usprawiedliwiają 450 stron specyfikacji. Powinien być jeden model klas zarządzanych przez kontener.

M9
Powiedz to springowcom. W springu tą samą rzecz można zrobić na 10 sposobów. To dopiero brak spójności. Poza tym zaawansowane opcje mogą być przydatne na dużych projektach (2PC). W normalnych okolicznościach nie należy się w to pchać (proszenie się o problemy). Kompatybilność wstecz to właśnie to za co JEE jest doceniane w konserwatywnych sektorach przemysłu (banki).
M9
  • Rejestracja:prawie 10 lat
  • Ostatnio:około 6 lat
0

450 stron specyfikacji na pewno nie jest istotne dla programisty aplikacji biznesowych. Co najwyżej dla programisty serwera aplikacyjnego (im bardziej dokładna specyfikacja przy tej liczbie serwerów aplikacyjnych tym lepiej). To co potrzebne z EJB dla małego-średniego projektu spokojnie można zamknąć na kilkugodzinnym szkoleniu (z praktyczną wiedzą jak ktoś kuma SOLID i DI). Podejrzewam, że pełna specyfikacja (dokumentacja) Springa jest większa (np. różne podejścia do obsługi transakcji).

Czy potrzebujemy serwerów aplikacyjnych? To już inna sprawa. Często nie, ale w tej chwili serwery aplikacyjne są już używalne (kiedyś to był mordor).

Z tego co widać JEE ewoluuje w tą stronę, aby serwery aplikacyjne były opcjonalne (rozwój CDI).

edytowany 5x, ostatnio: margor90
H1
  • Rejestracja:około 10 lat
  • Ostatnio:prawie 7 lat
  • Postów:185
0

np. Mały, średni projekt, microservices = JAX-RS, CDI, JPA, Spring Data/Apache DeltaSpike... czego chcieć więcej? Pisze się w tym dobrze.
Z dobrym mentoringiem albo mając dobry przykład i można lecieć z CRUDami niemal na ślepo ;)

Aczkolwiek jak każda technologia ma to swoje niuanse, które pewnie można poznawać latami.
np. sprawy związane z transakcjami i lazy initialziation exception itp. pewnie na początek mogą spędzać sen z powiek.
Albo czemu używać Setów w encjach zamiast List itp. ;)

Ja jestem przyzwyczajony do Spring Boota. Ostatnio zacząłem trochę interesować sie Wildfly to stwierdziłem, że można napisać aplikację łudząco podobnie do Springa. A taki Wildfly praktycznie dostarcza wszystkie potrzebne jary by napisać fajną aplikację.

Według mnie fajne i przyjazne technologie.

PS. Jak macie propozycje to chętnie poznam jak można to fajniej napisać w innym języku.

edytowany 4x, ostatnio: H1ghlander

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.