本文目錄一覽:
- 1、golang 進程創建,fork,以及熱重啟(無縫升級)
- 2、請Golang深度用戶說說,現在Golang的性能可以和C比嗎
- 3、請教關於在golang中怎麼使用進程的問題
- 4、Golang 線程和協程的區別
- 5、golang多進程庫pagent
- 6、如何運行一個golang程序為守護進程
golang 進程創建,fork,以及熱重啟(無縫升級)
一般來說,進程的操作使用的是一些系統的命令,所以go內部使用os包,進行一些運行系統命令的操作
os 包及其子包 os/exec 提供了創建進程的方法。
一般的,應該優先使用 os/exec 包。因為 os/exec 包依賴 os 包中關鍵創建進程的 API,為了便於理解,我們先探討 os 包中和進程相關的部分。
Unix :fork創建一個進程,(及其一些變種,如 vfork、clone)。
Go:Linux 下創建進程使用的系統調用是 clone。
允許一進程(父進程)創建一新進程(子進程)。具體做法是,新的子進程幾近於對父進程的翻版:子進程獲得父進程的棧、數據段、堆和執行文本段的拷貝。可將此視為把父進程一分為二。
終止一進程,將進程佔用的所有資源(內存、文件描述符等)歸還內核,交其進行再次分配。參數 status 為一整型變量,表示進程的退出狀態。父進程可使用系統調用 wait() 來獲取該狀態。
目的有二:其一,如果子進程尚未調用 exit() 終止,那麼 wait 會掛起父進程直至子進程終止;其二,子進程的終止狀態通過 wait 的 status 參數返回。
加載一個新程序(路徑名為 pathname,參數列表為 argv,環境變量列表為 envp)到當前進程的內存。這將丟棄現存的程序文本段,並為新程序重新創建棧、數據段以及堆。通常將這一動作稱為執行一個新程序。
沒有直接提供 fork 系統調用的封裝,而是將 fork 和 execve 合二為一,提供了 syscall.ForkExec。如果想只調用 fork,得自己通過 syscall.Syscall(syscall.SYS_FORK, 0, 0, 0) 實現。
os.Process 存儲了通過 StartProcess 創建的進程的相關信息。
一般通過 StartProcess 創建 Process 的實例,函數聲明如下:
它使用提供的程序名、命令行參數、屬性開始一個新進程。StartProcess 是一個低級別的接口。os/exec 包提供了高級別的接口,一般應該盡量使用 os/exec 包。如果出錯,錯誤的類型會是 *PathError。
屬性定義如下:
FindProcess 可以通過 pid 查找一個運行中的進程。該函數返回的 Process 對象可以用於獲取關於底層操作系統進程的信息。在 Unix 系統中,此函數總是成功,即使 pid 對應的進程不存在。
Process 提供了四個方法:Kill、Signal、Wait 和 Release。其中 Kill 和 Signal 跟信號相關,而 Kill 實際上就是調用 Signal,發送了 SIGKILL 信號,強制進程退出,關於信號,後續章節會專門講解。
Release 方法用於釋放 Process 對象相關的資源,以便將來可以被再使用。該方法只有在確定沒有調用 Wait 時才需要調用。Unix 中,該方法的內部實現只是將 Process 的 pid 置為 -1。
通過 os 包可以做到運行外部命令,如前面的例子。不過,Go 標準庫為我們封裝了更好用的包: os/exec,運行外部命令,應該優先使用它,它包裝了 os.StartProcess 函數以便更容易的重定向標準輸入和輸出,使用管道連接 I/O,以及作其它的一些調整。
exec.LookPath 函數在 PATH 指定目錄中搜索可執行程序,如 file 中有 /,則只在當前目錄搜索。該函數返回完整路徑或相對於當前路徑的一個相對路徑。
func LookPath(file string) (string, error)
如果在 PATH 中沒有找到可執行文件,則返回 exec.ErrNotFound。
Cmd 結構代表一個正在準備或者在執行中的外部命令,調用了 Run、Output 或 CombinedOutput 後,Cmd 實例不能被重用。
一般的,應該通過 exec.Command 函數產生 Cmd 實例:
用法
得到 * Cmd 實例後,接下來一般有兩種寫法:
前面講到,通過 Cmd 實例後,有兩種方式運行命令。有時候,我們不只是簡單的運行命令,還希望能控制命令的輸入和輸出。通過上面的 API 介紹,控制輸入輸出有幾種方法:
參考資料:
請Golang深度用戶說說,現在Golang的性能可以和C比嗎
不可以,完全沒有可比性。
Golang的優勢是開發速度,C可以自由、精準的操控內存。
拿string類型舉個栗子:
1、修改字符串:
golang:需要分配新內存,然後進行內存copy。
c:可直接修改,可realloc。
2、存一段data:
golang:使用[]byte類型,[]byte轉成string需要進行內存拷貝(排除掉利用指針進行類型轉換的情況)。
c:直接用char[],可讀可寫。
golang中為了語言的安全性,類似的這種限制有很多,犧牲了一部分性能。但golang的優勢也是顯而易見的,goroutine、chan都很好用,而c則需要自己進行進程、線程的管控。
請教關於在golang中怎麼使用進程的問題
這個似乎不是那麼容易解答的,首先你要把數據從mongodb查出來,你要確保已經安裝了go語言的mongodb驅動。然後對查出來的數據進行解析,查出來的數據是類似json的數據,這個解析代碼需要相關的庫或者你自己寫的。然後再把數據相應的插入mysql里,這裡你也要安裝go語言的mysql驅動和odbc
Golang 線程和協程的區別
線程:
多線程是為了解決CPU利用率的問題,線程則是為了減少上下文切換時的開銷,進程和線程在Linux中沒有本質區別,最大的不同就是進程有自己獨立的內存空間,而線程是共享內存空間。
在進程切換時需要轉換內存地址空間,而線程切換沒有這個動作,所以線程切換比進程切換代價要小得多。
協程:
想要簡單,又要性能高,協程就可以達到我們的目的,它是用戶視角的一種抽象,操作系統並沒有這個概念,主要思想是在用戶態實現調度算法,用少量線程完成大量任務的調度。
Goroutine是GO語言實現的協程,其特點是在語言層面就支持,使用起來十分方便,它的核心是MPG調度模型:M即內核線程;P即處理器,用來執行Goroutine,它維護了本地可運行隊列;G即Goroutine,代碼和數據結構;S及調度器,維護M和P的信息。
golang多進程庫pagent
地址:
pagent是一個多進程模型的golang庫,具有以下特點:
簡單: 父子進程只通過stdin和stdout來交互
安全: 多進程很安全,子進程掛掉一個不影響其他子進程
解耦:子進程交互和業務分離
例子:
package main
import (
“fmt”
“time”
“github.com/adwpc/pagent”
)
type MyBiz struct {
pagent.Master
}
func NewBiz() *MyBiz {
return MyBiz{}
}
func (a *MyBiz) BizRunning(id, str string) error {
fmt.Println(“[MyBiz BizRunning] str=” + str)
return nil
}
func (a *MyBiz) BizFinish(id string, err error) error {
fmt.Println(“[MyBiz BizFinish] id=” + id)
return err
}
func main() {
a := NewBiz()
fmt.Println(“worker1————————-“)
a.GetWorker(“worker1”).Start(“bash”, a.BizRunning, a.BizFinish)
a.GetWorker(“worker1”).Input(“ls”)
time.Sleep(1 * time.Second)
a.DelWorker(“worker1”)
fmt.Println(“worker2————————-“)
a.GetWorker(“worker2”).Start(“ifconfig”, nil, a.BizFinish)
time.Sleep(1 * time.Second)
a.DelWorker(“worker2”)
fmt.Printf(“end!—————————-“)
}
如何運行一個golang程序為守護進程
您好,很高興為您解答。
安裝daemonize
安裝git環境
yum install git -y
獲取daemonize
git clone git://github.com/bmc/daemonize.git
安裝daemonize
cd daemonize
./configure
make make install
查看是否安裝
daemonize -v
通過daemonize執行golang守護進程
需要打包golang程序為可執行文件(go build),並通過daemonize來執行它來實現守護進程,如:
daemonize -p /var/run/myapp.pid -l /var/lock/subsys/myapp -u nobody /path/to/myapp
如若滿意,請點擊右側【採納答案】,如若還有問題,請點擊【追問】
希望我的回答對您有所幫助,望採納!
~ O(∩_∩)O~
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/259329.html