Skip to content

An observability platform mainly for Java

License

Notifications You must be signed in to change notification settings

yuanlihan/bithon

 
 

Repository files navigation

Build Status


What's Bithon

Bithon is a word combining binocular together with python.

It targets application metrics, logging, distributed tracing, alert and application risk governance under microservice environment.

Reference:

Demon

A demo is provided by this demo repo with a docker-compose file. You can follow the README on that demo repo to start the demo within just 3 steps.

Build

1. clone source code

After cloning this project, remember to clone the submodules by following command

git submodule update --init

2. choose a right JDK

JDK 1.8 is recommended because the agent is compatible with higher JRE that is used to run your Java applications.

If you have multiple JDKs on your machine, use export JAVA_HOME={YOUR_JDK_HOME} command to set correct JDK.

For example

export JAVA_HOME=/Library/Java/JavaVirtualMachines/openjdk-8.jdk/Contents/Home

3. build the project

For the first time to build this project, use the following command to build dependencies first:

mvn clean install --activate-profiles shaded,jooq

and then execute the following command to build the project.

mvn clean install -DskipTests

After the first build, we don't need to build the dependencies anymore unless there are changes in these dependencies.

Run

Once the project has been built, you could run the project in a standalone mode to evaluate this project.

1. Launch collector & web server

To launch server in evaluation mode, execute the following command:

java -Dspring.profiles.active=all-in-one -jar server/server-starter/target/server-starter.jar

By default, the application opens and listens on following ports at local

Function Port
tracing 9895
event 9896
metric 9898
ctrl 9899
web 9897

Once the application has started, visit http://localhost:9897/web/home to view the monitor.

Note: -Dspring.profiles.include parameter here is just for demo.

You can make changes to server/server-starter/src/main/resources/application.yml to reflect your own settings.

You can also use enable Alibaba Nacos as your configuration storage center.

2. Attach agent to your java application

Attach agent to your java agent by adding the following VM arguments.

-javaagent:<YOUR_PROJECT_DIRECTORY>/agent/agent-distribution/target/agent-distribution/agent-main.jar -Dbithon.application.name=<YOUR_APPLICATION_NAME> -Dbithon.application.env=<YOUR_APPLICATION_ENV>
Variable Description
YOUR_PROJECT_DIRECTORY the directory where this project saves
YOUR_APPLICATION_NAME the name of your application. It could be any string
YOUR_APPLICATION_ENV the name of your environment to label your application. It could be any string. Usually it could be dev, test, prd

By default, the agent connects collector running at local(127.0.0.1). Collector address could be changed in file agent/agent-main/src/main/resources/agent.yml. Make sure to re-build the project after changing the configuration file above.

JDKs Compatibility

The following matrix lists the JDKs that have been tested on macOS. And in theory, this matrix works both for Windows and Linux.

JDK Supported
JDK 1.8.0_291
JDK 9.0.4
JDK 10.0.2
JDK 11.0.12
JDK 12.0.2
JDK 13.0.2
JDK 14.0.2
JDK 15.0.2
JDK 16.02
JDK 17

JDK 11 and above

If the target application runs under JDK 11 and above, the following arguments should be added to JVM command to allow the agent to use Java Reflection on corresponding packages.

--add-exports=java.base/jdk.internal.misc=ALL-UNNAMED --add-exports=java.base/sun.net.www=ALL-UNNAMED

Supported Components

Component Min Version Max Version Metrics Tracing
JVM 1.8
JDK - Thread Pool 1.8
JDK - HTTP Client 1.8
Alibaba Druid 1.0.28
Apache Druid 0.16 24.0
Apache Kafka 0.10
Apache OZone 1.3.0
Eclipse Glassfish 2.34
GRPC 1.6.0
Google Guice 4.1.0
HTTP Client - Apache 4.5.2
HTTP Client - Jetty 9.4.6
HTTP Client - Netty 3.10.6 < 4.0
HTTP Client - okhttp3 3.2 4.9
Jersey 1.19.4
MongoDB 3.4.2
MySQL 5.x 8.x
Quartz 2.x
Redis - Jedis 2.9
Redis - Lettuce 5.1.2
Spring Boot 1.5 3.0+
Spring Bean 4.3.12
Spring Open Feign 10.12
Spring Rest Template 4.3.12
Spring Scheduling 4.3.12
Spring WebFlux 5.0.0
HTTP Server - Jetty 9.4.41
HTTP Server - Netty 2.0.0
HTTP Server - Tomcat 8.5.20
HTTP Server - Undertow 1.4.12

User Doc

  1. Metrics
  2. Tracing
  3. Logging
  4. Diagnosis
  5. Configuration
  6. SDK
    1. Metrics
    2. Tracing

Contribution

To develop for this project, intellij is recommended.

A code style template file(dev/bithon_intellij_code_style) must be imported into intellij for coding.

For more information, check the development doc.

License

Apache License, Version 2.0

About

An observability platform mainly for Java

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 72.8%
  • JavaScript 23.0%
  • HTML 2.1%
  • CSS 1.3%
  • SCSS 0.6%
  • Shell 0.1%
  • ANTLR 0.1%