本文目錄一覽:
深入理解golang
最近三年,在工作中使用go開發了不少服務。深感go的便捷,以及它的runtime的複雜。我覺得需要定期的進行總結,因此決定寫這篇文章,也許更準確的,應該叫筆記。
最近終於解決了一個和cgo有關的問題。這個問題從發現到解決前後經歷了接近4個月,當然,和人手不足也有關係。而對於我個人而言,這個問題其實歷時2年!這得從頭說起。
在上一家公司的一個項目里,有一個服務做音視頻數據的提取,這個服務運行在嵌入式設備TX2上。音視頻提取這一關鍵功能主要利用nvidia基於gstreamer開發的插件,這個插件可以發揮nvidia gpu的硬件解碼功能。當時這個服務使用go和c混編的方式,問題的癥狀是服務運行一段時間後,不輸出音視頻數據。遺憾的是,由於疫情,項目停止,因此沒有機會繼續研究這個問題。
時間來到去年底。當前這個項目進行壓力測試,發現關鍵的語音處理服務運行一段時間後,會出現不拉流的情況,因此也沒有後續的結果輸出。癥狀和上一個項目非常像。雖然使用的第三方SDK不一樣,但同樣用了go和c混編的方式。一開始,焦點就放在go的運行時上,覺得可能是go和c相互調用的方式不對。經過合理猜測,並用測試進行驗證後,發現問題還是在第三方拉流的SDK上,它們的回調函數必須要快,否則有可能會阻塞它們的回調線程。當然,在go調用c的時候,如果耗時比較長,會對go的運行時造成一些副作用;在c回調go的時候,go的運行時也有可能阻塞c的回調線程。但go的運行時已經比較成熟,因此我覺得它對這個問題的貢獻不大。以上採用了假設-驗證的方法,主要的原因還是第三方的拉流SDK不開源。在定位問題的過程中,使用了gdb的gcore來生成堆棧;也搭建了灰度環境來進行壓力測試,以及完善監控,這些都是解決方法的一部分。
正是這一問題,促使我更多的了解go的運行時。而我看得越多,越覺得go的運行時是一個龐大的怪物。因此,抱着能了解一點是一點的心態,不斷的完善這篇筆記。
golang如何讀寫音頻文件
12345678910111213141516171819202122232425262728session := engine.NewSession()defer session.Close()// add Begin() before any actionerr := session.Begin()user1 := Userinfo{Username: “xiaoxiao”, Departname: “dev”, Alias: “lunny”, Created: time.Now()}_, err = session.Insert(user1)if err != nil { session.Rollback() return}user2 := Userinfo{Username: “yyy”}_, err = session.Where(“id = ?”, 2).Update(user2)if err != nil { session.Rollback() return} _, err = session.Exec(“delete from userinfo where username = ?”, user2.Username)if err != nil { session.Rollback() return} // add Commit() after all actionserr = session.Commit()if err != nil { return}
golang聲音播放的初探
公司需要實現一個定期抓取分銷系統數據並以聲音播放的方式通知的pc端程序,本人對golang非常感興趣,於是打算用golang來實現。
1、golang語言非常簡單高效。
2、有問題,大家可以百度,谷歌,到 社區 提問。
3、如果您想支持作者,可以到 B站 上,給作者點個贊,關注作者。
原創文章,作者:UYMML,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/325214.html