Configure data access for the Application Client
Configure data access for the Application Client involves specifying the resource reference and associated database information required for data access. This specification is done as part of the assembly and deployment steps for the Application Client.
There are two tools needed to configure data sources used by J2EE application clients:
- An assembly tool for defining the resource reference in the deployment descriptor; and
- The Application Client Resource Configuration Tool (ACRCT) for defining the connection to the database in the client deployment environment.
Data access from an application client uses the JDBC driver connection functions directly from the client side. It does not take advantage of the additional pooling support available in the WebSphere Application Server run time. Configuring data access for an application client does not require configuration of a JDBC provider and data source on the WAS server machine.
To take advantage of the pooling and additional database functions provided by the product, IBM recommends that the client application utilize an enterprise bean running on the server side to perform data access.
Define an application client resource reference using an assembly tool
Tasks
- Assemble the application client module as described in the topic, Assembling Java EE client applications.
- Create a new resource reference:
- In a Project Explorer view, right-click the application client module and click Open With > Deployment Descriptor Editor.
- On the References tab, click Add > Resource reference > Next.
- On the Resource Reference page, enter the Name of this resource reference. The Application Client for WAS run time uses this name for two purposes: to bind the object into the java:comp/env portion of the JNDI namespace, and to find client specific configuration information. If the code for the Application Client performs a lookup for java:comp/env/jdbc/myDB, the name of the resource reference should be jdbc/myDB.
- For Type, select javax.sql.DataSource for JDBC connections.
- For Authentication, select Application if the client application intends to provide authentication information. If the Application Client run time provides the authentication information (as configured by the Application Client Resource Configuration tool), select Container.
- Ignore the Sharing scope setting; it is unused in an application client resource reference. All Application Client resources are not shared.
- Click Finish.
- Close the deployment descriptor and save the changes.
The JNDI name field appears under WebSphere Bindings after your add the reference.
Client configuration with the ACRCT
About this task
There are two client resources for you to configure in the Application Client Resource Configuration Tool (ACRCT) to enable data access from an application client: a data source provider and a data source.Restriction: The following objects, which can be bound into the server name space, are not supported on the client:
- Java 2 Connector (J2C) objects
- Connection manager objects
The Application Client does not provide client database drivers. If our client application uses a database directly, rather than using an enterprise bean, provide the database drivers on the client machine. This action can involve contacting the database vendor to acquire client database driver code and licenses.
Instead of accessing the database directly, IBM recommends that the client application use an enterprise bean. Accessing a database through an enterprise bean eliminates the need to have database drivers on the client machine because the database access is handled by the enterprise bean running on the application server. Enterprise beans can also take advantage of the additional database functions provided by the run time.
Tasks
- Configure a new data source provider as described in the topic Configuring new data source providers. This provider describes the JDBC database implementation for our client application.
- Enter the following information on the General tab:
- A name for this data source provider.
- Optional: A description.
- The classpath to the data source provider implementation classes or JAR files. This is optional if the implementation classes or JAR files are already in the class path configuration of the client.
- The name of the implementation class. For example, for DB2 this value is COM.ibm.db2.jdbc.DB2DataSource. Remember this class must implement the javax.sql.DataSource class. The ACRCT does not verify this class and we receive an error when we run the client application if the class does not implement javax.sql.DataSource.
Use the Custom tab to configure non-standard properties of the data source provider. This panel enables us to enter property-value pairs. During run time the implementation class name is created and any custom properties added on this panel are set on the newly created data source object using reflection. Any properties configured on this panel must have an appropriate set method on the data source class. For example, assume there is a property called use2Phase and its value should be 1. On the custom panel you enter the value use2Phase into the name column and the value 1 into the value column. The Application Client run time then uses reflection to find a property on the data source class called, typically setUse2Phase and call that method passing the value of 1. See the database product documentation for valid properties on the data source implementation.
- Click OK.
- Configure a new data source as described in the topic, Configuring new data sources for application clients. This describes the client properties of the database the client application uses.
- Enter the following information on the General tab:
- A Name. This field is required and identifies a name for the Application Client Resource Configuration Tool to use. This name is not used by the client application program.
- Optional: A description.
- The JNDI name. This field is required and must match the value entered in the Name field on the Add Resource Reference page of the assembly tool. In the previous example, set this value to jdbc/myDB.
- Optional: The Database Name.
- Optional: Your userid in the User field.
- Optional: Your password in the Password field. This password does not display.
- Your password again to confirm in the Re-Enter password field. Note: The User and Password fields are used only when the Authentication field on the Add Resource Reference page of the assembly tool is set to Container.
Related:
Data sources Assembling Java EE client applications Deploy a Java EE client application Configure new data sources for application clients Java EE client application class loading