%% 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(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(miRequest, { method :: method() , path :: path() , queryPars :: queryPars() , headers :: headers() , body :: body() , messageId :: pos_integer() , fromPid :: pid() , overTime = infinity :: timeout() , isSystem = false :: boolean() }). -record(miRequestRet, { 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(), buffer = <<>> :: 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() :: #miRequest{}. -type miRequestRet() :: #miRequestRet{}. -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().