CDI Tools

This section lists existing development tools available from the CDI implementation shipped in Payara Server.

CDI Development Mode

CDI Development Mode enables some CDI related tools and features that help when developing and inspecting applications that contain CDI beans.

This mode also provides a CDI Probe, which allows to inspect and monitor CDI beans of deployed applications at runtime.

It’s possible to enable CDI Development Mode for each application separately or enable it for all applications globally. In both cases, each application is assigned a separate CDI Probe instance.

CDI Development Mode can be enabled in the following ways:

  • The application defines a context parameter in web.xml (always enabled for the application)

  • At deploy time (enabled only for individual application)

  • Via a system property (always enabled for all deployed applications)

If CDI Development Mode is enabled by one of the options above, it can’t be disabled by any other option.
CDI Development Mode will be enabled only if the deployed application contains any valid CDI bean definitions.

Once CDI Development mode is enabled you should be able to see a message similar to this one in the server’s log output:

Weld Development Mode: ENABLED
log

Enabling CDI Development Mode

The CDI Development Mode can be enabled using the following mechanisms:

Via asadmin CLI

Using the asadmin CLI it is possible to enable development mode for a single application or for ALL deployed applications.

Enabling for a single application

The CDI Development Mode can be enabled for a single application with the deploy command. Add the cdiDevModeEnabled=true property to the --properties argument’s value of the deploy command.

Here’s an example of enabling development mode for an application named application.war:

asadmin> deploy --properties cdiDevModeEnabled=true myapplication.war
shell
It’s also possible to use the same cdiDevModeEnabled property with the redeploy command to enable/disable development mode when redeploying an application.
Enabling for all applications

The CDI Development Mode can be enabled for all applications by setting the org.jboss.weld.development system property to true with the create-system-properties asadmin command:

asadmin> create-system-properties org.jboss.weld.development=true
shell
All applications deployed AFTER this setting is applied will have CDI Development Mode enabled.

To enable it for already deployed applications, it’s necessary to redeploy them or disable and then enable them. The latter can be done with the disable and enable asadmin commands:

asadmin> disable myapplication
asadmin> enable myapplication
shell

Using Admin Console

Using the admin web console it is possible to enable development mode for a single application or for ALL deployed applications.

Enabling for a single application

The CDI Development Mode can be enabled for a single application during deployment. The Deploy Application page provides a checkbox to enable the CDI Development Mode for the application. If the checkbox is clicked, the CDI development mode is enabled:

Turn On CDI Development Mode

In the Edit Application page, you can see that the CDI Development Mode checkbox is checked:

CDI Development Mode enabled

In this page, it’s also possible to enable/disable the CDI Development Mode after an application is deployed. Changing the value of the CDI Development Mode checkbox will trigger redeployment of the application to take effect immediately.

Enabling for all applications

The CDI Development Mode can be enabled for all applications by setting the org.jboss.weld.development system property to true in the server configuration or by specifying it as a JVM startup option.

To set the system property for the server globally, click on server (Admin Server) in the sidebar on the left. Then click on the Properties tab. In the System Properties page, add property with variable name org.jboss.weld.development and override value set to true, and press Save:

Set CDI Development Mode System Property
All applications deployed AFTER this setting is applied will have CDI Development Mode enabled.

To enable it for already deployed applications, it’s necessary to redeploy each application or disable then enable it.

Using web.xml deployment descriptor

To enable CDI Development Mode in a WAR application archive, add the following context parameter to the web.xml deployment descriptor:

<web-app>
    <context-param>
        <param-name>org.jboss.weld.development</param-name>
        <param-value>true</param-value>
    </context-param>
</web-app>
xml

This configuration will automatically enable CDI Development Mode for the application once is deployed.

Currently, it’s not possible to override this option and disable CDI Development Mode in application server configuration without providing an alternative web.xml deployment descriptor during deployment.

CDI Probe

Once CDI Development Mode is enabled, the web admin console will provide access to the CDI Probe tool which allows users to inspect and monitor CDI beans of deployed applications at runtime.

The CDI Probe supplies the following interfaces for consuming data in real time:

  • A REST API

  • An HTML-based application accessible via a web browser

  • Multiple JMX beans with monitoring metrics

Accessing the CDI Probe via REST API

The CDI Probe exposes a REST API at the context root of the application suffixed by path /weld-probe, followed by path to the REST resource.

The REST interface is documented in the official Weld CDI Probe documentation

Using CDI Probe Web Application

An instance of the CDI Probe is attached to each application in CDI Development Mode and is available at the context root of the application suffixed by the path /weld-probe. For example, http://localhost:8080/cargo-tracker/weld-probe.

Access from Admin Console

Once CDI Development Mode is enabled for an application, the Edit Application page in the Admin Console provides a link to open the CDI Probe web application for quick reference.

You can find the link called CDI Probe in the Modules and Components table, in the Action column:

CDI Probe web application in Admin Console
The CDI Probe link won’t be visible if the CDI Development Mode checkbox on this page isn’t selected. If the development mode is enabled by other means, the CDI Probe will still be accessible. Either check the CDI Development Mode checkbox and press Save or access CDI Probe directly by adding /weld-probe to the URL of your application.

The CDI Probe link will open the web application in a new browser window:

CDI Probe Web Application
Access from an application’s web pages

If your application serves web pages, you can also access the CDI Probe web application from the toolbar that is added by the CDI Development Mode at the bottom of every web page. Below is an example on how the toolbar looks like in a sample application named "Cargo Tracker":

CDI Probe via Sample Application

If the application uses CDI beans to process the HTTP request used to serve the webpage in question, the toolbar will also contain a link to see all bean invocations as a tree of events, which may look like this:

CDI Invocation Event Tree sample