From bcb8c32a794c38658fcb4240069d2246fa2aebc7 Mon Sep 17 00:00:00 2001 From: Meepoljdx <278914323@qq.com> Date: Mon, 27 Nov 2023 10:32:27 +0800 Subject: [PATCH 1/2] add time out param to ntp function --- nux/ntp.go | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/nux/ntp.go b/nux/ntp.go index 6de2023..e2b5cbf 100644 --- a/nux/ntp.go +++ b/nux/ntp.go @@ -64,7 +64,7 @@ func (m *msg) SetMode(md mode) { // Time returns the "receive time" from the remote NTP server // specifed as host. NTP client mode is used. -func getTwoTime(host string, version byte) (time.Time, time.Time, error) { +func getTwoTime(host string, version byte, timeout int64) (time.Time, time.Time, error) { if version < 2 || version > 4 { panic("ntp: invalid version number") } @@ -79,7 +79,7 @@ func getTwoTime(host string, version byte) (time.Time, time.Time, error) { return time.Now(), time.Now(), err } defer con.Close() - con.SetDeadline(time.Now().Add(5 * time.Second)) + con.SetDeadline(time.Now().Add(time.Duration(timeout) * time.Second)) m := new(msg) m.SetMode(client) @@ -100,7 +100,7 @@ func getTwoTime(host string, version byte) (time.Time, time.Time, error) { return t, transmitTime, nil } -func getTime(host string, version byte) (time.Time, error) { +func getTime(host string, version byte, timeout int64) (time.Time, error) { if version < 2 || version > 4 { panic("ntp: invalid version number") } @@ -115,8 +115,7 @@ func getTime(host string, version byte) (time.Time, error) { return time.Now(), err } defer con.Close() - con.SetDeadline(time.Now().Add(5 * time.Second)) - + con.SetDeadline(time.Now().Add(time.Duration(timeout) * time.Second)) m := new(msg) m.SetMode(client) m.SetVersion(version) @@ -138,18 +137,18 @@ func getTime(host string, version byte) (time.Time, error) { // TimeV returns the "receive time" from the remote NTP server // specifed as host. Use the NTP client mode with the requested // version number (2, 3, or 4). -func NtpTimeV(host string, version byte) (time.Time, error) { - return getTime(host, version) +func NtpTimeV(host string, version byte, timeout int64) (time.Time, error) { + return getTime(host, version, timeout) } // Time returns the "receive time" from the remote NTP server // specifed as host. NTP client mode version 4 is used. -func NtpTime(host string) (time.Time, error) { - return getTime(host, 4) +func NtpTime(host string, timeout int64) (time.Time, error) { + return getTime(host, 4, timeout) } // Time returns the "receive time" from the remote NTP server // specifed as host. NTP client mode version 4 is used. -func NtpTwoTime(host string) (time.Time, time.Time, error) { - return getTwoTime(host, 4) +func NtpTwoTime(host string, timeout int64) (time.Time, time.Time, error) { + return getTwoTime(host, 4, timeout) } From 5bfc859874420891a1c79da8fb614037ecf62916 Mon Sep 17 00:00:00 2001 From: Meepoljdx <278914323@qq.com> Date: Tue, 28 Nov 2023 09:47:43 +0800 Subject: [PATCH 2/2] change timeout param to ...int64 --- nux/ntp.go | 21 +++++++++++++++------ nux/ntp_test.go | 24 ++++++++++++++++++++++++ 2 files changed, 39 insertions(+), 6 deletions(-) create mode 100644 nux/ntp_test.go diff --git a/nux/ntp.go b/nux/ntp.go index e2b5cbf..cc63e0e 100644 --- a/nux/ntp.go +++ b/nux/ntp.go @@ -134,21 +134,30 @@ func getTime(host string, version byte, timeout int64) (time.Time, error) { return t, nil } +func getTimeout(timeout []int64) int64 { + // If the timeout parameter is not provided or the timeout parameter is greater than 0 + if len(timeout) != 1 { + return 5 + } else { + return timeout[0] + } +} + // TimeV returns the "receive time" from the remote NTP server // specifed as host. Use the NTP client mode with the requested // version number (2, 3, or 4). -func NtpTimeV(host string, version byte, timeout int64) (time.Time, error) { - return getTime(host, version, timeout) +func NtpTimeV(host string, version byte, timeout ...int64) (time.Time, error) { + return getTime(host, version, getTimeout(timeout)) } // Time returns the "receive time" from the remote NTP server // specifed as host. NTP client mode version 4 is used. -func NtpTime(host string, timeout int64) (time.Time, error) { - return getTime(host, 4, timeout) +func NtpTime(host string, timeout ...int64) (time.Time, error) { + return getTime(host, 4, getTimeout(timeout)) } // Time returns the "receive time" from the remote NTP server // specifed as host. NTP client mode version 4 is used. -func NtpTwoTime(host string, timeout int64) (time.Time, time.Time, error) { - return getTwoTime(host, 4, timeout) +func NtpTwoTime(host string, timeout ...int64) (time.Time, time.Time, error) { + return getTwoTime(host, 4, getTimeout(timeout)) } diff --git a/nux/ntp_test.go b/nux/ntp_test.go new file mode 100644 index 0000000..a137a13 --- /dev/null +++ b/nux/ntp_test.go @@ -0,0 +1,24 @@ +package nux + +import ( + "log" + "testing" + "time" +) + +func TestNtpTime(t *testing.T) { + orgTime := time.Now() + log.Println("Begin") + serverReciveTime, serverTransmitTime, err := NtpTwoTime("ntp1.aliyun.com", 20) + if err != nil { + log.Println(err) + return + } + dstTime := time.Now() + + // https://en.wikipedia.org/wiki/Network_Time_Protocol + duration := ((serverReciveTime.UnixNano() - orgTime.UnixNano()) + (serverTransmitTime.UnixNano() - dstTime.UnixNano())) / 2 + + delta := duration / 1e6 // convert to ms + log.Println(delta) +}