Skip to content

Sermant, a proxyless service mesh solution based on Javaagent.

License

Notifications You must be signed in to change notification settings

fuziye01/Sermant

 
 

Repository files navigation

A proxyless service mesh solution based on Javaagent

Gitter License CI/IT Tests

What is Sermant

Sermant is a proxyless service mesh technology based on JavaAgent . It leverages the JavaAgent to instrument the host application with enhanced service governance function, in order to solve the service governance problem, in the massive micro-service architecture.

Sermant's purpose also includes building a plugin-development ecosystem to help developers develop the service governance function more easily while not interfering the business code. The Sermant architecture is depicted as follows.

pic

As described above, Sermant's Javaagent has two layers of functions.

  • Framework core layer. The core layer provides Sermant's basic framework capability, in order to ease the plugin development. The function of this layer includes heart beat, data transmit, dynamic configuration, etc.
  • Plugin service layer. The plugin provides actual governance service for the application. The developer can either develop simple plugin by directly leveraging framework core service, or can develop complex plugin by developing plugin's own complex service-governance function.

Sermant's Javaagent widely adopts class isolation technology in order to eliminate the class load conflicts between framework code, plugin code, and application code.

A microservice architecture using Sermant has the following has the following three components, which is depicted in the following diagram.

pic

  • Sermant Javaagent: dynamically instrument the application for the service governance capability.
  • Sermant Backend: provide the connection and the pre-processing service for the Javaagents' all uploaded-data.
  • Dynamic configuration center: Providing the instructions by dynamically update the config to the listening Javaagent. Dynamic configuration center is not directly provided by Sermant project. The projects currently support servicecomb-kie, etc.

Quick start

Download or compile

Click here to download Sermant binary package. If you will to compile the project yourself, please follow the following steps.

Execute maven command to package the Sermant project's demo module.

mvn clean package -Dmaven.test.skip -Pexample

Execute maven command to package the Sermant project's back-end module.

mvn clean package -Dmaven.test.skip -Pbackend

Start Sermant

Start Sermant backend

# Run under Linux
java -jar sermant-agent-x.x.x/server/sermant/sermant-backend-x.x.x.jar
# Run under Windows
java -jar sermant-agent-x.x.x\server\sermant\sermant-backend-x.x.x.jar

Start Sermant demo project:

# Run under Linux
java -cp sermant-plugins/sermant-example/demo-application/target/demo-application.jar \
  -javaagent:sermant-agent-x.x.x/agent/sermant-agent.jar=appName=test \
  com.huawei.example.demo.DemoApplication
# Run under Windows
java -cp sermant-plugins\sermant-example\demo-application\target\demo-application.jar ^
  -javaagent:sermant-agent-x.x.x\agent\sermant-agent.jar=appName=test ^
  com.huawei.example.demo.DemoApplication

More documents to follow

Please refer to the Development Guide

License

Sermant adopts Apache 2.0 License.

How to contribute

Please read Contribute Guide to refer how to jion the contribution.

Declaration

  • Apache/Servicecomb-java-chassis: Sermant refer the service governance algorithm from Apache Servicecomb project.
  • Apache/Servicecomb-kie: Sermant uses servicecomb-kie as the default dynamic configuration center.
  • Apache/SkyWalking: The plugin architecture in this project is refered to Apache Skywalking. Part of the framework code in Sermant is built based on Apache Skywalking project as well.
  • Alibaba/Sentinel: Sermant's flow-control plugin is built based on Alibaba Sentinel project.

About

Sermant, a proxyless service mesh solution based on Javaagent.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 95.0%
  • JavaScript 3.1%
  • Roff 0.8%
  • FreeMarker 0.3%
  • HTML 0.3%
  • Shell 0.2%
  • Other 0.3%