Summary: Byteman is a tool that simplifies tracing and testing of Java programs. It allows you to insert extra Java code into your application, either as it is loaded during JVM startup or after it has already started running. This code can be used to trace what the application is doing and to monitor and debug deployments to be sure it is operating correctly. You can also use Byteman to inject faults or synchronization code when testing your application.
A few of the quickstarts use Byteman to demonstrate distributed transaction processing and crash recovery, for example, to halt an application server in the middle of a distributed transaction to demonstrate crash recovery.
The following sections describe the steps necessary to install, configure, and use Byteman with these quickstarts.
- Download and Configure Byteman
- Clear the Transaction ObjectStore
- Use Byteman to Halt the Application
- Disable the Byteman Script
NOTE: See Use of EAP_HOME for information about the Red Hat JBoss Enterprise Application Platform installation path.
-
Download Byteman from http://www.jboss.org/byteman/downloads/
-
Extract the ZIP file to a directory of your choice. In the instructions below, we refer to this directory as
BYTEMAN_HOME
. -
By default, the Byteman download provides unrestricted permissions to
others
which can cause a problem when running Ruby commands for the OpenShift quickstarts. To restrict the permissions toothers
, open a command prompt and type the following:chmod -R o-rwx BYTEMAN_HOME/
Transaction objectstore data remaining from previous tests can prevent Byteman from working properly. You must remove any remaining data before running new Byteman tests. If you are using the default file based transaction logging store:
-
Open a command prompt and type the following:
ls EAP_HOME/standalone/data/tx-object-store/ShadowNoFileLockStore/defaultStore/StateManager/BasicAction/TwoPhaseCoordinator/AtomicAction/
-
If this directory exists and contains any files, delete them before starting the server:
rm -rf EAP_HOME/standalone/data/tx-object-store/ShadowNoFileLockStore/defaultStore/StateManager/BasicAction/TwoPhaseCoordinator/AtomicAction/*
-
On Windows, use the file manager to accomplish the same result.
NOTE: The Byteman scripts only work in JTA mode. They do not work in JTS mode. If you have configured the server for a quickstart that uses JTS, you must follow the quickstart instructions to remove the JTS configuration from the JBoss EAP server before making the following changes. Otherwise Byteman will not halt the server.
When instructed to use Byteman to halt the application, perform the following steps:
-
Find the appropriate configuration file for your operating system in the list below.
For Linux: EAP_HOME/bin/standalone.conf For Windows: EAP_HOME\bin\standalone.conf.bat
-
Important: Make a backup copy of this configuration file before making any modifications!
-
Open the configuration file and append the text specified in the quickstart README instructions to the end of the configuration file. Be sure to replace the
BYTEMAN_HOME
with the path to the Byteman download and theQUICKSTART_HOME
with the path to the quickstarts.The following is an example of of the configuration changes needed for the jta-crash-rec quickstart.
For Linux:
JAVA_OPTS="-javaagent:/BYTEMAN_HOME/lib/byteman.jar=script:/QUICKSTART_HOME/jta-crash-rec/src/main/scripts/xa.btm ${JAVA_OPTS}"
For Windows:
SET "JAVA_OPTS=%JAVA_OPTS% -javaagent:C:\BYTEMAN_HOME\lib\byteman.jar=script:C:\QUICKSTART_HOME\jta-crash-rec\src\main\scripts\xa.btm %JAVA_OPTS%"
When you have completed testing the quickstart, replace the server configuration file with the backup copy you created in step 2 above to disable Byteman.