Application Clients
This chapter discusses application clients that are executed on a separate JVM from the JEUS server (engine container).
1. Overview
In general, an application client module running in a JEUS client container is used to call a Jakarta EE application or be provided with Jakarta EE service.
An application client is a stand-alone client that runs in a Jakarta EE environment. It operates within the application client container, which is defined in Jakarta EE Specification. An application client module, a type of JEUS clients, is useful for client/server systems, testing, or debugging.
JEUS application client can use JEUS services, including naming service, scheduler, and security, by using a client container. Without using a client container, JNDI and security services can be used through the JEUS client library. However, dependency injection and JEUS scheduler cannot be used.
|
2. Programming
This section describes JEUS client and server architectures, and describes some examples using sample codes.
2.1. Program Architecture
An application client is a client program that runs on a JVM that is different from the server.
An application client calls and executes the main() method and runs until the JVM terminates. Like other Jakarta EE application components, an application client also runs in a client container that provides system services, but the container uses less system resources than other Jakarta EE containers. It provides the environment in which Jakarta EE services offered by JEUS can be provided for a general client application.
The services include scheduler, security, JNDI, and other services with which users can use the application components (EJB) and system resources (JDBC data source, JMS connection factory, etc.) that are bound to JEUS via JNDI.
2.2. Example
Like other Java programs, an application client must have the main method that is declared in the public class.
The following example calls EJB via injection. (refer to the example of JEUSHOME/samples/client/hello/hello-client directory).
package helloejb;
import java.io.*;
import jakarta.ejb.EJB;
public class HelloClient {
@EJB(mappedName="helloejb.Hello")
private static Hello hello;
public static void main(String[] args) {
System.out.println("EJB output : " + hello.sayHello());
}
}
3. Deployment Descriptor(DD)
This section describes how to create a deployment descriptor (DD).
3.1. Writing a DD
A DD can be written in the following two ways:
-
Jakarta EE DD
Jakarta EE Specification defines DD for client modules, and uses standard settings regardless of WAS.
Jakarta EE 5 and above do not require a standard DD file, and necessary settings can be done through annotations. Therefore, the previous example, Application Client: <HelloClient.java> can be run without any separate application-client.xml file.
For more information about standard XML descriptor, refer to Jakarta EE Specifications.
-
JEUS DD
Information about the client module is required for a server to communicate with an application client. DD is an XML document that contains such information.
DD filename for a client is META-INF\jeus-client-dd.xml. Using a deployment descriptor, a user can decide which services should be provided when deploying each application client to the client container. DD can be modified without changes to the program.
In general, a deployment descriptor is used to configure a resource used by the client. However, the previous example Application Client: <HelloClient.java> does not require the DD file, thus it is omitted.
For more information about jeus-client-dd.xml, refer to JEUS XML Reference. |
3.2. Creating a DD
If it is necessary to create the jeus-client-dd.xml file, you need to create it before JEUS deploys the client module.
The following example shows an XML file that creates a DD.
The XML file contains environment variables used by the client, a name to which the EJB application is bound, a name of the bound JDBC datasource, and a JNDI binding name for the JMS queue. Except for the environment variables, specify <export-name> as the JNDI name which is actually bound to <ref-name> in the application-client.xml file.
<jeus-client-dd>
<env>
<name>year</name>
<type>java.lang.Integer</type>
<value>2002</value>
</env>
<ejb-ref>
<jndi-info>
<ref-name>count</ref-name>
<export-name>count_bean</export-name>
</jndi-info>
</ejb-ref>
<res-ref>
<jndi-info>
<ref-name>datasource</ref-name>
<export-name>Oracle_DataSource</export-name>
</jndi-info>
</res-ref>
<res-env-ref>
<jndi-info>
<ref-name>jms/SalaryInfo</ref-name>
<export-name>jms/salary_info_queue1</export-name>
</jndi-info>
</res-env-ref>
</jeus-client-dd>
For a description of each element in the jeus-client-dd.xml file, refer to JEUS XML Reference. |
4. Packaging
Client module packaging can be done by manual packaging or by packaging with IDE.
-
Manual Packaging
If an XML file is necessary for a DD, you can create a DD XML file by using the XML editor or text editor that is installed on the user’s computer. Then gather all the necessary files and create a JAR file for the client module by using the JAR tool provided by Java.
To package an application client, the application class files, and, in some cases, the application-client.xml and jeus-client-dd.xml files are required.
Use the jar command to create a JAR file for the client module in the console. By standard usage, it is possible to specify the main class, which is to be used when executing the JAR file, by using the main-class attribute in the MANIFEST.MF of the JAR file. In such cases, the JEUS client container automatically executes the class.
The following example shows how to create a JAR file using the jar command.
jar cvf hello-client.jar *
-
Packaging with IDE
You can create using the IDE tool that supports Jakarta EE environment such as Eclipse, NetBeans, or IntelliJ IDEA. Refer to each IDE’s help for details.
5. Deployment
An application client module can be deployed "manually".
In the module, depending on the need, there are the Jakarta EE standard descriptor files, namely the application-client.xml file, and the jeus-client-dd.xml file, which is provided by JEUS. First, create a module file for the application client, and then move the file to a preferred location.
If there is a function that is controlled by the web service client, perform additional deployment via a console tool named jeusadmin, or use appcompiler to create a web service stub.
For more information about deployment, refer to JEUS Applications & Deployment Guide. |
6. Execution
This section outlines JEUS libraries that are additionally required by each service and describes how to execute modules in the console.
6.1. JEUS Libraries
To use a web service by using an application client, additional libraries besides JEUS_HOME/lib/client/clientcontainer.jar (the default library) are required. Most of the libraries are located in JEUS_HOME/lib/system (SYSTEM_LIB_DIR).
The following is the list of JEUS libraries required for each service.
Service | JEUS Library |
---|---|
JMS(Java Message Service) |
|
Web Service |
|
JMX(Java Management eXtensions) |
|
For more information about the web service, refer to JEUS Web Service Guide. |
6.2. Executing in Console
To execute an application client module in the console, you can use the appclient command. The appclient script is located under the JEUS_HOME\bin directory, and executes an application client module through a client container.
The following are the command lines for JEUS client container.
-
Usage
appclient -client client_jar_path [-main main_class] [-cp classpath] application_arguments...
The following describes the command options.
Option Description -client client_jar_path
Specifies the path of the application client to be executed.
[-main main_class]
Specifies the main class of the application client. This option is not required when main-class is already specified in the META-INF\MANIFEST.MF, located in the client’s class path.
[-cp classpath]
Specifies a class path for executing the client, if needed.
-
Example
If the sample command lines are executed, the following is displayed. For the application client to be successfully executed, the Hello EJB should be deployed first.
JEUS_HOME/samples/client/hello/hello-client/dist$ appclient -client hello-client.jar [2016.08.03 14:44:46][0] [t-1] [CLIENT-0050] Starting the Application Client Container - JEUS 9 Fix#0 EJB output : Hello EJB!
If you want to turn off logging, use the following command:
-Djeus.log.level=OFF
For detailed information on log settings, see Logging in JEUS Server Guide.