婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Golang標準庫syscall詳解(什么是系統調用)

Golang標準庫syscall詳解(什么是系統調用)

熱門標簽:揚州電銷外呼系統軟件 百度地圖標注位置網站 武漢百應人工智能電銷機器人 電腦外呼系統輻射大嗎 上海企業外呼系統排名 智能語音電銷的機器人 開通400電話申請流程 如何利用高德地圖標注家 400手機電話免費辦理

一、什么是系統調用

In computing, a system call is the programmatic way in which a computer program requests a service from the kernel of the operating system it is executed on. This may include hardware-related services (for example, accessing a hard disk drive), creation and execution of new processes, and communication with integral kernel services such as process scheduling. System calls provide an essential interface between a process and the operating system.

系統調用是程序向操作系統內核請求服務的過程,通常包含硬件相關的服務(例如訪問硬盤),創建新進程等。系統調用提供了一個進程和操作系統之間的接口。

二、Golang標準庫-syscall

syscall包包含一個指向底層操作系統原語的接口。

注意:該軟件包已被鎖定。標準以外的代碼應該被遷移到golang.org/x/sys存儲庫中使用相應的軟件包。這也是應用新系統或版本所需更新的地方。 Signal , Errno 和 SysProcAttr 在 golang.org/x/sys 中尚不可用,并且仍然必須從 syscall 程序包中引用。有關更多信息,請參見 https://golang.org/s/go1.4-syscall。

https://pkg.go.dev/golang.org/x/sys
該存儲庫包含用于與操作系統進行低級交互的補充Go軟件包。

1. syscall無處不在

舉個最常用的例子, fmt.Println(“hello world”), 這里就用到了系統調用 write, 我們翻一下源碼。

func Println(a ...interface{}) (n int, err error) {
	return Fprintln(os.Stdout, a...)
}
Stdout = NewFile(uintptr(syscall.Stdout), "/dev/stdout")
 
func (f *File) write(b []byte) (n int, err error) {
    if len(b) == 0 {
        return 0, nil
    }
    // 實際的write方法,就是調用syscall.Write()
    return fixCount(syscall.Write(f.fd, b))
}

2. syscall demo舉例:

 go版本的strace Strace

strace 是用于查看進程系統調用的工具, 一般使用方法如下:

strace -c 用于統計各個系統調用的次數

[root@localhost ~]# strace -c echo hello
hello
% time     seconds  usecs/call     calls    errors syscall
------ ----------- ----------- --------- --------- ----------------
  0.00    0.000000           0         1           read
  0.00    0.000000           0         1           write
  0.00    0.000000           0         3           open
  0.00    0.000000           0         5           close
  0.00    0.000000           0         4           fstat
  0.00    0.000000           0         9           mmap
  0.00    0.000000           0         4           mprotect
  0.00    0.000000           0         2           munmap
  0.00    0.000000           0         4           brk
  0.00    0.000000           0         1         1 access
  0.00    0.000000           0         1           execve
  0.00    0.000000           0         1           arch_prctl
------ ----------- ----------- --------- --------- ----------------
100.00    0.000000                    36         1 total
[root@localhost ~]#

stace 的實現原理是系統調用 ptrace, 我們來看下 ptrace 是什么。

man page 描述如下:

The ptrace() system call provides a means by which one process (the “tracer”) may observe and control the execution of another process (the “tracee”), and examine and change the tracee's memory and registers. It is primarily used to implement breakpoint debuggingand system call tracing.

簡單來說有三大能力:

追蹤系統調用
讀寫內存和寄存器
向被追蹤程序傳遞信號

ptrace接口:

int ptrace(int request, pid_t pid, caddr_t addr, int data);
 
request包含:
PTRACE_ATTACH
PTRACE_SYSCALL
PTRACE_PEEKTEXT, PTRACE_PEEKDATA
等

tracer 使用 PTRACE_ATTACH 命令,指定需要追蹤的PID。緊接著調用 PTRACE_SYSCALL。
tracee 會一直運行,直到遇到系統調用,內核會停止執行。 此時,tracer 會收到 SIGTRAP 信號,tracer 就可以打印內存和寄存器中的信息了。

