Skip to content

Azure-Samples/clustered-jboss-demo

Repository files navigation

Clustered JBoss Quickstart

To complete this quickstart you will need an active Azure Subscription and the following tools installed on your machine:

  • Azure CLI
  • Java 11
  • Maven

If you do not have those tools installed locally, you can use the Azure Cloud Shell in your web browser.

Deploy the Application

  1. Clone this repository

    git clone https://github.com/Azure-Samples/clustered-jboss-demo.git
  2. Run the shell commands below to create a resource group and deploy the ARM template. The template will create a Virtual Network, App Service Plan, and JBoss EAP web app.

    Bash

    Set your desired Web App name, location, and resource group if you have not done so prevoiusly.

    WEBAPP_NAME=<provide a unique name>  # upper and lowercase letters, numbers, and dashes OK
    LOCATION=eastus
    RESOURCE_GROUP=jboss-rg

    Deploy the ARM Template.

    az group create --name $RESOURCE_GROUP --location $LOCATION
    az deployment group create \
        --name jboss_deployment \
        --resource-group $RESOURCE_GROUP \
        --template-file arm-template.json \
        --parameters jboss_app_name=$WEBAPP_NAME

    PowerShell

    Set your desired Web App name, location, and resource group if you have not done so prevoiusly.

    $env:WEBAPP_NAME=''
    $env:LOCATION='westus'
    $env:RESOURCE_GROUP='jboss-rg'

    Deploy the ARM Template.

    az group create --name $env:RESOURCE_GROUP --location $env:LOCATION
    az deployment group create `
        --name jboss_deployment `
        --resource-group $env:RESOURCE_GROUP `
        --template-file arm-template.json `
        --parameters jboss_app_name=$env:WEBAPP_NAME

    The App Service Plan is configured to have 3 JBoss EAP instances which will form the cluster.

  3. Build the app with Maven.

    mvn clean package
  4. Deploy the app using the Azure CLI.

    Bash

    az webapp deploy -n $WEBAPP_NAME -g $RESOURCE_GROUP --src-path target/session-replication.war

    PowerShell

    az webapp deploy -n $env:WEBAPP_NAME -g $env:RESOURCE_GROUP --src-path target/session-replication.war
  5. After a moment the web app will restart and initialize JBoss with the new application. Browse to the app at http://<your-site-name>.azurewebsites.net/testHA.jsp.

Explore the app

The table in the web page displays your current session ID, the JBoss instance ID, and a simple counter. Increment the counter and refresh the web page. You should see a new JBoss EAP instance ID, but the counter will display the same session and counter information. This means that the stateful session information was shared between the first and second EAP instances. Even though you were routed to a different cluster member the session information was persisted across instances.

About

Demo app for clustered Red Hat JBoss EAP on App Service

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published