mirror of
https://github.com/go-micro/go-micro.git
synced 2024-12-12 08:23:58 +02:00
148 lines
3.6 KiB
Markdown
148 lines
3.6 KiB
Markdown
# Plugins [![License](https://img.shields.io/:license-apache-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![GoDoc](https://godoc.org/github.com/asim/go-micro/plugins?status.svg)](https://godoc.org/github.com/asim/go-micro/plugins)
|
|
|
|
Go plugins is a place for community maintained plugins.
|
|
|
|
## Overview
|
|
|
|
Micro tooling is built on a powerful pluggable architecture. Plugins can be swapped out with zero code changes.
|
|
This repository contains plugins for all micro related tools. Read on for further info.
|
|
|
|
## Getting Started
|
|
|
|
* [Contents](#contents)
|
|
* [Usage](#usage)
|
|
* [Build Pattern](#build-pattern)
|
|
* [Contributions](#contributions)
|
|
|
|
## Contents
|
|
|
|
Contents of this repository:
|
|
|
|
| Directory | Description |
|
|
| --------- | ----------------------------------------------------------------|
|
|
| Broker | PubSub messaging; NATS, NSQ, RabbitMQ, Kafka |
|
|
| Client | RPC Clients; gRPC, HTTP |
|
|
| Codec | Message Encoding; BSON, Mercury |
|
|
| Micro | Micro Toolkit Plugins |
|
|
| Registry | Service Discovery; Etcd, Gossip, NATS |
|
|
| Selector | Load balancing; Label, Cache, Static |
|
|
| Server | RPC Servers; gRPC, HTTP |
|
|
| Transport | Bidirectional Streaming; NATS, RabbitMQ |
|
|
| Wrapper | Middleware; Circuit Breakers, Rate Limiting, Tracing, Monitoring|
|
|
|
|
## Usage
|
|
|
|
Plugins can be added to go-micro in the following ways. By doing so they'll be available to set via command line args or environment variables.
|
|
|
|
Import the plugins in a `plugins.go` file
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
_ "github.com/asim/go-micro/plugins/broker/rabbitmq/v3"
|
|
_ "github.com/asim/go-micro/plugins/registry/kubernetes/v3"
|
|
_ "github.com/asim/go-micro/plugins/transport/nats/v3"
|
|
)
|
|
```
|
|
|
|
Create your service and ensure you call `service.Init`
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
"github.com/asim/go-micro/v3"
|
|
)
|
|
|
|
func main() {
|
|
service := micro.NewService(
|
|
// Set service name
|
|
micro.Name("my.service"),
|
|
)
|
|
|
|
// Parse CLI flags
|
|
service.Init()
|
|
}
|
|
```
|
|
|
|
Build your service
|
|
|
|
```
|
|
go build -o service ./main.go ./plugins.go
|
|
```
|
|
|
|
### Env
|
|
|
|
Use environment variables to set the
|
|
|
|
```
|
|
MICRO_BROKER=rabbitmq \
|
|
MICRO_REGISTRY=kubernetes \
|
|
MICRO_TRANSPORT=nats \
|
|
./service
|
|
```
|
|
|
|
### Flags
|
|
|
|
Or use command line flags to enable them
|
|
|
|
```shell
|
|
./service --broker=rabbitmq --registry=kubernetes --transport=nats
|
|
```
|
|
|
|
### Options
|
|
|
|
Import and set as options when creating a new service
|
|
|
|
```go
|
|
import (
|
|
"github.com/asim/go-micro/v3"
|
|
"github.com/asim/go-micro/plugins/registry/kubernetes/v3"
|
|
)
|
|
|
|
func main() {
|
|
registry := kubernetes.NewRegistry() //a default to using env vars for master API
|
|
|
|
service := micro.NewService(
|
|
// Set service name
|
|
micro.Name("my.service"),
|
|
// Set service registry
|
|
micro.Registry(registry),
|
|
)
|
|
}
|
|
```
|
|
|
|
## Build
|
|
|
|
An anti-pattern is modifying the `main.go` file to include plugins. Best practice recommendation is to include
|
|
plugins in a separate file and rebuild with it included. This allows for automation of building plugins and
|
|
clean separation of concerns.
|
|
|
|
Create file plugins.go
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
_ "github.com/asim/go-micro/plugins/broker/rabbitmq/v3"
|
|
_ "github.com/asim/go-micro/plugins/registry/kubernetes/v3"
|
|
_ "github.com/asim/go-micro/plugins/transport/nats/v3"
|
|
)
|
|
```
|
|
|
|
Build with plugins.go
|
|
|
|
```shell
|
|
go build -o service main.go plugins.go
|
|
```
|
|
|
|
Run with plugins
|
|
|
|
```shell
|
|
MICRO_BROKER=rabbitmq \
|
|
MICRO_REGISTRY=kubernetes \
|
|
MICRO_TRANSPORT=nats \
|
|
service
|
|
```
|