esxi时区设置 +8_Go语言MySQL时区问题
原文見(jiàn):Go語(yǔ)言MySQL時(shí)區(qū)問(wèn)題 - Jiajun的編程隨想
最近由于我要統(tǒng)一技術(shù)棧,因此把原本使用SQLite做存儲(chǔ)的數(shù)據(jù)全部遷移到MySQL。博客也是。不過(guò)當(dāng)我檢查數(shù)據(jù)庫(kù)時(shí),發(fā)現(xiàn)時(shí)間和 我產(chǎn)生數(shù)據(jù)的時(shí)間相差8小時(shí)。
首先檢查機(jī)器的時(shí)間:
$ date Thu 14 Nov 2019 11:13:59 AM CST檢查MySQL的時(shí)間:
> select now(); +---------------------+ | now() | +---------------------+ | 2019-11-14 11:14:42 | +---------------------+ 1 row in set (0.000 sec)檢查Go的時(shí)間:
package mainimport ("fmt""time" )func main() {fmt.Printf("now: %sn", time.Now()) }執(zhí)行:
$ go run main.go now: 2019-11-14 11:16:44.277801507 +0800 CST m=+0.000070270檢查數(shù)據(jù)時(shí)間:
> select * from issue order by id desc limit 1; +-----+---------------------+---------------------+------------+------------+----------------------------------+ | id | created_at | updated_at | deleted_at | content | url | +-----+---------------------+---------------------+------------+------------+----------------------------------+ | 285 | 2019-11-14 01:54:53 | 2019-11-14 01:54:57 | NULL | htop詳解 | https://peteris.rocks/blog/htop/ | +-----+---------------------+---------------------+------------+------------+----------------------------------+ 1 row in set (0.000 sec)1點(diǎn)?這是不可能的。
綜合上面的檢查結(jié)果,我們知道:
- Go的程序輸出的時(shí)間沒(méi)有問(wèn)題
- 系統(tǒng)的時(shí)間也沒(méi)有問(wèn)題
- 數(shù)據(jù)庫(kù)的時(shí)間也沒(méi)有問(wèn)題
- 本地開(kāi)發(fā)機(jī)器的時(shí)間也沒(méi)有問(wèn)題
那么問(wèn)題會(huì)在哪里呢?我的經(jīng)驗(yàn)告訴我,可能是數(shù)據(jù)庫(kù)驅(qū)動(dòng)的鍋。檢查一下配置:
SQLX_URL="user:abcdefg@(localhost:3306)/blog?parseTime=true"發(fā)現(xiàn)我之前加了 parseTime=true,如果不加的話(huà),就無(wú)法讓驅(qū)動(dòng)把MySQL的 DATETIME 類(lèi)型和Go的 time.Time 互轉(zhuǎn)。于是查了一下 文檔,發(fā)現(xiàn)需要用loc來(lái)指定時(shí)區(qū)。我選擇和機(jī)器一致,因此改成下面即可:
SQLX_URL="user:abcdefg@(localhost:3306)/blog?parseTime=true&loc=Local"參考資料:
- https://github.com/go-sql-driver/mysql
更多文章
- 協(xié)程(coroutine)簡(jiǎn)介 - 什么是協(xié)程?
- goroutine 切換的時(shí)候發(fā)生了什么?
- Prometheus 數(shù)據(jù)類(lèi)型
- Gin源碼閱讀與分析
- 如何面試-作為面試官得到的經(jīng)驗(yàn)
- 自己寫(xiě)一個(gè)容器
- Golang(Go語(yǔ)言)中實(shí)現(xiàn)典型的fork調(diào)用
- 軟件開(kāi)發(fā)之禪---大事化小,各個(gè)擊破
- 程序員的自我修養(yǎng):鏈接,裝載與庫(kù) 閱讀筆記
- Redis源碼閱讀與分析三:哈希表
- Redis源碼閱讀與分析二:雙鏈表
- Redis源碼閱讀與分析一:sds
- Golang runtime 源碼閱讀與分析
- Golang的一些坑
- GC 垃圾回收
總結(jié)
以上是生活随笔為你收集整理的esxi时区设置 +8_Go语言MySQL时区问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: c打开指定路径文件_C++ 读取指定路径
- 下一篇: python windows窗口开发_W