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
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
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
Quick Start
Installation
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
Motan client
Use agent.
agent is not necessary for golang. it designed for interpreted languages such as PHP to support service governance
Documents
Contributors
License
Motan is released under the Apache License 2.0.