2017-01-01 21:39:05 +03:00
|
|
|
# HTTP Client
|
|
|
|
|
|
|
|
This plugin is a http client for go-micro.
|
|
|
|
|
2018-11-23 17:25:46 +03:00
|
|
|
## Overview
|
|
|
|
|
|
|
|
The http client wraps `net/http` to provide a robust go-micro client with service discovery, load balancing and streaming.
|
2017-01-01 21:43:29 +03:00
|
|
|
It complies with the [go-micro.Client](https://godoc.org/github.com/micro/go-micro/client#Client) interface.
|
2017-01-01 21:39:05 +03:00
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
### Use directly
|
|
|
|
|
|
|
|
```go
|
|
|
|
import "github.com/micro/go-plugins/client/http"
|
|
|
|
|
|
|
|
service := micro.NewService(
|
|
|
|
micro.Name("my.service"),
|
|
|
|
micro.Client(http.NewClient()),
|
|
|
|
)
|
|
|
|
```
|
|
|
|
|
|
|
|
### Use with flags
|
|
|
|
|
|
|
|
```go
|
|
|
|
import _ "github.com/micro/go-plugins/client/http"
|
|
|
|
```
|
|
|
|
|
|
|
|
```shell
|
|
|
|
go run main.go --client=http
|
|
|
|
```
|
|
|
|
|
|
|
|
### Call Service
|
|
|
|
|
|
|
|
Assuming you have a http service "my.service" with path "/foo/bar"
|
|
|
|
```go
|
|
|
|
// new client
|
|
|
|
client := http.NewClient()
|
|
|
|
|
|
|
|
// create request/response
|
2017-01-01 22:33:24 +03:00
|
|
|
request := client.NewRequest("my.service", "/foo/bar", protoRequest{})
|
2017-01-01 22:33:44 +03:00
|
|
|
response := new(protoResponse)
|
2017-01-01 21:39:05 +03:00
|
|
|
|
|
|
|
// call service
|
|
|
|
err := client.Call(context.TODO(), request, response)
|
|
|
|
```
|
2017-01-01 21:41:07 +03:00
|
|
|
|
2017-01-01 22:21:21 +03:00
|
|
|
Look at http_test.go for detailed use.
|
|
|
|
|
2017-01-01 22:20:53 +03:00
|
|
|
### Encoding
|
|
|
|
|
|
|
|
Default protobuf with content-type application/proto
|
|
|
|
```go
|
|
|
|
client.NewRequest("service", "/path", protoRequest{})
|
|
|
|
```
|
|
|
|
|
|
|
|
Json with content-type application/json
|
|
|
|
```go
|
|
|
|
client.NewJsonRequest("service", "/path", jsonRequest{})
|
|
|
|
```
|
|
|
|
|