Categorygithub.com/weibocom/motan-go
modulepackage
1.2.0
Repository: https://github.com/weibocom/motan-go.git
Documentation: pkg.go.dev

# README

Motan-go

License Build Status codecov GoDoc Go Report Card

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

  1. 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"
  1. 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

  1. 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
  1. 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

  1. 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
  1. 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

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