module

package
v1.4.18 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 1, 2022 License: Apache-2.0 Imports: 8 Imported by: 0

Documentation

Overview

Package module 模块定义

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type App

type App interface {
	UpdateOptions(opts ...Option) error
	Run(mods ...Module) error
	SetMapRoute(fn func(app App, route string) string) error
	Configure(settings conf.Config) error
	OnInit(settings conf.Config) error
	OnDestroy() error
	Options() Options
	Transport() *nats.Conn
	Registry() registry.Registry
	GetServerByID(id string) (ServerSession, error)
	/**
	filter		 调用者服务类型    moduleType|moduleType@moduleID
	Type	   	想要调用的服务类型
	*/
	GetRouteServer(filter string, opts ...selector.SelectOption) (ServerSession, error) //获取经过筛选过的服务
	GetServersByType(Type string) []ServerSession
	GetSettings() conf.Config //获取配置信息

	Invoke(module RPCModule, moduleType string, _func string, params ...interface{}) (interface{}, error)
	InvokeNR(module RPCModule, moduleType string, _func string, params ...interface{}) error
	Call(ctx context.Context, moduleType, _func string, param mqrpc.ParamOption, opts ...selector.SelectOption) (interface{}, error)

	/**
	添加一个 自定义参数序列化接口
	gate,system 关键词一被占用请使用其他名称
	*/
	AddRPCSerialize(name string, Interface RPCSerialize) error

	GetRPCSerialize() map[string]RPCSerialize

	GetModuleInited() func(app App, module Module)

	OnConfigurationLoaded(func(app App)) error
	OnModuleInited(func(app App, module Module)) error
	OnStartup(func(app App)) error

	SetProtocolMarshal(protocolMarshal func(trace string, result interface{}, err error) (ProtocolMarshal, error)) error
	/**
	与客户端通信的协议包接口
	*/
	ProtocolMarshal(trace string, result interface{}, err error) (ProtocolMarshal, error)
	NewProtocolMarshal(data []byte) ProtocolMarshal
	GetProcessID() string
	WorkDir() string
}

App mqant应用定义

type ClientRPCHandler

type ClientRPCHandler func(app App, server registry.Node, rpcinfo *rpcpb.RPCInfo, result interface{}, err error, exec_time int64)

ClientRPCHandler 调用方RPC监控

type FileNameHandler

type FileNameHandler func(logdir, prefix, processID, suffix string) string

type Module

type Module interface {
	Version() string                             //模块版本
	GetType() string                             //模块类型
	OnAppConfigurationLoaded(app App)            //当App初始化时调用,这个接口不管这个模块是否在这个进程运行都会调用
	OnConfChanged(settings *conf.ModuleSettings) //为以后动态服务发现做准备
	OnInit(app App, settings *conf.ModuleSettings)
	OnDestroy()
	GetApp() App
	Run(closeSig chan bool)
}

Module 基本模块定义

type Option

type Option func(*Options)

Option 配置项

func Configure

func Configure(v string) Option

Configure 配置路径

func Debug

func Debug(t bool) Option

Debug 只有是在调试模式下才会在控制台打印日志, 非调试模式下只在日志文件中输出日志

func KillWaitTTL

func KillWaitTTL(t time.Duration) Option

KillWaitTTL specifies the interval on which to re-register

func LogDir

func LogDir(v string) Option

LogDir 日志存储路径

func Nats

func Nats(nc *nats.Conn) Option

Nats nats配置

func Parse

func Parse(t bool) Option

Parse mqant框架是否解析环境参数

func ProcessID

func ProcessID(v string) Option

ProcessID 进程分组ID

func RPCExpired

func RPCExpired(t time.Duration) Option

RPC超时时间

func RPCMaxCoroutine

func RPCMaxCoroutine(t int) Option

单个节点RPC同时并发协程数

func RegisterInterval

func RegisterInterval(t time.Duration) Option

RegisterInterval specifies the interval on which to re-register

func RegisterTTL

func RegisterTTL(t time.Duration) Option

RegisterTTL specifies the TTL to use when registering the service

func Registry

func Registry(r registry.Registry) Option

Registry sets the registry for the service and the underlying components

func Selector

func Selector(r selector.Selector) Option

Selector 路由选择器

func SetClientRPChandler

func SetClientRPChandler(t ClientRPCHandler) Option

SetClientRPChandler 配置调用者监控器

func SetRpcCompleteHandler

func SetRpcCompleteHandler(t RpcCompleteHandler) Option

SetServerRPCCompleteHandler 服务RPC执行结果监控器

func SetServerRPCHandler

func SetServerRPCHandler(t ServerRPCHandler) Option

SetServerRPCHandler 配置服务方监控器

func Version

func Version(v string) Option