接著,tracer 繼續調用 PTRACE_SYSCALL, tracee 繼續執行,直到 tracee退出當前的系統調用。
需要注意的是,這里在進入syscall和退出syscall時,tracer都會察覺。

go版本的strace

了解以上內容后,presenter 現場實現了一個go版本的strace, 需要在 linux amd64 環境編譯。
https://github.com/silentred/gosys

// strace.go

package main
 
import (
    "fmt"
    "os"
    "os/exec"
    "syscall"
)
 
func main() {
    var err error
    var regs syscall.PtraceRegs
    var ss syscallCounter
    ss = ss.init()
 
    fmt.Println("Run: ", os.Args[1:])
 
    cmd := exec.Command(os.Args[1], os.Args[2:]...)
    cmd.Stderr = os.Stderr
    cmd.Stdout = os.Stdout
    cmd.Stdin = os.Stdin
    cmd.SysProcAttr = syscall.SysProcAttr{
        Ptrace: true,
    }
 
    cmd.Start()
    err = cmd.Wait()
    if err != nil {
        fmt.Printf("Wait err %v \n", err)
    }
 
    pid := cmd.Process.Pid
    exit := true
 
    for {
        // 記得 PTRACE_SYSCALL 會在進入和退出syscall時使 tracee 暫停,所以這里用一個變量控制,RAX的內容只打印一遍
        if exit {
            err = syscall.PtraceGetRegs(pid, regs)
            if err != nil {
                break
            }
            //fmt.Printf("%#v \n",regs)
            name := ss.getName(regs.Orig_rax)
            fmt.Printf("name: %s, id: %d \n", name, regs.Orig_rax)
            ss.inc(regs.Orig_rax)
        }
        // 上面Ptrace有提到的一個request命令
        err = syscall.PtraceSyscall(pid, 0)
        if err != nil {
            panic(err)
        }
        // 猜測是等待進程進入下一個stop,這里如果不等待,那么會打印大量重復的調用函數名
        _, err = syscall.Wait4(pid, nil, 0, nil)
        if err != nil {
            panic(err)
        }
 
        exit = !exit
    }
 
    ss.print()
}

// 用于統計信息的counter, syscallcounter.go

package main
 
import (
    "fmt"
    "os"
    "text/tabwriter"
 
    "github.com/seccomp/libseccomp-golang"
)
 
type syscallCounter []int
 
const maxSyscalls = 303
 
func (s syscallCounter) init() syscallCounter {
    s = make(syscallCounter, maxSyscalls)
    return s
}
 
func (s syscallCounter) inc(syscallID uint64) error {
    if syscallID > maxSyscalls {
        return fmt.Errorf("invalid syscall ID (%x)", syscallID)
    }
 
    s[syscallID]++
    return nil
}
 
func (s syscallCounter) print() {
    w := tabwriter.NewWriter(os.Stdout, 0, 0, 8, ' ', tabwriter.AlignRight|tabwriter.Debug)
    for k, v := range s {
        if v > 0 {
            name, _ := seccomp.ScmpSyscall(k).GetName()
            fmt.Fprintf(w, "%d\t%s\n", v, name)
        }
    }
    w.Flush()
}
 
func (s syscallCounter) getName(syscallID uint64) string {
    name, _ := seccomp.ScmpSyscall(syscallID).GetName()
    return name
}

最后結果:

Run:  [echo hello]
Wait err stop signal: trace/breakpoint trap
name: execve, id: 59
name: brk, id: 12
name: access, id: 21
name: mmap, id: 9
name: access, id: 21
name: open, id: 2
name: fstat, id: 5
name: mmap, id: 9
name: close, id: 3
name: access, id: 21
name: open, id: 2
name: read, id: 0
name: fstat, id: 5
name: mmap, id: 9
name: mprotect, id: 10
name: mmap, id: 9
name: mmap, id: 9
name: close, id: 3
name: mmap, id: 9
name: arch_prctl, id: 158
name: mprotect, id: 10
name: mprotect, id: 10
name: mprotect, id: 10
name: munmap, id: 11
name: brk, id: 12
name: brk, id: 12
name: open, id: 2
name: fstat, id: 5
name: mmap, id: 9
name: close, id: 3
name: fstat, id: 5
hello
name: write, id: 1
name: close, id: 3
name: close, id: 3
        1|read
        1|write
        3|open
        5|close
        4|fstat
        7|mmap
        4|mprotect
        1|munmap
        3|brk
        3|access
        1|execve
        1|arch_prctl

