%% agency 管理进程的名称
|
|
-define(agAgencyPoolMgr, agAgencyPoolMgr).
|
|
|
|
%% beam cache 模块名
|
|
-define(agBeamPool, agBeamPool).
|
|
-define(agBeamAgency, agBeamAgency).
|
|
|
|
-define(AgCUndef, 0). %% Wait One Chunk start
|
|
-define(AgCHeader, 1). %% Wait One Chunk header
|
|
-define(AgCBody, 2). %% Wait One Chunk Body
|
|
-define(AgCDone, 3). %% Wait One Chunk Receive Over
|
|
-define(AgMDone, 4). %% Wait One Message Over
|
|
-define(AgCBodyStart, 5). %% Ret Start Wait One Chunk Body
|
|
-define(AgCBodyGoOn, 6). %% Ret Go On Wait One Chunk Body
|
|
|
|
%% IMY-todo 考虑多个消息回复的的时候 如果有消息 此时进程自动可能不存在 需要重新订阅获取
|
|
%% pidFrom pid() to reply; undefiend discard; waitSend 起送定时器等待requester来获取 过期就删除
|
|
-record(msgIdCache, {pidFrom, timerRef, chunkCnt, msgBuffer}).
|
|
|
|
-define(AgMBIdx, 4).
|
|
-define(AgCCIdx, 3).
|
|
|
|
%% 默认选项定义
|
|
-define(AgDefBaseUrl, <<"http://127.0.0.1:8529">>).
|
|
-define(AgDefDbName, <<"_system">>).
|
|
-define(AgDefUser, <<"root">>).
|
|
-define(AgDefPassWord, <<"156736">>).
|
|
-define(AgDefBacklogSize, 1024).
|
|
-define(AgDefConnTimeout, 5000).
|
|
-define(AgDefPoolSize, 16).
|
|
-define(AgDefIsReConn, true).
|
|
-define(AgDefReConnMin, 500).
|
|
-define(AgDefReConnMax, 120000).
|
|
-define(AgDefTimeout, infinity).
|
|
-define(AgDefPid, self()).
|
|
-define(AgDefSocketOpts, [binary, {active, true}, {nodelay, true}, {delay_send, true}, {keepalive, true}, {recbuf, 1048576}, {send_timeout, 5000}, {send_timeout_close, true}]).
|
|
|
|
-define(AgGetListKV(Key, List), agMiscUtils:getListValue(Key, List, undefined)).
|
|
-define(AgGetListKV(Key, List, Default), agMiscUtils:getListValue(Key, List, Default)).
|
|
-define(AgWarn(Tag, Format, Data), agMiscUtils:warnMsg(Tag, Format, Data)).
|
|
|
|
-define(AgMDoNetConn, mDoNetConn).
|
|
|
|
-record(agReq, {
|
|
method :: method()
|
|
, path :: path()
|
|
, queryPars :: queryPars()
|
|
, headers :: headers()
|
|
, body :: body()
|
|
, messageId :: pos_integer()
|
|
, fromPid :: pid()
|
|
, overTime = infinity :: timeout()
|
|
, isSystem = false :: boolean()
|
|
}).
|
|
|
|
-record(agReqRet, {
|
|
messageId :: messageId(),
|
|
reply :: term()
|
|
}).
|
|
|
|
-record(reConnState, {
|
|
min :: non_neg_integer(),
|
|
max :: non_neg_integer() | infinity,
|
|
current :: non_neg_integer() | undefined
|
|
}).
|
|
|
|
-record(srvState, {
|
|
poolName :: poolName(),
|
|
serverName :: serverName(),
|
|
userPassWord :: binary(),
|
|
host :: binary(),
|
|
dbName :: binary(),
|
|
reconnectState :: undefined | reconnectState(),
|
|
socket :: undefined | ssl:sslsocket(),
|
|
timerRef :: undefined | reference()
|
|
}).
|
|
|
|
-record(cliState, {
|
|
revStatus = ?AgCUndef :: pos_integer(),
|
|
backlogNum = 0 :: integer(),
|
|
backlogSize = 0 :: integer(),
|
|
messageId = 0 :: pos_integer(),
|
|
chunkIdx = 0 :: pos_integer(),
|
|
chunkSize = 0 :: pos_integer(),
|
|
chunkBuffer = <<>> :: binary()
|
|
}).
|
|
|
|
-record(dbOpts, {
|
|
host :: host(),
|
|
port :: 0..65535,
|
|
hostname :: hostName(),
|
|
dbName :: binary(),
|
|
protocol :: protocol(),
|
|
poolSize :: poolSize(),
|
|
userPassword :: binary(),
|
|
socketOpts :: socketOpts()
|
|
}).
|
|
|
|
-record(agencyOpts, {
|
|
reconnect :: boolean(),
|
|
backlogSize :: backlogSize(),
|
|
reconnectTimeMin :: pos_integer(),
|
|
reconnectTimeMax :: pos_integer()
|
|
}).
|
|
|
|
-type miRequest() :: #agReq{}.
|
|
-type miRequestRet() :: #agReqRet{}.
|
|
-type srvState() :: #srvState{}.
|
|
-type cliState() :: #cliState{}.
|
|
-type reconnectState() :: #reConnState{}.
|
|
|
|
-type poolName() :: atom().
|
|
-type poolNameOrSocket() :: atom() | socket().
|
|
-type serverName() :: atom().
|
|
-type protocol() :: ssl | tcp.
|
|
-type method() :: binary().
|
|
-type queryPars() :: map().
|
|
-type headers() :: map().
|
|
-type body() :: iodata() | undefined.
|
|
-type path() :: binary().
|
|
-type host() :: binary().
|
|
-type hostName() :: string().
|
|
-type poolSize() :: pos_integer().
|
|
-type backlogSize() :: pos_integer() | infinity.
|
|
-type messageId() :: pos_integer().
|
|
-type socket() :: inet:socket() | ssl:sslsocket().
|
|
-type socketOpts() :: [gen_tcp:connect_option() | ssl:tls_client_option()].
|
|
-type error() :: {error, term()}.
|
|
|
|
-type dbCfg() ::
|
|
{baseUrl, binary()} |
|
|
{dbName, binary()} |
|
|
{user, binary()} |
|
|
{password, binary()} |
|
|
{poolSize, poolSize()} |
|
|
{socketOpts, socketOpts()}.
|
|
|
|
-type agencyCfg() ::
|
|
{reconnect, boolean()} |
|
|
{backlogSize, backlogSize()} |
|
|
{reconnectTimeMin, pos_integer()} |
|
|
{reconnectTimeMax, pos_integer()}.
|
|
|
|
-type dbCfgs() :: [dbCfg()].
|
|
-type dbOpts() :: #dbOpts{}.
|
|
-type agencyCfgs() :: [agencyCfg()].
|
|
-type agencyOpts() :: #agencyOpts{}.
|
|
|
|
%% http header 头
|
|
%% -type header() ::
|
|
%% 'Cache-Control' |
|
|
%% 'Connection' |
|
|
%% 'Date' |
|
|
%% 'Pragma'|
|
|
%% 'Transfer-Encoding' |
|
|
%% 'Upgrade' |
|
|
%% 'Via' |
|
|
%% 'Accept' |
|
|
%% 'Accept-Charset'|
|
|
%% 'Accept-Encoding' |
|
|
%% 'Accept-Language' |
|
|
%% 'Authorization' |
|
|
%% 'From' |
|
|
%% 'Host' |
|
|
%% 'If-Modified-Since' |
|
|
%% 'If-Match' |
|
|
%% 'If-None-Match' |
|
|
%% 'If-Range'|
|
|
%% 'If-Unmodified-Since' |
|
|
%% 'Max-Forwards' |
|
|
%% 'Proxy-Authorization' |
|
|
%% 'Range'|
|
|
%% 'Referer' |
|
|
%% 'User-Agent' |
|
|
%% 'Age' |
|
|
%% 'Location' |
|
|
%% 'Proxy-Authenticate'|
|
|
%% 'Public' |
|
|
%% 'Retry-After' |
|
|
%% 'Server' |
|
|
%% 'Vary' |
|
|
%% 'Warning'|
|
|
%% 'Www-Authenticate' |
|
|
%% 'Allow' |
|
|
%% 'Content-Base' |
|
|
%% 'Content-Encoding'|
|
|
%% 'Content-Language' |
|
|
%% 'Content-Length' |
|
|
%% 'Content-Location'|
|
|
%% 'Content-Md5' |
|
|
%% 'Content-Range' |
|
|
%% 'Content-Type' |
|
|
%% 'Etag'|
|
|
%% 'Expires' |
|
|
%% 'Last-Modified' |
|
|
%% 'Accept-Ranges' |
|
|
%% 'Set-Cookie'|
|
|
%% 'Set-Cookie2' |
|
|
%% 'X-Forwarded-For' |
|
|
%% 'Cookie' |
|
|
%% 'Keep-Alive' |
|
|
%% 'Proxy-Connection' |
|
|
%% binary() |
|
|
%% string().
|
|
|