日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

esxi时区设置 +8_Go语言MySQL时区问题

發(fā)布時(shí)間:2025/3/20 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 esxi时区设置 +8_Go语言MySQL时区问题 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

原文見(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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。