• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2018年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 217588
            • 排名 - 118

            最新評論

            閱讀排行榜

            golang os/exec 執行外部命令

            exec包執行外部命令,它將os.StartProcess進行包裝使得它更容易映射到stdin和stdout,并且利用pipe連接i/o.

            func LookPath(file string) (string, error) //LookPath在環境變量中查找科執行二進制文件,如果file中包含一個斜杠,則直接根據絕對路徑或者相對本目錄的相對路徑去查找

            [html] view plain copy
            1. func main() {  
            2.     f, err := exec.LookPath("ls")  
            3.     if err != nil {  
            4.         fmt.Println(err)  
            5.     }  
            6.     fmt.Println(f) //  /bin/ls  
            7. }  


            type Cmd   //表示一個正在準備或者正在運行的外部命令

            [html] view plain copy
            1. type Cmd struct {  
            2.     Path         string   //運行命令的路徑,絕對路徑或者相對路徑  
            3.     Args         []string   // 命令參數  
            4.     Env          []string         //進程環境,如果環境為空,則使用當前進程的環境  
            5.     Dir          string   //指定command的工作目錄,如果dir為空,則comman在調用進程所在當前目錄中運行  
            6.     Stdin        io.Reader  //標準輸入,如果stdin是nil的話,進程從null device中讀取(os.DevNull),stdin也可以時一個文件,否則的話則在運行過程中再開一個goroutine去  
            7.              //讀取標準輸入  
            8.     Stdout       io.Writer       //標準輸出  
            9.     Stderr       io.Writer  //錯誤輸出,如果這兩個(Stdout和Stderr)為空的話,則command運行時將響應的文件描述符連接到os.DevNull  
            10.     ExtraFiles   []*os.File     
            11.     SysProcAttr  *syscall.SysProcAttr  
            12.     Process      *os.Process    //Process是底層進程,只啟動一次  
            13.     ProcessState *os.ProcessState  //ProcessState包含一個退出進程的信息,當進程調用Wait或者Run時便會產生該信息.  
            14. }  

             

            func Command(name string, arg ...string) *Cmd    //command返回cmd結構來執行帶有相關參數的命令,它僅僅設定cmd結構中的Path和Args參數,如果name參數中不包含路徑分隔符,command使用LookPath來解決路徑問題,否則的話就直接使用name;Args直接跟在command命令之后,所以在Args中不許要添加命令.

            [html] view plain copy
            1. func main() {  
            2.     cmd := exec.Command("tr", "a-z", "A-Z")  
            3.     cmd.Stdin = strings.NewReader("some input")  
            4.     var out bytes.Buffer  
            5.     cmd.Stdout = &out  
            6.     err := cmd.Run()  
            7.     if err != nil {  
            8.         log.Fatal(err)  
            9.     }  
            10.     fmt.Printf("in all caps: %q\n", out.String())  //in all caps: "SOME INPUT"  
            11. }  

            func (c *Cmd) CombinedOutput() ([]byte, error) //運行命令,并返回標準輸出和標準錯誤

            [html] view plain copy
            1. func main() {  
            2.     cmd := exec.Command("ls")  //查看當前目錄下文件  
            3.     out, err := cmd.CombinedOutput()  
            4.     if err != nil {  
            5.         fmt.Println(err)  
            6.     }  
            7.     fmt.Println(string(out))  
            8. }  



            func (c *Cmd) Output() ([]byte, error)     //運行命令并返回其標準輸出

            [html] view plain copy
            1. func main() {  
            2.     cmd := exec.Command("ls") ///查看當前目錄下文件  
            3.     out, err := cmd.Output()  
            4.     if err != nil {  
            5.         fmt.Println(err)  
            6.     }  
            7.     fmt.Println(string(out))  
            8. }  

            注意:Output()和CombinedOutput()不能夠同時使用,因為command的標準輸出只能有一個,同時使用的話便會定義了兩個,便會報錯

            func (c *Cmd) Run() error          //開始指定命令并且等待他執行結束,如果命令能夠成功執行完畢,則返回nil,否則的話邊會產生錯誤
            func (c *Cmd) Start() error          //使某個命令開始執行,但是并不等到他執行結束,這點和Run命令有區別.然后使用Wait方法等待命令執行完畢并且釋放響應的資源

            [html] view plain copy
            1. func main() {  
            2.     cmd := exec.Command("ls")  
            3.     cmd.Stdout = os.Stdout //  
            4.     cmd.Run()  
            5.     fmt.Println(cmd.Start()) //exec: already started  
            6. }  

            注:一個command只能使用Start()或者Run()中的一個啟動命令,不能兩個同時使用.

            func (c *Cmd) StderrPipe() (io.ReadCloser, error)  //StderrPipe返回一個pipe,這個管道連接到command的標準錯誤,當command命令退出時,Wait將關閉這些pipe
            func (c *Cmd) StdinPipe() (io.WriteCloser, error)   //StdinPipe返回一個連接到command標準輸入的管道pipe


            [html] view plain copy
            1. package main  
            2.   
            3. import (  
            4.     "fmt"  
            5.     "os"  
            6.     "os/exec"  
            7. )  
            8.   
            9. func main() {  
            10.     cmd := exec.Command("cat")  
            11.     stdin, err := cmd.StdinPipe()  
            12.     if err != nil {  
            13.         fmt.Println(err)  
            14.     }  
            15.     _, err = stdin.Write([]byte("tmp.txt"))  
            16.     if err != nil {  
            17.         fmt.Println(err)  
            18.     }  
            19.     stdin.Close()  
            20.     cmd.Stdout = os.Stdout     //終端標準輸出tmp.txt  
            21.     cmd.Start()  
            22. }  


            func (c *Cmd) StdoutPipe() (io.ReadCloser, error)        //StdoutPipe返回一個連接到command標準輸出的管道pipe

            [html] view plain copy
            1. func main() {  
            2.     cmd := exec.Command("ls")  
            3.     stdout, err := cmd.StdoutPipe()  //指向cmd命令的stdout  
            4.     cmd.Start()  
            5.     content, err := ioutil.ReadAll(stdout)  
            6.     if err != nil {  
            7.         fmt.Println(err)  
            8.     }  
            9.     fmt.Println(string(content))     //輸出ls命令查看到的內容  
            10. }  



            func (c *Cmd) Wait() error             //Wait等待command退出,他必須和Start一起使用,如果命令能夠順利執行完并順利退出則返回nil,否則的話便會返回error,其中Wait會是放掉所有與cmd命令相關的資源


            type Error    //Error返回科執行二進制文件名字不能夠執行的原因的錯誤

            [html] view plain copy
            1. type Error struct {  
            2.     Name string  
            3.     Err  error  
            4. }  


            func (e *Error) Error() string


            type ExitError  //一個command不能夠正常退出的error

            [html] view plain copy
            1. type ExitError struct {  
            2.     *os.ProcessState  
            3. }  


            func (e *ExitError) Error() string

            posted on 2018-10-09 16:16 思月行云 閱讀(878) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            中文国产成人精品久久亚洲精品AⅤ无码精品| 久久国产香蕉视频| 久久综合色之久久综合| 久久AV高清无码| 亚洲AV无码1区2区久久| 99久久99久久精品国产片果冻| 人人狠狠综合久久亚洲| 国产精品亚洲综合专区片高清久久久| 久久久无码人妻精品无码| 亚洲AV日韩精品久久久久| 婷婷综合久久中文字幕蜜桃三电影| 久久午夜免费视频| 亚洲午夜无码久久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久精品无码一区二区无码| 久久久久亚洲av成人网人人软件 | 久久久久成人精品无码中文字幕| 超级碰碰碰碰97久久久久| 亚洲午夜久久久影院| 97久久精品无码一区二区天美| 久久国产乱子精品免费女| 99久久精品久久久久久清纯| 久久露脸国产精品| 97精品国产97久久久久久免费| 久久AV高潮AV无码AV| 久久九九青青国产精品| 久久久WWW成人免费精品| 大香伊人久久精品一区二区| 老司机国内精品久久久久| 欧美亚洲日本久久精品| 久久久无码一区二区三区| 激情综合色综合久久综合| 亚洲人成精品久久久久 | 国内精品伊人久久久久av一坑| 99久久99久久精品国产片| 精品久久久久久久久免费影院| 国产精品久久成人影院| 亚洲伊人久久综合中文成人网| 国产午夜福利精品久久2021| 热综合一本伊人久久精品| 免费观看成人久久网免费观看|