Version 应用版本

func WithLogFile

func WithLogFile(name FileNameHandler) Option

WithLogFile 日志文件名称

func WorkDir

func WorkDir(v string) Option

WorkDir 进程工作目录

type Options

type Options struct {
	Nats        *nats.Conn
	Version     string
	Debug       bool
	Parse       bool //是否由框架解析启动环境变量,默认为true
	WorkDir     string
	ConfPath    string
	LogDir      string
	ProcessID   string
	KillWaitTTL time.Duration
	Registry    registry.Registry
	Selector    selector.Selector
	// Register loop interval
	RegisterInterval   time.Duration
	RegisterTTL        time.Duration
	ClientRPChandler   ClientRPCHandler
	ServerRPCHandler   ServerRPCHandler
	RpcCompleteHandler RpcCompleteHandler
	RPCExpired         time.Duration
	RPCMaxCoroutine    int
	// 自定义日志文件名字
	// 主要作用方便k8s映射日志不会被冲突,建议使用k8s pod实现
	LogFileName FileNameHandler
}

Options 应用级别配置项

type ProtocolMarshal

type ProtocolMarshal interface {
	GetData() []byte
}

ProtocolMarshal 数据包装

type RPCModule

type RPCModule interface {
	context.Context
	Module
	GetServerID() string //模块类型
	Invoke(moduleType string, _func string, params ...interface{}) (interface{}, error)
	InvokeNR(moduleType string, _func string, params ...interface{}) error
	InvokeArgs(moduleType string, _func string, ArgsType []string, args [][]byte) (interface{}, error)
	InvokeNRArgs(moduleType string, _func string, ArgsType []string, args [][]byte) error

	//	Call 通用RPC调度函数
	//	ctx 		context.Context 			上下文,可以设置这次请求的超时时间
	//	moduleType	string 						服务名称
	//	_func		string						需要调度的服务方法
	//	param 		mqrpc.ParamOption			方法传参
	//	opts ...selector.SelectOption			服务发现模块过滤,可以用来选择调用哪个服务节点
	Call(ctx context.Context, moduleType, _func string, param mqrpc.ParamOption, opts ...selector.SelectOption) (interface{}, error)
	GetModuleSettings() (settings *conf.ModuleSettings)
	/**
	filter		 调用者服务类型    moduleType|moduleType@moduleID
	Type	   	想要调用的服务类型
	*/
	GetRouteServer(filter string, opts ...selector.SelectOption) (ServerSession, error)
	GetExecuting() int64
}

RPCModule RPC模块定义

type RPCSerialize

type RPCSerialize interface {
	/**
	序列化 结构体-->[]byte
	param 需要序列化的参数值
	@return ptype 当能够序列化这个值,并且正确解析为[]byte时 返回改值正确的类型,否则返回 ""即可
	@return p 解析成功得到的数据, 如果无法解析该类型,或者解析失败 返回nil即可
	@return err 无法解析该类型,或者解析失败 返回错误信息
	*/
	Serialize(param interface{}) (ptype string, p []byte, err error)
	/**
	反序列化 []byte-->结构体
	ptype 参数类型 与Serialize函数中ptype 对应
	b   参数的字节流
	@return param 解析成功得到的数据结构
	@return err 无法解析该类型,或者解析失败 返回错误信息
	*/
	Deserialize(ptype string, b []byte) (param interface{}, err error)
	/**
	返回这个接口能够处理的所有类型
	*/
	GetTypes() []string
}

RPCSerialize 自定义参数序列化接口

type RpcCompleteHandler

type RpcCompleteHandler func(app App, module Module, callInfo *mqrpc.CallInfo, input []interface{}, out []interface{}, execTime time.Duration)

ServerRPCHandler 服务方RPC监控

type ServerRPCHandler

type ServerRPCHandler func(app App, module Module, callInfo *mqrpc.CallInfo)

ServerRPCHandler 服务方RPC监控

type ServerSession

type ServerSession interface {
	GetID() string
	GetName() string
	GetRPC() mqrpc.RPCClient
	GetApp() App
	GetNode() *registry.Node
	SetNode(node *registry.Node) (err error)
	Call(ctx context.Context, _func string, params ...interface{}) (interface{}, error)
	CallNR(_func string, params ...interface{}) (err error)
	CallArgs(ctx context.Context, _func string, ArgsType []string, args [][]byte) (interface{}, error)
	CallNRArgs(_func string, ArgsType []string, args [][]byte) (err error)
}

ServerSession 服务代理

Directories

Path Synopsis
Package basemodule BaseModule定义
Package basemodule BaseModule定义
* 一定要记得在confin.json配置这个模块的参数,否则无法使用
* 一定要记得在confin.json配置这个模块的参数,否则无法使用

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL