This is the basic Jakarta EE 8 application used throughout the Docker and Kubernetes demos. It is a simple CRUD application. It uses Maven and Jakarta EE 8 (Jakarta REST, enterprise beans, CDI, Persistence, Faces, Bean Validation).
We use Eclipse but you can use any Maven capable IDE such as IntelliJ, NetBeans or Visual Studio Code. We use WebSphere Liberty but you should be able to use any Jakarta EE 8 compatiple application server such as Open Liberty, WildFly, JBoss EAP, Payara or WebLogic. We use PostgreSQL but you can use any relational database such as MySQL.
- Install Java SE 8 or Java SE 11 (we used Azul Zulu Java 11 LTS).
- Install the Eclipse IDE for Enterprise Java Developers from here.
- Install Docker for your OS.
- Download this repository somewhere in your file system (easiest way might be to download as a zip and extract).
The first step to getting the application running is getting the database up. The simplest way to actually do this is through Docker. Please follow the instructions below to get the database running.
- Make sure Docker is running. Open a console.
- Enter the following command and wait for the database to come up fully.
docker run -it --rm -e POSTGRES_HOST_AUTH_METHOD=trust --name jakartaee-cafe-db -v pgdata:/var/lib/postgresql/data -p 5432:5432 postgres
- The database is now ready. To stop it, simply press Control-C.
The next step is to get the application up and running. Follow the steps below to do so.
- Start Eclipse.
- Go to the 'Servers' panel, right click. Select New -> Server -> IBM -> WebSphere Application Server Liberty Extended Tools. Click Next. Accept the license agreement, click Finish.
- After the Eclipse WebSphere Liberty adapters are done installing, go to the 'Servers' panel again, right click. Select New -> Server -> IBM -> Liberty Server. Click Next. Select "Install from an archive or a repository". Click Next. Enter the destination path to install WebSphere Liberty. Select "Download and install a new runtime environment from ibm.com". Choose the "WAS Liberty with Java EE 8 Full Platform" option. Click next. Install the Java EE 8 Full Platform Bundle. Click Next. Accept the license agreement and click Next. Click Finish. When you are done, WebSphere Liberty will be set up in Eclipse.
- Find out where Eclipse has installed WebSphere Liberty in your file system. In the Servers panel, double click to open the WebSphere Liberty configuration. Click on Runtime Environment. Note the installation path.
- Browse to where you have this repository code in your file system. You will need to copy the server.xml and PostgreSQL driver to the WebSphere install location. Both of these files are located under jakartaee/server. Copy the PostgreSQL driver into the WebSphere Liberty installation location under usr/shared/resources. Now copy the server.xml into usr/servers/[your-server-name]/. The server name is probably defaultServer or newServer.
- Get the jakartaee-cafe application into the IDE. In order to do that, go to File -> Import -> Maven -> Existing Maven Projects. Then browse to where you have this repository code in your file system and select jakartaee/jakartaee-cafe. Accept the rest of the defaults and finish.
- Once the application loads, you should do a full Maven build by going to Right click the application -> Run As -> Maven install.
- It is now time to run the application. Go to Right click the application -> Run As -> Run on Server. Make sure to choose Liberty as the server going forward. Just accept the defaults and wait for the application to finish running.
- Once the application runs, Eclise will open it up in a browser. The application is available at http://localhost:9080/jakartaee-cafe.
The application is composed of:
-
A RESTFul service:* protocol://hostname:port/jakartaee-cafe/rest/coffees
- GET by Id: protocol://hostname:port/jakartaee-cafe/rest/coffees/{id}
- GET all: protocol://hostname:port/jakartaee-cafe/rest/coffees
- POST to add a new element at: protocol://hostname:port/jakartaee-cafe/rest/coffees
- DELETE to delete an element at: protocol://hostname:port/jakartaee-cafe/rest/coffees/{id}
-
A JSF Client: protocol://hostname:port/jakartaee-cafe/index.xhtml
Feel free to take a minute to explore the application.