Documentation ¶
Index ¶
- Constants
- Variables
- func NewHCM(mapService *PeerMapService, nt p2p.NetworkTransport) *healthCheckManager
- type HealthCheckManager
- type LiteContainerService
- func (lntc *LiteContainerService) AfterStart()
- func (lntc *LiteContainerService) BeforeStart()
- func (lntc *LiteContainerService) BeforeStop()
- func (lntc *LiteContainerService) CallRequest(actor string, msg interface{}, timeout time.Duration) (interface{}, error)
- func (lntc *LiteContainerService) CallRequestDefaultTimeout(actor string, msg interface{}) (interface{}, error)
- func (lntc *LiteContainerService) ChainID() *types.ChainID
- func (lntc *LiteContainerService) FutureRequest(actor string, msg interface{}, timeout time.Duration) *actor.Future
- func (lntc *LiteContainerService) FutureRequestDefaultTimeout(actor string, msg interface{}) *actor.Future
- func (lntc *LiteContainerService) GetNetworkTransport() p2p.NetworkTransport
- func (lntc *LiteContainerService) Receive(context actor.Context)
- func (lntc *LiteContainerService) SendRequest(actor string, msg interface{})
- func (lntc *LiteContainerService) Statistics() *map[string]interface{}
- func (lntc *LiteContainerService) TellRequest(actor string, msg interface{})
- type PeerHealth
- type PeerMapService
- func (pms *PeerMapService) AfterStart()
- func (pms *PeerMapService) BeforeStart()
- func (pms *PeerMapService) BeforeStop()
- func (pms *PeerMapService) Receive(context actor.Context)
- func (pms *PeerMapService) SendGoAwayMsg(message string, wt p2p.MsgWriter) error
- func (pms *PeerMapService) Statistics() *map[string]interface{}
- type PolarisConnectSvc
Constants ¶
const ( PolarisMapSub protocol.ID = "/polaris/0.1" PolarisPingSub protocol.ID = "/ping/0.1" )
subprotocol for polaris
const ( MapQuery p2p.SubProtocol = 0x0100 + iota MapResponse )
const ( PolarisConnectionTTL = time.Second * 30 PolarisPingTTL = PolarisConnectionTTL >> 1 // polaris will return peers list at most this number ResponseMaxPeerLimit = 500 // libp2p internal library is not always send message instantly, so closing socket soon after sent a message will cause packet loss and read error, us walkaround here till finding the real reason and fix it. MsgSendDelay = time.Second * 1 PeerHealthcheckInterval = time.Minute //PeerHealthcheckInterval = time.Minute * 5 ConcurrentHealthCheckCount = 20 )
internal
Variables ¶
var ( // 89.15 is floor of declination of Polaris MainnetMapServer = []string{ "/dns/polaris.aergo.io/tcp/8915/p2p/16Uiu2HAkvJTHFuJXxr15rFEHsJWnyn1QvGatW2E9ED9Mvy4HWjVF", } // 89.16 is ceiling of declination of Polaris TestnetMapServer = []string{ "/dns/polaris.aergo.io/tcp/8916/p2p/16Uiu2HAkvJTHFuJXxr15rFEHsJWnyn1QvGatW2E9ED9Mvy4HWjVF", } )
var (
EmptyMsgID = p2p.MsgID(uuid.Nil)
)
Functions ¶
func NewHCM ¶
func NewHCM(mapService *PeerMapService, nt p2p.NetworkTransport) *healthCheckManager
Types ¶
type HealthCheckManager ¶
type HealthCheckManager interface { Start() Stop() }
type LiteContainerService ¶
type LiteContainerService struct { *component.BaseComponent // contains filtered or unexported fields }
P2P is actor component for p2p
func NewNTContainer ¶
func NewNTContainer(cfg *config.Config) *LiteContainerService
NewP2P create a new ActorService for p2p
func (*LiteContainerService) AfterStart ¶
func (lntc *LiteContainerService) AfterStart()
func (*LiteContainerService) BeforeStart ¶
func (lntc *LiteContainerService) BeforeStart()
BeforeStart starts p2p service.
func (*LiteContainerService) BeforeStop ¶
func (lntc *LiteContainerService) BeforeStop()
BeforeStop is called before actor hub stops. it finishes underlying peer manager
func (*LiteContainerService) CallRequest ¶
func (lntc *LiteContainerService) CallRequest(actor string, msg interface{}, timeout time.Duration) (interface{}, error)
CallRequest implement interface method of ActorService
func (*LiteContainerService) CallRequestDefaultTimeout ¶
func (lntc *LiteContainerService) CallRequestDefaultTimeout(actor string, msg interface{}) (interface{}, error)
CallRequest implement interface method of ActorService
func (*LiteContainerService) ChainID ¶
func (lntc *LiteContainerService) ChainID() *types.ChainID
func (*LiteContainerService) FutureRequest ¶
func (lntc *LiteContainerService) FutureRequest(actor string, msg interface{}, timeout time.Duration) *actor.Future
FutureRequest implement interface method of ActorService
func (*LiteContainerService) FutureRequestDefaultTimeout ¶
func (lntc *LiteContainerService) FutureRequestDefaultTimeout(actor string, msg interface{}) *actor.Future
FutureRequestDefaultTimeout implement interface method of ActorService
func (*LiteContainerService) GetNetworkTransport ¶
func (lntc *LiteContainerService) GetNetworkTransport() p2p.NetworkTransport
func (*LiteContainerService) Receive ¶
func (lntc *LiteContainerService) Receive(context actor.Context)
Receive got actor message and then handle it.
func (*LiteContainerService) SendRequest ¶
func (lntc *LiteContainerService) SendRequest(actor string, msg interface{})
SendRequest implement interface method of ActorService
func (*LiteContainerService) Statistics ¶
func (lntc *LiteContainerService) Statistics() *map[string]interface{}
Statistics show statistic information of p2p module. NOTE: It it not implemented yet
func (*LiteContainerService) TellRequest ¶
func (lntc *LiteContainerService) TellRequest(actor string, msg interface{})
TellRequest implement interface method of ActorService
type PeerHealth ¶
type PeerHealth int
const ( PeerHealth_GOOD PeerHealth = 0 PeerHealth_MID PeerHealth = 1 PeerHealth_BAD PeerHealth = 2 )
PeersState
type PeerMapService ¶
type PeerMapService struct { *component.BaseComponent PrivateNet bool // contains filtered or unexported fields }
PeerMapService is
func NewPolarisService ¶
func NewPolarisService(cfg *config.Config, ntc p2p.NTContainer) *PeerMapService
func (*PeerMapService) AfterStart ¶
func (pms *PeerMapService) AfterStart()
func (*PeerMapService) BeforeStart ¶
func (pms *PeerMapService) BeforeStart()
func (*PeerMapService) BeforeStop ¶
func (pms *PeerMapService) BeforeStop()
func (*PeerMapService) Receive ¶
func (pms *PeerMapService) Receive(context actor.Context)
func (*PeerMapService) SendGoAwayMsg ¶
func (pms *PeerMapService) SendGoAwayMsg(message string, wt p2p.MsgWriter) error
send notice message and then disconnect. this routine should only run in RunPeer go routine
func (*PeerMapService) Statistics ¶
func (pms *PeerMapService) Statistics() *map[string]interface{}
type PolarisConnectSvc ¶
type PolarisConnectSvc struct { *component.BaseComponent PrivateChain bool // contains filtered or unexported fields }
PeerMapService is
func NewPolarisConnectSvc ¶
func NewPolarisConnectSvc(cfg *config.P2PConfig, ntc p2p.NTContainer) *PolarisConnectSvc
func (*PolarisConnectSvc) AfterStart ¶
func (pcs *PolarisConnectSvc) AfterStart()
func (*PolarisConnectSvc) BeforeStart ¶
func (pcs *PolarisConnectSvc) BeforeStart()
func (*PolarisConnectSvc) BeforeStop ¶
func (pcs *PolarisConnectSvc) BeforeStop()
func (*PolarisConnectSvc) Receive ¶
func (pcs *PolarisConnectSvc) Receive(context actor.Context)
func (*PolarisConnectSvc) Statistics ¶
func (pcs *PolarisConnectSvc) Statistics() *map[string]interface{}