Drop-in software update
The examples in this section assume that the agent is installed in
/path/to/java_agents/agent_type
, and the update is from
the minor version ${previous.minor.version} to the minor version ${current.minor.version}.
Tomcat Java Agent software update
-
Read the release notes for information about changes in Java Agent.
-
Download the agent binaries from the ForgeRock BackStage download site and extract them to a temporary directory.
The example in this section is extracted to
/tmp
, and the .jar files are in/tmp/tomcat_agent/lib
. -
Back up the directories for the agent installation and the web application container configuration:
-
$ cp -r /path/to/java_agents/tomcat_agent /path/to/backup $ cp -r /path/to/tomcat/webapps/agentapp /path/to/backup
bash -
In remote configuration mode, back up as described in AM’s Maintenance guide.
-
-
Redirect client traffic away from protected web applications.
-
Stop the web applications where the agent is installed.
-
Locate the following files in the container:
-
agent.jar
-
jee-agents-sdk-version.jar
The following example finds
./lib/jee-agents-sdk-${previous.minor.version}.jar
:$ cd /opt/container $ find . -type f -name 'jee-agents-*.jar' -print ./lib/jee-agents-sdk-${previous.minor.version}.jar
C:\> cd C:\opt\container C:\opt\container> dir /s jee-agents-*.jar ... Directory of C:\opt\container\lib date time ... jee-agents-sdk-${previous.minor.version}.jar ...
-
-
If
agent.jar
is present in the container, delete it. -
Replace
jee-agents-sdk-version.jar
with the newer downloaded version. The following example replacesjee-agents-sdk-${previous.minor.version}.jar
:$ cd /opt/container $ rm -f lib/jee-agents-sdk-${previous.minor.version}.jar $ cp /tmp/tomcat_agent/lib/jee-agents-sdk-${current.minor.version}.jar lib
C:\opt\container> del lib\jee-agents-sdk-${previous.minor.version}.jar C:\opt\container> copy C:\tmp\tomcat_agent\lib\jee-agents-sdk-${current.minor.version}.jar lib
-
(Optional) Update the .jar files outside the container.
-
Using the
.amAgentLocator
file, find the directory in which the agent was originally installed: -
View the content of the
lib
subdirectory:$ cd /path/to/java_agents/tomcat_agent/lib $ ls -F agent.jar jee-agents-installtools-${previous.minor.version}.jar jee-agents-sdk-${previous.minor.version}.jar
C:\opt\container> cd C:\path\to\java_agents\tomcat_agent\lib C:\path\to\java_agents\tomcat_agent\lib> dir Directory of C:\path\to\java_agents\tomcat_agent\lib ... agent.jar ... jee-agents-installtools-${previous.minor.version}.jar ... jee-agents-sdk-${previous.minor.version}.jar
-
Replace the files with the newer downloaded version:
$ rm -f * $ cp /tmp/java_agents/tomcat_agent/lib/*.jar . $ ls -F agent.jar jee-agents-installtools-${current.minor.version}.jar jee-agents-sdk-${current.minor.version}.jar
C:\path\to\java_agents\tomcat_agent\lib> del *.jar C:\path\to\java_agents\tomcat_agent\lib> copy C:\temp\java_agents\tomcat_agent\lib\*.jar . C:\tmp\tomcat_agent\lib\agent.jar C:\tmp\tomcat_agent\lib\jee-agents-installtools-${current.minor.version}.jar C:\tmp\tomcat_agent\lib\jee-agents-sdk-${current.minor.version}.jar
-
-
Replace the current
agentadmin
file with the newer downloaded version:$ cd /path/to/java_agents/tomcat_agent/bin $ rm agentadmin $ cp /tmp/tomcat_agent/bin/agentadmin .
C:\> cd C:\path\to\java_agents\tomcat_agent\bin C:\path\to\java_agents\tomcat_agent\bin> del agentadmin agentadmin.bat C:\path\to\java_agents\tomcat_agent\bin> copy C:\tmp\tomcat_agent\bin\agentadmin . C:\path\to\java_agents\tomcat_agent\bin> copy C:\tmp\tomcat_agent\bin\agentadmin.bat .
-
Start the web applications where the agent is installed.
-
Check that the agent is performing as expected:
-
Check the correct version of the agent is running:
-
Set the log level to
trace
, as described in Logging. -
In
/path/to/java_agents/agent_type/Agent_n/logs/debug
, search for lines containing the stringX-ForgeRock-Edge-Metadata
. The version number is given in the header.For example, the log file can contain the following header:
--header "X-ForgeRock-Edge-Metadata: JPA ${current.minor.version}
.
-
-
Navigate to a protected page on the website and confirm whether you can access it according to your configuration.
-
Check logs files for warnings and errors.
-
-
Allow client traffic to flow to the protected web applications.
JBoss and WildFly Java Agent software update
-
Read the release notes for information about changes in Java Agent.
-
Download the agent binaries from the ForgeRock BackStage download site and extract them to a temporary directory.
The example in this section is extracted to
/tmp
, and the .jar files are in/tmp/jboss_agent/lib
. -
Back up the directories for the agent installation and the web application container configuration:
-
$ cp -r /path/to/java_agents/jboss_agent /path/to/backup $ cp -r /path/to/jboss/webapps/agentapp /path/to/backup
bash -
In remote configuration mode, back up as described in AM’s Maintenance guide.
-
-
Redirect client traffic away from protected web applications.
-
Stop the web applications where the agent is installed.
-
Update the
module.xml
file.-
Locate the path to the installation, for example, at
/path/to/jboss/modules/org/forgerock/openam/agent/main/modules/org/forgerock/openam/agent/main
. -
If any of the following files are listed, remove the resource for the file:
-
tyrus-standalone-client-2.1.3.jar
-
jee-agents-jboss-common-${previous.minor.version}.jar
-
agent.jar
-
-
Update the resource for
jee-agents-sdk-version.jar
to use the absolute path and the newer downloaded version agent version. For example, change<resource-root path="jee-agents-sdk-${previous.minor.version}.jar"/>
to
<resource-root path="/path/to/java_agents/jboss_agent/lib/jee-agents-sdk-${current.minor.version}.jar"/>
-
-
Update the .jar files outside the container.
-
Using the
.amAgentLocator
file, find the directory in which the agent was originally installed:$ cd /opt/container $ cat .amAgentLocator; echo /path/to/java_agents/jboss_agent
-
View the content of the
lib
subdirectory:$ cd /path/to/java_agents/jboss_agent/lib $ ls -F agent.jar jee-agents-jboss-common-version.jar jee-agents-sdk-version.jar tyrus-standalone-client-version.jar
-
Replace the files with the newer downloaded version:
$ rm -f * $ cp /tmp/java_agents/jboss_agent/lib/*.jar . $ ls -F agent.jar jee-agents-jboss-common-version.jar jee-agents-sdk-version.jar tyrus-standalone-client-version.jar
-
-
Replace the current
agentadmin
file with the newer downloaded version:$ cd /path/to/java_agents/jboss_agent/bin $ rm agentadmin $ cp /tmp/jboss_agent/bin/agentadmin .
-
Start the web applications where the agent is installed.
-
Check that the agent is performing as expected:
-
Check the correct version of the agent is running:
-
Set the log level to
trace
, as described in Logging. -
In
/path/to/java_agents/agent_type/Agent_n/logs/debug
, search for lines containing the stringX-ForgeRock-Edge-Metadata
. The version number is given in the header.For example, the log file can contain the following header:
--header "X-ForgeRock-Edge-Metadata: JPA ${current.minor.version}
.
-
-
Navigate to a protected page on the website and confirm whether you can access it according to your configuration.
-
Check logs files for warnings and errors.
-
-
Allow client traffic to flow to the protected web applications.
Jetty Java Agent software update
-
Read the release notes for information about changes in Java Agent.
-
Download the agent binaries from the ForgeRock BackStage download site and extract them to a temporary directory.
The example in this section is extracted to
/tmp
, and the .jar files are in/tmp/jetty_agent/lib
. -
Back up the directories for the agent installation and the web application container configuration:
-
$ cp -r /path/to/java_agents/jetty_agent /path/to/backup $ cp -r /path/to/jetty/webapps/agentapp /path/to/backup
bash -
In remote configuration mode, back up as described in AM’s Maintenance guide.
-
-
Redirect client traffic away from protected web applications.
-
Stop the web applications where the agent is installed.
-
Replace the following files with the newer downloaded versions.
-
agent.jar
-
jee-agents-installtools-version.jar
-
jee-agents-sdk-version.jar
The following example replaces
jee-agents-sdk-${previous.minor.version}.jar
:$ cd /path/to/java_agents/jetty_agent/lib $ rm -f jee-agents-sdk-${previous.minor.version}.jar $ cp /tmp/jetty_agent/lib/jee-agents-sdk-${current.minor.version}.jar .
-
-
Update the Jetty configuration:
-
Go to the Jetty base directory.
$ cd /path/to/jetty-base/modules
-
In
amlogin.mod
, delete the line for/path/to/java_agents/jetty_agent/lib/agent.jar
if it is present. This file isn’t required from Java Agent 2023.9. -
In
amlogin.mod
, update the version number forjee-agents-sdk-version.jar
. The following example includesjee-agents-sdk-${current.minor.version}.jar
:# Jetty AM module # [depend] server security jndi webapp plus [xml] etc/amlogin.xml [lib] /path/to/java_agents/jetty_agent/Agent_001/config /path/to/java_agents/jetty_agent/locale /path/to/java_agents/jetty_agent/lib/jee-agents-sdk-${previous.minor.version}.jar
-
-
Replace the current
agentadmin
file with the newer downloaded version:$ cd /path/to/java_agents/jetty_agent/bin $ rm agentadmin $ cp /tmp/jetty_agent/bin/agentadmin .
-
Start the web applications where the agent is installed.
-
Check that the agent is performing as expected:
-
Check the correct version of the agent is running:
-
Set the log level to
trace
, as described in Logging. -
In
/path/to/java_agents/agent_type/Agent_n/logs/debug
, search for lines containing the stringX-ForgeRock-Edge-Metadata
. The version number is given in the header.For example, the log file can contain the following header:
--header "X-ForgeRock-Edge-Metadata: JPA ${current.minor.version}
.
-
-
Navigate to a protected page on the website and confirm whether you can access it according to your configuration.
-
Check logs files for warnings and errors.
-
-
Allow client traffic to flow to the protected web applications.
WebLogic Java Agent software update
-
Read the release notes for information about changes in Java Agent.
-
Download the agent binaries from the ForgeRock BackStage download site and extract them to a temporary directory.
The example in this section is extracted to
/tmp
, and the .jar files are in/tmp/weblogic_agent/lib
. -
Back up the directories for the agent installation and the web application container configuration:
-
$ cp -r /path/to/java_agents/weblogic_agent /path/to/backup
bash -
In remote configuration mode, back up as described in AM’s Maintenance guide.
-
-
Add the following file to the backup:
-
/Oracle/Middleware/Oracle_Home/user_projects/domains/base_domain/setAgentEnv_AdminServer.sh
-
-
Redirect client traffic away from protected web applications.
-
Stop the web applications where the agent is installed.
-
Update the .jar files in the installation directory.
-
Using the
.amAgentLocator
file, find the directory in which the agent was originally installed:$ cd /opt/container $ cat .amAgentLocator; echo /path/to/java_agents/weblogic_agent
-
View the content of the
lib
subdirectory:$ cd /path/to/java_agents/weblogic_agent/lib $ ls -F agent.jar jee-agents-installtools-${previous.minor.version}.jar jee-agents-sdk-${previous.minor.version}.jar
-
Replace the files with the newer downloaded version:
$ rm -f * $ cp /tmp/java_agents/weblogic_agent/lib/*.jar . $ ls -F agent.jar jee-agents-installtools-${current.minor.version}.jar jee-agents-sdk-${current.minor.version}.jar
-
-
Update the environment settings:
-
Locate the
setAgentEnv_AdminServer.sh
file. The file can be in a directory such as/Oracle/Middleware/Oracle_Home/user_projects/domains/base_domain/
. -
If any of the following files are listed, remove the information for the file:
-
/path/to/java_agents/weblogic_agent/lib/agent.jar
. -
/path/to/java_agents/weblogic_agent/lib/jee-agents-installtools-launcher-version
. The installation launcher was removed in Java Agent 2023.6. -
/path/to/java_agents/weblogic_agent/lib/jee-agents-installtools-version.jar
.
-
-
Change the version of
jee-agents-sdk-version.jar
to the newer downloaded version:... # Append AGENT_CLASSPATH to the WebLogic server classpath AGENT_CLASSPATH="/path/to/java_agents/weblogic_agent/lib/jee-agents-sdk-${current.minor.version}.jar:/path/to/java_agents/weblogic_agent/locale:/path/to/java_agents/weblogic_agent/Agent_001/config" CLASSPATH="${CLASSPATH}${CLASSPATHSEP}${AGENT_CLASSPATH}" export CLASSPATH ...
bash -
Save the file.
-
-
Replace the current
agentadmin
file with the newer downloaded version:$ cd /path/to/java_agents/weblogic_agent/bin $ rm agentadmin $ cp /tmp/weblogic_agent/bin/agentadmin .
-
Start the web applications where the agent is installed.
-
Check that the agent is performing as expected:
-
Check the correct version of the agent is running:
-
Set the log level to
trace
, as described in Logging. -
In
/path/to/java_agents/agent_type/Agent_n/logs/debug
, search for lines containing the stringX-ForgeRock-Edge-Metadata
. The version number is given in the header.For example, the log file can contain the following header:
--header "X-ForgeRock-Edge-Metadata: JPA ${current.minor.version}
.
-
-
Navigate to a protected page on the website and confirm whether you can access it according to your configuration.
-
Check logs files for warnings and errors.
-
-
Allow client traffic to flow to the protected web applications.