1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-17 17:44:30 +02:00
go-micro/README.md

90 lines
4.7 KiB
Markdown
Raw Normal View History

2020-12-09 21:52:18 +00:00
# Go Micro [![License](https://img.shields.io/:license-apache-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![Go.Dev reference](https://img.shields.io/badge/go.dev-reference-007d9c?logo=go&logoColor=white&style=flat-square)](https://pkg.go.dev/github.com/micro/go-micro/v2?tab=doc) [![Travis CI](https://api.travis-ci.org/micro/go-micro.svg?branch=master)](https://travis-ci.org/micro/go-micro) [![Go Report Card](https://goreportcard.com/badge/micro/go-micro)](https://goreportcard.com/report/github.com/micro/go-micro)
2015-01-13 23:31:27 +00:00
2020-04-13 22:15:21 +01:00
Go Micro is a framework for distributed systems development.
2016-06-20 02:52:38 +01:00
2018-11-27 19:43:57 +00:00
## Overview
Go Micro provides the core requirements for distributed systems development including RPC and Event driven communication.
2020-05-23 16:46:50 +01:00
The **Micro** philosophy is sane defaults with a pluggable architecture. We provide defaults to get you started quickly
2018-11-27 19:43:57 +00:00
but everything can be easily swapped out.
2016-12-07 16:54:19 +00:00
## Features
2016-07-03 02:49:13 +01:00
2017-06-15 19:57:27 +01:00
Go Micro abstracts away the details of distributed systems. Here are the main features.
2016-07-03 02:49:13 +01:00
2020-05-31 11:26:46 +01:00
- **Authentication** - Auth is built in as a first class citizen. Authentication and authorization enable secure
zero trust networking by providing every service an identity and certificates. This additionally includes rule
based access control.
- **Dynamic Config** - Load and hot reload dynamic config from anywhere. The config interface provides a way to load application
level config from any source such as env vars, file, etcd. You can merge the sources and even define fallbacks.
- **Data Storage** - A simple data store interface to read, write and delete records. It includes support for memory, file and
CockroachDB by default. State and persistence becomes a core requirement beyond prototyping and Micro looks to build that into the framework.
2018-12-02 13:23:46 +00:00
- **Service Discovery** - Automatic service registration and name resolution. Service discovery is at the core of micro service
2019-01-16 13:12:21 +00:00
development. When service A needs to speak to service B it needs the location of that service. The default discovery mechanism is
2019-11-06 22:04:02 +00:00
multicast DNS (mdns), a zeroconf system.
2018-12-02 13:23:46 +00:00
- **Load Balancing** - Client side load balancing built on service discovery. Once we have the addresses of any number of instances
of a service we now need a way to decide which node to route to. We use random hashed load balancing to provide even distribution
across the services and retry a different node if there's a problem.
- **Message Encoding** - Dynamic message encoding based on content-type. The client and server will use codecs along with content-type
to seamlessly encode and decode Go types for you. Any variety of messages could be encoded and sent from different clients. The client
2018-12-26 12:03:08 +00:00
and server handle this by default. This includes protobuf and json by default.
2018-12-02 13:23:46 +00:00
2020-12-09 18:35:07 +00:00
- **RPC Client/Server** - RPC based request/response with support for bidirectional streaming. We provide an abstraction for synchronous
communication. A request made to a service will be automatically resolved, load balanced, dialled and streamed.
2018-12-02 13:23:46 +00:00
- **Async Messaging** - PubSub is built in as a first class citizen for asynchronous communication and event driven architectures.
2020-04-11 18:23:37 +01:00
Event notifications are a core pattern in micro service development. The default messaging system is a HTTP event message broker.
2018-11-27 19:43:57 +00:00
2020-05-31 11:21:55 +01:00
- **Synchronization** - Distributed systems are often built in an eventually consistent manner. Support for distributed locking and
leadership are built in as a Sync interface. When using an eventually consistent database or scheduling use the Sync interface.
2018-12-02 13:26:38 +00:00
- **Pluggable Interfaces** - Go Micro makes use of Go interfaces for each distributed system abstraction. Because of this these interfaces
2020-12-26 15:42:10 +00:00
are pluggable and allows Go Micro to be runtime agnostic. You can plugin any underlying technology.
2018-12-02 13:26:38 +00:00
2018-11-14 15:18:13 +00:00
## Getting Started
2017-02-10 12:36:42 +00:00
2020-04-19 00:44:52 +01:00
To make use of Go Micro
2020-04-19 00:45:29 +01:00
```golang
2020-04-19 00:44:52 +01:00
import "github.com/micro/go-micro/v2"
2020-05-31 11:27:54 +01:00
2020-05-31 11:28:32 +01:00
// create a new service
2020-05-31 11:27:54 +01:00
service := micro.NewService(
micro.Name("helloworld"),
)
2020-05-31 11:28:32 +01:00
// initialise flags
2020-05-31 11:27:54 +01:00
service.Init()
2020-05-31 11:28:32 +01:00
// start the service
2020-05-31 11:27:54 +01:00
service.Run()
2020-04-19 00:44:52 +01:00
```
2020-12-09 17:05:05 +00:00
See the [docs](https://github.com/micro/micro/tree/master/docs/v2) for detailed information on the architecture, installation and use of go-micro.
2020-04-19 00:46:33 +01:00
2020-12-26 15:15:39 +00:00
## Code Generation
See [cmd/protoc-gen-micro](https://github.com/micro/go-micro/tree/master/cmd/protoc-gen-micro) for protobuf code generation.
2020-12-26 15:18:11 +00:00
## Example Usage
2020-12-26 15:17:20 +00:00
See [examples](https://github.com/micro/go-micro/tree/master/examples) directory for usage examples.
2020-12-26 15:32:45 +00:00
## Plugins
See [plugins](https://github.com/micro/go-micro/tree/master/plugins) directory for all the plugins.
2020-04-19 00:46:33 +01:00
## License
2020-04-28 19:35:13 +01:00
Go Micro is Apache 2.0 licensed.
2020-04-19 00:46:33 +01:00
2020-12-18 18:45:14 +00:00
## Upgrade
[Micro](https://github.com/micro/micro) v3 consolidates Go Micro into it as a single unified platform.
Please see the [upgrade guide](https://micro.mu/v2-to-v3-upgrade-guide).