Documentation ¶
Index ¶
Constants ¶
View Source
const ( // DefaultMaxAllowedFailures defines how many failures will be tolerated. DefaultMaxAllowedFailures = 1 // FastNTPSyncPeriod period between ntp synchronizations before the first // successful connection. FastNTPSyncPeriod = 2 * time.Minute // SlowNTPSyncPeriod period between ntp synchronizations after the first // successful connection. SlowNTPSyncPeriod = 1 * time.Hour // DefaultRPCTimeout defines write deadline for single ntp server request. DefaultRPCTimeout = 2 * time.Second )
Variables ¶
View Source
var DefaultServers = []string{
"0.pool.ntp.org",
"1.pool.ntp.org",
"2.pool.ntp.org",
"3.pool.ntp.org",
}
DefaultServers will be resolved to the closest available, and with high probability resolved to the different IPs
Functions ¶
This section is empty.
Types ¶
type NTPTimeSource ¶
type NTPTimeSource struct {
// contains filtered or unexported fields
}
NTPTimeSource provides source of time that tries to be resistant to time skews. It does so by periodically querying time offset from ntp servers.
func NewNTPTimesource ¶
func NewNTPTimesource(ntpServers []string, log *zap.Logger) *NTPTimeSource
func (*NTPTimeSource) Now ¶
func (s *NTPTimeSource) Now() time.Time
Now returns time adjusted by latest known offset
func (*NTPTimeSource) Start ¶
func (s *NTPTimeSource) Start(ctx context.Context) error
Start runs a goroutine that updates local offset every updatePeriod.
func (*NTPTimeSource) Stop ¶
func (s *NTPTimeSource) Stop()
Stop goroutine that updates time source.
type Timesource ¶
type WallClockTimeSource ¶
type WallClockTimeSource struct { }
func NewDefaultClock ¶
func NewDefaultClock() *WallClockTimeSource
func (*WallClockTimeSource) Now ¶
func (t *WallClockTimeSource) Now() time.Time
func (*WallClockTimeSource) Stop ¶
func (t *WallClockTimeSource) Stop()
Click to show internal directories.
Click to hide internal directories.