You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
包子 dc0ed5bc42
docs: add wechat official account image to the Chinese document (#1190)
4 years ago
.github ci(github action): use golangci-lint to replace the deprecated golint (#1175) 4 years ago
api add v2.0.0 4 years ago
cmd fix(cmd/run): fix the problem of looking for the cmd directory outside the project (#1166) 4 years ago
config feat(env): add config env source (#1181) 4 years ago
docs docs: add wechat official account image to the Chinese document (#1190) 4 years ago
encoding ci(github action): use golangci-lint to replace the deprecated golint (#1175) 4 years ago
errors fix(http): fix error encoder (#1141) 4 years ago
examples fix(examples/config): fixed spelling mistake (#1186) 4 years ago
internal add v2.0.0 4 years ago
log change debug level to -1 (#1105) 4 years ago
metadata add range (#1052) 4 years ago
metrics init v2 4 years ago
middleware add response header (#1119) 4 years ago
registry fix nacos 4 years ago
third_party add swagger api examples 4 years ago
transport style(transport): remove duplicate get path code (#1188) 4 years ago
.gitignore init v2 4 years ago
.golangci.yml ci(github action): use golangci-lint to replace the deprecated golint (#1175) 4 years ago
LICENSE init v2 4 years ago
Makefile add source code installing (#1113) 4 years ago
README.md docs: default documents points to the english document (#1180) 4 years ago
README_zh.md docs: add wechat official account image to the Chinese document (#1190) 4 years ago
ROADMAP.md roadmap: update roadmap progress (#828) 4 years ago
SECURITY.md Create SECURITY.md 4 years ago
app.go Revert/root ctx v2 (#1088) 4 years ago
app_test.go init v2 4 years ago
go.mod feat(examples/i18n) add i18n example (#1157) 4 years ago
go.sum feat(examples/i18n) add i18n example (#1157) 4 years ago
options.go add feat endpoint (#972) 4 years ago

README.md

Build Status GoDoc Go Report Card License Discord

Translate to: 简体中文

About Kratos

The name is inspired by the game God of War which is based on Greek myths, tells the Kratos from mortals to become a God of War and launches the adventure of killing god.

Kratos is a microservice-oriented governance framework implements by golang, which offers convenient capabilities to help you quickly build a bulletproof application from scratch, such as:

Kratos is accessible, powerful, and provides tools required for large, robust applications.

Learning Kratos

Kratos has the most extensive and thorough documentation and example library of all modern web application frameworks, making it a breeze to get started with the framework.

We also provide a moderm template, This template should help reduce the work required to setup up a modern project.

Goals

Kratos boosts your productivity. With the integration of excellent resources and further support, programmers can get rid of most issues might encounter in the field of distributed systems and software engineering such that they are allowed to focus on the release of businesses only. Additionally, for each programmer, Kratos is also an ideal one learning warehouse for many aspects of microservices to enrich their experiences and skills.

Principles

  • Simple: Appropriate design, plain and easy code.
  • General: Cover the various utilities for business development.
  • Highly efficient: Speeding up the efficiency of businesses upgrading.
  • Stable: The base libs validated in the production environment which have the characters of the high testability, high coverage as well as high security and reliability.
  • Robust: Eliminating misusing through high quality of the base libs.
  • High-performance: Optimal performance excluding the optimization of hacking in case of unsafe. 
  • Expandability: Properly designed interfaces, you can expand utilities such as base libs to meet your further requirements.
  • Fault-tolerance: Designed against failure, enhance the understanding and exercising of SRE within Kratos to achieve more robustness.
  • Toolchain: Includes an extensive toolchain, such as the code generation of cache, the lint tool, and so forth.

Getting Started

Create a kratos playground through docker:

docker run -it --rm -p 8000:8000 --workdir /workspace golang
apt-get update && apt-get -y install protobuf-compiler
export GOPROXY=https://goproxy.io,direct
go get github.com/go-kratos/kratos/cmd/kratos/v2@latest && kratos upgrade
kratos new helloworld
kratos run

Use a browser to open and visit: http://localhost:8000/helloworld/kratos, The kratos program is running!

If you need more, please visit the kratos documentation.

Security Vulnerabilities

If you discover a security vulnerability within Kratos, please send an e-mail to tonybase via go-kratos@googlegroups.com. All security vulnerabilities will be promptly addressed.

Community

Contributors

Thank you for considering contributing to the Kratos framework! The contribution guide can be found in the Kratos documention.

License

The Kratos framework is open-sourced software licensed under the MIT license.

Acknowledgments

The following project had particular influence on kratos's design.

  • go-kit/kit is a programming toolkit for building microservices in go.
  • asim/go-micro a distributed systems development framework.
  • google/go-cloud is go cloud development kit.
  • tal-tech/go-zero is a web and rpc framework with lots of builtin engineering practices.
  • beego/beego is a web framework including RESTful APIs, web apps and backend services.