1
0
mirror of https://github.com/go-kratos/kratos.git synced 2025-01-24 03:46:37 +02:00
kratos/README.md

141 lines
6.0 KiB
Markdown
Raw Normal View History

![kratos](docs/images/kratos.png)
2019-04-29 17:29:50 +08:00
[![Language](https://img.shields.io/badge/Language-Go-blue.svg)](https://golang.org/)
[![Build Status](https://github.com/go-kratos/kratos/workflows/Go/badge.svg)](https://github.com/go-kratos/kratos/actions)
2021-02-17 22:44:56 +08:00
[![GoDoc](https://pkg.go.dev/badge/github.com/go-kratos/kratos/v2)](https://pkg.go.dev/github.com/go-kratos/kratos/v2)
2021-03-21 17:08:06 +08:00
[![Go Report Card](https://goreportcard.com/badge/github.com/go-kratos/kratos)](https://goreportcard.com/report/github.com/go-kratos/kratos)
2020-10-16 22:44:28 +08:00
[![Discord](https://img.shields.io/discord/766619759214854164?label=chat&logo=discord)](https://discord.gg/BWzJsUJ)
2019-02-01 15:57:43 +08:00
Translations: [English](README.md) | [简体中文](README_zh.md)
2019-06-12 00:27:51 +08:00
# Kratos
Kratos is a microservice-oriented governance framework implements by golang, which offers convenient capabilities to help you quickly build a bulletproof application from scratch.
2019-02-01 16:01:19 +08:00
>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.
2019-04-27 22:09:58 +08:00
2019-06-12 00:27:51 +08:00
## Goals
2019-04-27 22:09:58 +08:00
2021-03-05 13:31:36 +08:00
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.
2021-02-17 17:14:47 +08:00
### Principles
2019-04-28 17:43:31 +08:00
2021-03-05 13:31:36 +08:00
* **Simple**: Appropriate design, plain and easy code.
2021-02-24 22:27:54 +08:00
* **General**: Cover the various utilities for business development.
2021-03-05 13:31:36 +08:00
* **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.
2021-02-24 22:27:54 +08:00
* **Fault-tolerance**: Designed against failure, enhance the understanding and exercising of SRE within Kratos to achieve more robustness.
2021-03-05 13:31:36 +08:00
* **Toolchain**: Includes an extensive toolchain, such as the code generation of cache, the lint tool, and so forth.
2021-02-17 17:14:47 +08:00
## Features
2021-03-05 13:31:36 +08:00
* APIs: The communication protocol is based on the HTTP/gRPC through the definition of Protobuf.
* Errors: Both the definitions of error code and the handle interfaces of code generation for tools are defined by the Enum of the Protobuf.
* Metadata: In the protocol of HTTP/gRPC, the transmission of service atomic information are formalized by the Middleware.
* Config: Multiple data sources are supported for configurations and integrations such that dynamic configurations are offered through the manner of *Atomic* operations.
* Logger: The standard log interfaces ease the integration of the third-party log libs and logs are collected through the *Fluentd*.
* Metrics: *Prometheus* integrated by default. Furthermore, with the uniform metric interfaces, you can implement your own metric system more flexible.
* Tracing: The OpenTelemetry is conformed to achieve the tracing of microservices chains.
2021-03-05 13:31:36 +08:00
* Encoding: The selection of the content encoding is automatically supported by Accept and Content-Type.
* Transport: The uniform plugins for Middleware are supported by HTTP/gRPC.
* Registry: The interfaces of the centralized registry is able to be connected with various other centralized registries through plug-ins.
2021-02-17 17:14:47 +08:00
## Getting Started
### Required
- [go](https://golang.org/dl/)
- [protoc](https://github.com/protocolbuffers/protobuf)
- [protoc-gen-go](https://github.com/protocolbuffers/protobuf-go)
2021-02-19 23:06:26 +08:00
### Installing
2021-06-27 13:12:56 +08:00
##### install from go get:
2019-04-12 21:07:26 +08:00
```
go get github.com/go-kratos/kratos/cmd/kratos/v2@latest
2021-06-27 13:12:56 +08:00
kratos upgrade
2021-02-17 17:14:47 +08:00
```
2021-06-27 13:12:56 +08:00
##### install from source code:
```
git clone https://github.com/go-kratos/kratos
cd kratos
make install
```
2021-02-17 17:14:47 +08:00
### Create a service
```
# create project template
2021-02-17 17:14:47 +08:00
kratos new helloworld
cd helloworld
2021-03-17 20:31:37 +08:00
# download modules
go mod download
# generate Proto template
2021-02-17 17:14:47 +08:00
kratos proto add api/helloworld/helloworld.proto
# generate Proto source code
kratos proto client api/helloworld/helloworld.proto
# generate server template
kratos proto server api/helloworld/helloworld.proto -t internal/service
# generate all proto source code, wire, etc.
2021-02-24 19:37:19 +08:00
go generate ./...
# run
kratos run
2019-04-12 21:07:26 +08:00
```
2021-02-19 23:06:26 +08:00
### Kratos Boot
2021-02-17 17:34:19 +08:00
```
import "github.com/go-kratos/kratos/v2"
import "github.com/go-kratos/kratos/v2/transport/grpc"
import "github.com/go-kratos/kratos/v2/transport/http"
httpSrv := http.NewServer(http.Address(":8000"))
grpcSrv := grpc.NewServer(grpc.Address(":9000"))
app := kratos.New(
kratos.Name("kratos"),
kratos.Version("latest"),
kratos.Server(httpSrv, grpcSrv),
)
app.Run()
```
2021-02-19 23:06:26 +08:00
## Related
2021-02-17 17:34:19 +08:00
2021-03-21 17:08:06 +08:00
* [Tutorial](https://go-kratos.dev/docs/getting-started/start)
* [Examples](./examples)
2021-03-21 17:08:06 +08:00
* [Project Template](https://github.com/go-kratos/kratos-layout)
* [FAQ](https://go-kratos.dev/docs/getting-started/faq)
2019-04-17 12:30:59 +08:00
2021-02-17 17:14:47 +08:00
## Community
* [Wechat Group](https://github.com/go-kratos/kratos/issues/682)
* [Discord Group](https://discord.gg/BWzJsUJ)
2021-06-17 10:29:22 +08:00
* Website: [go-kratos.dev](https://go-kratos.dev)
2021-02-17 17:14:47 +08:00
* QQ Group: 716486124
2019-04-12 21:07:26 +08:00
## Conventional commits
The structure of the commit message should look like the following
```text
<type>[optional scope]: <description>
[optional body]
[optional footer(s)]
```
The information should be commit in the following format:
- fix: simply describe the problem that has been fixed
- feat(log): simple describe of new features
- deps(examples): simple describe the change of the dependency
- break(http): simple describe the reasons for breaking change
2021-01-06 22:51:57 +08:00
## License
2021-02-17 17:14:47 +08:00
Kratos is MIT licensed. See the [LICENSE](./LICENSE) file for details.
2021-03-18 11:05:16 +08:00
## Contributors
Thanks for their outstanding contributions.
<a href="https://github.com/go-kratos/kratos/graphs/contributors">
<img src="https://contrib.rocks/image?repo=go-kratos/kratos" />
</a>