mirror of https://github.com/alibaba/arthas.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
3.9 KiB
Plaintext
87 lines
3.9 KiB
Plaintext
Advanced Usage
|
|
==============
|
|
|
|
## Basic
|
|
|
|
* help - display Arthas help
|
|
* cls - clear the screen
|
|
* [cat](cat.md) - Concatenate and print files
|
|
* [pwd](pwd.md) - Return working directory name
|
|
* session - display current session information
|
|
* [reset](reset.md) - reset all the enhanced classes. All enhanced classes will also be reset when Arthas server is closed by `shutdown`
|
|
* version - print the version for the Arthas attached to the current Java process
|
|
* history - view command history
|
|
* quit/exit - exit the current Arthas session, without effecting other sessions
|
|
* shutdown - terminate the Arthas server, all Arthas sessions will be destroyed
|
|
* [keymap](keymap.md) - keymap for Arthas keyboard shortcut
|
|
|
|
## JVM
|
|
|
|
* [dashboard](dashboard.md) - dashboard for the system's real-time data
|
|
* [thread](thread.md) - show java thread information
|
|
* [jvm](jvm.md) - show JVM information
|
|
* [sysprop](sysprop.md) - view/modify system properties
|
|
* [sysenv](sysenv.md) — view system environment variables
|
|
* [getstatic](getstatic.md) - examine class's static properties
|
|
* **New!** [ognl](ognl.md) - execute ongl expression
|
|
* **New!** [mbean](mbean.md) - show Mbean information
|
|
|
|
## class/classloader
|
|
|
|
* [sc](sc.md) - check the info for the classes loaded by JVM
|
|
* [sm](sm.md) - check methods info for the loaded classes
|
|
* [jad](jad.md) - decompile the specified loaded classes
|
|
* [mc](mc.md) - Memory compiler, compiles `.java` files into `.class` files in memory
|
|
* [redefine](redefine.md) - load external `*.class` files and re-define it into JVM
|
|
* [dump](dump.md) - dump the loaded classes in byte code to the specified location
|
|
* [classloader](classloader.md) - check the inheritance structure, urls, class loading info for the specified class; using classloader to get the url of the resource e.g. `java/lang/String.class`
|
|
|
|
## monitor/watch/trace - related
|
|
|
|
> **Attention**: commands here are taking advantage of byte-code-injection, which means we are injecting some [aspects](https://en.wikipedia.org/wiki/Aspect-oriented_programming) into the current classes for monitoring and statistics purpose. Therefore when use it for online troubleshooting in your production environment, you'd better **explicitly specify** classes/methods/criteria, and remember to remove the injected code by `shutdown` or `reset`.
|
|
|
|
* [monitor](monitor.md) - monitor method execution statistics
|
|
* [watch](watch.md) - display the input/output parameter, return object, and thrown exception of specified method invocation
|
|
* [trace](trace.md) - trace the execution time of specified method invocation
|
|
* [stack](stack.md) - display the stack trace for the specified class and method
|
|
* [tt](tt.md) - time tunnel, record the arguments and returned value for the methods and replay
|
|
|
|
## options
|
|
|
|
* [options](options.md) - check/set Arthas global options
|
|
|
|
|
|
## pipe
|
|
|
|
Arthas provides `pipe` to process the result returned from commands further, e.g. `sm java.lang.String * | grep 'index'`. Commands supported in `pipe`:
|
|
|
|
* grep - filter the result with the given keyword
|
|
* plaintext - remove the ANSI color
|
|
* wc - count lines
|
|
|
|
## async in background
|
|
|
|
[async](async.md) can be handy when a problem is hardly to reproduce in the production environment, e.g. one `watch` condition may happen only once in one single day.
|
|
|
|
* job control - use `>` to redirect result into the log file, use `&` to put the job to the background. Job keeps running even if the session is disconnected (the session lifecycle is 1 day by default)
|
|
* jobs - list all jobs
|
|
* kill - forcibly terminate the job
|
|
* fg - bring the suspend job to the foreground
|
|
* bg - put the job to run in the background
|
|
|
|
## Web Console
|
|
|
|
Arthas supports living inside a browser. The communication between arthas and browser is via websocket.
|
|
|
|
* [Web Console](web-console.md)
|
|
|
|
## Other features
|
|
|
|
* [Async support](async.md)
|
|
* [log the output](save-log.md)
|
|
* [batch](batch-support.md)
|
|
* [how to use ognl](https://github.com/alibaba/arthas/issues/11)
|
|
|
|
|
|
|