# README
Motan-go
Overview
Motan is a cross-language remote procedure call(RPC) framework for rapid development of high performance distributed services.
This project is the golang Motan implementation. Provides golang motan server, motan client and motan agent. motan agent is designed to support bio-proxy for any other language such as PHP, Python by motan2 protocol.
Features
- Interactive with mulit language through motan2 protocol,such as Java, PHP.
- Provides cluster support and integrate with popular service discovery services like Consul or Zookeeper.
- Supports advanced scheduling features like weighted load-balance, scheduling cross IDCs, etc.
- Optimization for high load scenarios, provides high availability in production environment.
- Supports both synchronous and asynchronous calls.
Quick Start
Installation
go get -u -v github.com/weibocom/motan-go
The quick start gives very basic example of running client and server on the same machine. For the detailed information about using and developing Motan, please jump to Documents. the demo case is in the main/ directory
Motan server
- Create serverdemo.yaml to config service
#config of registries
motan-registry:
direct-registry: # registry id
protocol: direct # registry type
#conf of services
motan-service:
mytest-motan2:
path: com.weibo.motan.demo.service.MotanDemoService # e.g. service name for register
group: motan-demo-rpc
protocol: motan2
registry: direct-registry
serialization: simple
ref : "main.MotanDemoService"
export: "motan2:8100"
- Write an implementation, create and start RPC Server.
package main
import (
"fmt"
"time"
motan "github.com/weibocom/motan-go"
)
func main() {
runServerDemo()
}
func runServerDemo() {
mscontext := motan.GetMotanServerContext("serverdemo.yaml") //get config by filename
mscontext.RegisterService(&MotanDemoService{}, "") // registry implement
mscontext.Start(nil) // start server
time.Sleep(time.Second * 50000000)
}
// service implement
type MotanDemoService struct{}
func (m *MotanDemoService) Hello(name string) string {
fmt.Printf("MotanDemoService hello:%s\n", name)
return "hello " + name
}
Motan client
- Create clientdemo.yaml to config service for subscribe
#config of registries
motan-registry:
direct-registry: # registry id
protocol: direct # registry type.
host: 127.0.0.1
port: 9981
#conf of refers
motan-refer:
mytest-motan2:
path: com.weibo.motan.demo.service.MotanDemoService # e.g. service name for subscribe
group: motan-demo-rpc # group name
protocol: motan2 # rpc protocol
registry: direct-registry
requestTimeout: 1000
serialization: simple
haStrategy: failover
loadbalance: roundrobin
- Start call
package main
import (
"fmt"
motan "github.com/weibocom/motan-go"
motancore "github.com/weibocom/motan-go/core"
)
func main() {
runClientDemo()
}
func runClientDemo() {
mccontext := motan.GetClientContext("clientdemo.yaml")
mccontext.Start(nil)
mclient := mccontext.GetClient("mytest-motan2")
var reply string
err := mclient.Call("hello", []interface{}{"Ray"}, &reply) // sync call
if err != nil {
fmt.Printf("motan call fail! err:%v\n", err)
} else {
fmt.Printf("motan call success! reply:%s\n", reply)
}
// async call
result := mclient.Go("hello", []interface{}{"Ray"}, &reply, make(chan *motancore.AsyncResult, 1))
res := <-result.Done
if res.Error != nil {
fmt.Printf("motan async call fail! err:%v\n", res.Error)
} else {
fmt.Printf("motan async call success! reply:%+v\n", reply)
}
}
Use agent.
agent is not necessary for golang. it designed for interpreted languages such as PHP to support service governance
- Create clientdemo.yaml to config service for subscribe or register
#config fo agent
motan-agent:
port: 9981 # agent serve port.
mport: 8002 # agent manage port
#config of registries
motan-registry:
direct-registry: # registry id
protocol: direct # registry type. will get instance from extFactory.
host: 127.0.0.1 # direct server ip.
port: 8100 #direct server port
#conf of refers
motan-refer:
mytest-motan2:
path: com.weibo.motan.demo.service.MotanDemoService # e.g. service name for subscribe
group: motan-demo-rpc
protocol: motan2
registry: direct-registry
serialization: simple
- Start Agent
package main
import motan "github.com/weibocom/motan-go"
func main() {
runAgentDemo()
}
func runAgentDemo() {
agent := motan.NewAgent(nil)
agent.ConfigFile = "./agentdemo.yaml"
agent.StartMotanAgent()
}
Documents
Contributors
- Ray(@rayzhang0603)
- 周晶(@idevz)
- xiaohutuer(@xiaohutuer)
- Arthur Guo(@jealone)
- huzhongx(@huzhongx)
- dingzk(@dingzk)
- lion2luo(@lion2luo)
- Zha(@Zha-Zha)
- 李枨煊(@flyhope)
License
Motan is released under the Apache License 2.0.
# Packages
Package cluster contains Cluster implement and command process.
No description provided by the author
Package core is motan-go base package.
Package endpoint is transport implement of different protocol.
Package filter is some default filter implements.
Package ha is default HaStrategy implements.
No description provided by the author
Package lb is default LoadBalance implements.
Package vlog ********** this file is modified based on "gopkg.in/natefinch/lumberjack.v2" ********** Package lumberjack provides a rolling logger.
No description provided by the author
No description provided by the author
No description provided by the author
Package protocol is motan2 protocol codec implements.
Package provider is default Provider implements.
Package registry is default registry implements.
Package serialize is default serialization implements.
Package server is default Server implements for different protocol.
No description provided by the author
# Functions
No description provided by the author
Cmdline responds with the running program's command line, with arguments separated by NUL bytes.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
GetMotanServerContext start a motan server context by config a motan server context can listen multi ports and provide many services.
No description provided by the author
No description provided by the author
Handler returns an HTTP handler that serves the named profile.
Index responds with the pprof-formatted profile named by the request.
No description provided by the author
JSONError return Error JSON data.
JSONSuccess return success JSON data.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
Profile responds with the pprof-formatted cpu profile.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
Symbol looks up the program counters listed in the request, responding with a table mapping program counters to function names.
Trace responds with the execution trace in binary form.
# Constants
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
# Variables
PermissionCheck is default permission check for manage request.
# Structs
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
DebugHandler control pprof dynamically ***the func of pprof is copied from net/http/pprof ***.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
MSContext is Motan Server Context.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
StatusHandler can change http status, such as 200, 503 the registed services will not available when status is 503, and will available when status change to 200.
No description provided by the author
# Interfaces
No description provided by the author
SetAgent : if need agent to do sth, the handler can implement this interface, the func SetAgent will called when agent init the handler.
# Type aliases
No description provided by the author