The ejb-multi-server quickstart shows how to communicate between multiple applications deployed to different servers using an EJB to log the invocation.
What is it?
The ejb-multi-server quickstart demonstrates communication between applications deployed to different JBoss Enterprise Application Platform Server servers. Each application is deployed as an EAR and contains a simple EJB bean. The only function of each bean is to log the invocation.
This example consists of the following Maven projects, each with a shared parent:
| Project | Description |
|---|---|
|
An application that can be called by the client. It can also call the different sub-applications. |
|
These simple applications contain an EJB subproject that builds the |
|
A simple WAR application. It consists of one servlet that demonstrates how to invoke EJBs on a different server. |
|
This project builds the standalone client and executes it. |
The root pom.xml builds each of the subprojects in an appropriate order.
The server configuration is done using CLI batch scripts located in the root of the quickstart folder.
System Requirements
The application this project produces is designed to be run on JBoss Enterprise Application Platform Server 7.2 or later.
All you need to build this project is Java 8.0 (Java SDK 1.8) or later and Maven 3.3.1 or later. See Configure Maven to Build and Deploy the Quickstarts to make sure you are configured correctly for testing the quickstarts.
To run these quickstarts with the provided build scripts, you need the JBoss EAP distribution ZIP. For information on how to install and run the JBoss EAP server, see the Getting Started Guide.
Use of EAP_HOME
In the following instructions, replace EAP_HOME with the actual path to your JBoss EAP installation. The installation path is described in detail here: Use of EAP_HOME and JBOSS_HOME Variables.
Start with a Clean Server Install
It is important to start with a clean version of JBoss EAP before testing this quickstart. Make sure you unzip or install a fresh JBoss EAP instance.
Add the Application Users
The following users must be added to the ApplicationRealm to run this quickstart. Make sure you use the names and passwords specified in the table as they are required to run this example.
| UserName | Realm | Password | Roles |
|---|---|---|---|
quickuser |
ApplicationRealm |
quick-123 |
|
quickuser1 |
ApplicationRealm |
quick123+ |
|
quickuser2 |
ApplicationRealm |
quick+123 |
To add the users, open a terminal and type the following commands.
$ EAP_HOME/bin/add-user.sh -a -u quickuser -p quick-123
$ EAP_HOME/bin/add-user.sh -a -u quickuser1 -p quick123+
$ EAP_HOME/bin/add-user.sh -a -u quickuser2 -p quick+123
|
Note
|
For Windows, use the EAP_HOME\bin\add-user.bat script.
|
If you prefer, you can use the add-user utility interactively. For an example of how to use the add-user utility, see the instructions located here: Add an Application User.
Back Up the JBoss EAP Managed Domain Configuration
Before you begin, back up your server configuration files.
-
If it is running, stop the JBoss EAP server.
-
Back up the following files:
EAP_HOME/domain/configuration/domain.xml EAP_HOME/domain/configuration/host.xml
After you have completed testing this quickstart, you can replace these file to restore the server to its original configuration.
Start the JBoss EAP Managed Domain
-
Open a terminal and navigate to the root of the JBoss EAP directory.
-
Start the JBoss EAP managed domain by typing the following command.
$ EAP_HOME/bin/domain.shNoteFor Windows, use the EAP_HOME\bin\domain.batscript.
Configure the Server
You configure the domain server by running JBoss CLI commands. For your convenience, this quickstart batches the commands into a install-domain.cli script provided in the root directory of this quickstart.
-
Before you begin, make sure you do the following:
-
Review the
install-domain.clifile in the root of this quickstart directory. This script configures and starts multiple servers needed to run this quickstart. -
Open a new terminal, navigate to the root directory of this quickstart, and run the following command, replacing EAP_HOME with the path to your server:
$ EAP_HOME/bin/jboss-cli.sh -c --file=install-domain.cliNoteFor Windows, use the EAP_HOME\bin\jboss-cli.batscript.You should see a result of
"outcome" ⇒ "success"for every step in the execution.ImportantDepending on your machine configuration, you might see "Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread" exceptions in the server log when you run this script. If you do, you must increase the ulimit open files and max user processes settings. Instructions to do this are located here: http://ithubinfo.blogspot.com/2013/07/how-to-increase-ulimit-open-file-and.html. After you update the ulimit settings, you must reboot and start with a fresh instance of the server.
Review the Modified Server Configuration
There are too many additions to the configuration files to list here. Feel free to compare the domain.xml and host.xml to the backup copies to see the changes made to configure the server to run this quickstart.
Install the Quickstart Parent Artifact in Maven
This quickstart requires the quickstart-parent artifact to be installed in your local Maven repository. To install it, navigate to your QUICKSTART_HOME directory directory and run the following command.
$ cd QUICKSTART_HOME
$ mvn clean install
Build and Deploy the Quickstart
-
Make sure you have installed the quickstart parent artifact in your Maven repository.
-
Make sure you have started and configured the JBoss EAP server successfully as described above.
-
Open a terminal and navigate to the root directory of this quickstart.
-
Type this command to build the artifacts.
$ mvn clean installYou should see
BUILD SUCCESSat the end of the buildSUCCESSmessages for each component. -
In the same terminal, deploy the applications using the provided CLI batch script by typing the following command.
$ EAP_HOME/bin/jboss-cli.sh -c --file=deploy-domain.cliNoteFor Windows, use the EAP_HOME\bin\jboss-cli.batscript.This deploys the
app-*.earfiles to different server groups of the running domain. You should see the following result when you run the script.The batch executed successfully process-state: reload-required -
You might see the following warnings in the server log. You can ignore these warnings.
[Server:app-oneB] 13:00:13,346 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 13) JGRP000015: the send buffer of socket MulticastSocket was set to 1MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max send buffer in the OS correctly (e.g. net.core.wmem_max on Linux) [Server:app-oneB] 13:00:13,346 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 13) JGRP000015: the receive buffer of socket MulticastSocket was set to 20MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max receive buffer in the OS correctly (e.g. net.core.rmem_max on Linux) [Server:app-oneB] 13:00:13,347 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 13) JGRP000015: the send buffer of socket MulticastSocket was set to 1MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max send buffer in the OS correctly (e.g. net.core.wmem_max on Linux) [Server:app-oneB] 13:00:13,347 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 13) JGRP000015: the receive buffer of socket MulticastSocket was set to 25MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max receive buffer in the OS correctly (e.g. net.core.rmem_max on Linux) [Server:app-oneA] 13:00:13,407 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 11) JGRP000015: the send buffer of socket MulticastSocket was set to 1MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max send buffer in the OS correctly (e.g. net.core.wmem_max on Linux) [Server:app-oneA] 13:00:13,408 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 11) JGRP000015: the receive buffer of socket MulticastSocket was set to 20MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max receive buffer in the OS correctly (e.g. net.core.rmem_max on Linux) [Server:app-oneA] 13:00:13,408 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 11) JGRP000015: the send buffer of socket MulticastSocket was set to 1MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max send buffer in the OS correctly (e.g. net.core.wmem_max on Linux) [Server:app-oneA] 13:00:13,408 WARN [org.jboss.as.clustering.jgroups.protocol.UDP] (ServerService Thread Pool -- 11) JGRP000015: the receive buffer of socket MulticastSocket was set to 25MB, but the OS only allocated 212.99KB. This might lead to performance problems. Please set your max receive buffer in the OS correctly (e.g. net.core.rmem_max on Linux)
|
Important
|
If errors appear in the server.log when installing or deploying the quickstart, stop the domain and restart it. This should ensure further steps run correctly.
|
Access the Remote Client Application
This example shows how to invoke an EJB from a remote standalone application.
-
Make sure that the deployments are successful as described above.
-
Navigate to the quickstart
client/subdirectory. -
Type this command to run the application:
$ mvn exec:javaThe client will output the following information provided by the applications:
InvokeAll succeed: MainApp[anonymous]@master:app-main > [ app1[quickuser1]@master:app-oneB > app2[quickuser2]@master:app-twoA ; app2[quickuser2]@master:app-twoA ]This output shows that the
MainAppis called with the useranonymousat nodemaster:app-mainand the sub-call is proceeded by themaster:app-oneAnode andmaster:app-twoAnode asquickuser2. -
Review the server log files to see the bean invocations on the servers.
-
If it is necessary to invoke the client with a different JBoss EAP version the main class can be invoked by using the following command from the root directory of this quickstart. Replace EAP_HOME with your current installation path. The output should be similar to the previous mvn executions.
java -cp $ EAP_HOME/bin/client/jboss-client.jar:app-main/ejb/target/ejb-multi-server-app-main-ejb-client.jar:app-two/ejb/target/ejb-multi-server-app-two-ejb-client.jar:client/target/ejb-multi-server-client.jar org.jboss.as.quickstarts.ejb.multi.server.Client
|
Important
|
|
Access the JSF Application Inside the Main Application
The JSF example shows different annotations to inject the EJB. Also how to handle the annotation if different beans implement the same interface and therefore the container is not able to decide which bean needs to be injected without additional informations.
-
Make sure that the deployments are successful as described above.
-
Use a browser to access the JSF application at the following URL: http://localhost:8080/ejb-multi-server-app-main-web/
-
Insert a message in the Text input and invoke the different methods. The result is shown in the browser.
-
See server logfiles and find your given message logged as INFO.
Access the Servlet Application Deployed as a WAR Inside a Minimal Server
An example how to access EJBs from a separate instance which only contains a web application.
-
Make sure that the deployments are successful as described above.
-
Use a browser to access the Servlet at the following URL: http://localhost:8380/ejb-multi-server-app-web/
-
The Servlet will invoke the remote EJBs directly and show the results, compare that the invocation is successful
Undeploy the Quickstart
-
Start the JBoss EAP managed domain as described above.
-
Open a terminal and navigate to the root directory of this quickstart.
-
When you are finished testing, type this command to undeploy the archive:
$ EAP_HOME/bin/jboss-cli.sh --connect --file=undeploy-domain.cliNoteFor Windows, use the EAP_HOME\bin\jboss-cli.bat.
Restore the JBoss EAP Managed Domain Configuration Manually
When you have completed testing the quickstart, you can restore the original server configuration by manually restoring the backup copies the configuration files.
-
If it is running, stop the JBoss EAP server.
-
Replace the following files with the backup copies of the files.
EAP_HOME/domain/configuration/domain.xml EAP_HOME/domain/configuration/host.xml
Run the Quickstart in Red Hat JBoss Developer Studio or Eclipse
This quickstart is not supported in Red Hat JBoss Developer Studio.
EJB Client (ejb-client) currently has limited support in the Eclipse Web Tools Platform (WTP).
Debug the Application
If you want to debug the source code of any library in the project, run the following command to pull the source into your local repository. The IDE should then detect it.
$ mvn dependency:sources