三、參考

Golang標準庫——syscall
參考URL: https://www.jianshu.com/p/44109d5e045b
Golang 與系統調用
參考URL: https://blog.csdn.net/weixin_33744141/article/details/89033990

以上就是Golang標準庫syscall詳解(什么是系統調用)的詳細內容,更多關于Golang標準庫syscall的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 解決Golang 中使用WaitGroup的那點坑
  • 在golang中使用Sync.WaitGroup解決等待的問題
  • Golang中的sync包的WaitGroup操作
  • Golang中的sync.WaitGroup用法實例
  • Golang的os標準庫中常用函數的整理介紹
  • Golang 標準庫 tips之waitgroup詳解

標簽:宜賓 江西 張掖 黑龍江 延邊 嘉峪關 武漢 新余

巨人網絡通訊聲明:本文標題《Golang標準庫syscall詳解(什么是系統調用)》,本文關鍵詞  Golang,標準,庫,syscall,詳解,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang標準庫syscall詳解(什么是系統調用)》相關的同類信息!
  • 本頁收集關于Golang標準庫syscall詳解(什么是系統調用)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91福利小视频| 丰满白嫩尤物一区二区| 亚洲激情男女视频| 亚洲视频资源在线| 亚洲三级在线播放| 婷婷综合另类小说色区| 午夜精品久久久久久久 | 男女性色大片免费观看一区二区 | www成人在线观看| 精品福利视频一区二区三区| 久久亚洲综合色一区二区三区| 精品精品国产高清a毛片牛牛 | 26uuu精品一区二区三区四区在线| 日韩欧美资源站| 久久影院电视剧免费观看| 国产亚洲女人久久久久毛片| 国产精品久久久久久久久快鸭| 亚洲精品视频免费观看| 日本午夜精品视频在线观看| 国产主播一区二区三区| 成人免费观看视频| 欧美日韩在线观看一区二区| 欧美一二三区在线| 一区免费观看视频| 亚洲成人激情综合网| 国产美女视频91| 欧美在线观看视频在线| 精品国产一区二区精华| 亚洲免费在线观看视频| 久久99精品国产麻豆婷婷| 国产精品123| 欧美日本视频在线| 欧美极品aⅴ影院| 日韩在线一区二区三区| 成人免费视频免费观看| 欧美日韩久久不卡| 国产精品美日韩| 久久精品国产在热久久| 色婷婷av一区二区| 久久精品男人天堂av| 午夜精彩视频在线观看不卡| 国产69精品久久99不卡| 在线综合+亚洲+欧美中文字幕| 日本一区二区三区在线观看| 三级不卡在线观看| 91视频在线观看免费| 久久嫩草精品久久久精品| 天天做天天摸天天爽国产一区 | 亚洲一区二区欧美| 国产精品影视在线| 欧美一区午夜视频在线观看| 亚洲欧美区自拍先锋| 国产精品一二二区| 26uuu色噜噜精品一区二区| 亚洲成人自拍网| 色久综合一二码| 亚洲精品久久久久久国产精华液| 国产精品自产自拍| 精品电影一区二区| 蜜桃视频在线观看一区二区| 欧美精品tushy高清| 亚洲高清视频在线| 在线视频观看一区| 亚洲精品videosex极品| 99re视频精品| 日韩毛片精品高清免费| 成人午夜视频网站| 国产精品国产三级国产aⅴ入口| 国产一区二区三区观看| 久久青草国产手机看片福利盒子 | 奇米精品一区二区三区四区| 欧美精品日韩综合在线| 日韩av一级片| 欧美大片在线观看一区二区| 毛片av一区二区三区| 日韩精品一区在线观看| 精品一区二区日韩| 久久精品免视看| 粉嫩aⅴ一区二区三区四区 | 在线成人av影院| 青青草成人在线观看| 欧美xxx久久| 国产精品一二三四五| 国产片一区二区| 95精品视频在线| 午夜精品成人在线视频| 精品日韩欧美在线| 高清国产一区二区| 亚洲国产sm捆绑调教视频| 欧美一区二区在线视频| 精品一区二区日韩| 成人免费一区二区三区在线观看| 97久久久精品综合88久久| 性感美女极品91精品| 精品久久久久一区二区国产| 成人性生交大片免费看视频在线| 亚洲色大成网站www久久九九| 欧美日韩精品电影| 国产精品99精品久久免费| 亚洲精品久久久蜜桃| 日韩一区二区精品葵司在线| 国产 日韩 欧美大片| 亚洲国产精品久久久久秋霞影院| 日韩欧美第一区| 91丨porny丨户外露出| 日韩av一级电影| 国产精品网站在线| 欧美日产在线观看| 国产乱子轮精品视频| 一区二区三区产品免费精品久久75| 91精品国产91久久久久久最新毛片 | 成人激情文学综合网| 亚洲国产精品人人做人人爽| 久久久www免费人成精品| 欧美在线观看视频一区二区三区 | 亚洲天堂福利av| 欧美日本视频在线| 亚洲第一成年网| 91在线视频免费91| 麻豆一区二区三区| 国产九九视频一区二区三区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧美日本在线观看| 色视频成人在线观看免| 国产盗摄视频一区二区三区| 日日骚欧美日韩| 亚洲乱码国产乱码精品精98午夜| 日韩免费高清av| 欧美三级韩国三级日本三斤| 91丨porny丨国产入口| 成人少妇影院yyyy| 国产中文字幕精品| 久久99久国产精品黄毛片色诱| 一区二区高清在线| 亚洲欧美视频在线观看| 国产精品美女久久久久久| 国产亚洲一区二区在线观看| 欧美一区二区三区视频在线| 欧美日韩一区久久| 在线看不卡av| 色狠狠一区二区三区香蕉| 色婷婷综合久久久久中文| proumb性欧美在线观看| 成人av电影在线观看| 播五月开心婷婷综合| 国产精品亚洲综合一区在线观看| 国内精品免费**视频| 国产精品一区免费在线观看| 韩国成人精品a∨在线观看| 美国毛片一区二区三区| 日本美女视频一区二区| 麻豆视频观看网址久久| 久久草av在线| 国产精品18久久久| av电影一区二区| 色激情天天射综合网| 精品视频在线免费| 欧美一区二区三区免费观看视频| 欧美日韩成人综合天天影院| 7878成人国产在线观看| 精品精品国产高清a毛片牛牛| 久久久不卡网国产精品二区| 国产精品欧美久久久久无广告 | 亚洲国产精品黑人久久久| 国产日韩欧美精品综合| 国产精品久久久久婷婷| 亚洲综合999| 免费一区二区视频| 成人免费看黄yyy456| 欧美自拍丝袜亚洲| 日韩一级片网址| 国产精品久久久久国产精品日日| 亚洲精品欧美激情| 久久国产精品99久久人人澡| 床上的激情91.| 欧美日韩亚洲综合在线| 精品久久久久av影院| 国产精品久久久久一区二区三区共| 亚洲精品伦理在线| 久久电影网电视剧免费观看| 99re在线视频这里只有精品| 9191成人精品久久| 国产精品久久久久毛片软件| 亚洲成人动漫一区| 粉嫩aⅴ一区二区三区四区五区 | 欧美国产乱子伦 | 久久久一区二区三区捆绑**| 亚洲天堂av老司机| 韩国女主播成人在线观看| 色综合激情五月| 久久久国产综合精品女国产盗摄| 亚洲精品自拍动漫在线| 国产精品自产自拍| 91精品一区二区三区久久久久久| 国产精品理论在线观看| 看国产成人h片视频| 91成人网在线| 国产精品理伦片| 国产精品一区二区久久精品爱涩 | 国产成人在线免费观看|