婷婷综合国产,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视频国产观看| 666欧美在线视频| 国产精品美女久久久久久久| 蜜臀av性久久久久蜜臀aⅴ| 色婷婷久久综合| 久久精品网站免费观看| 视频一区欧美精品| 色域天天综合网| 国产精品嫩草久久久久| 狠狠色丁香久久婷婷综合丁香| 欧美色图免费看| 国产精品免费免费| 国产精品白丝jk黑袜喷水| 欧美日韩精品系列| 一区二区视频免费在线观看| 成人精品视频一区二区三区尤物| 久久中文娱乐网| 美女视频黄免费的久久| 欧美日韩小视频| 亚洲一区二区影院| 欧美性色aⅴ视频一区日韩精品| 国产精品福利一区| a美女胸又www黄视频久久| 国产视频一区二区在线观看| 青娱乐精品视频在线| 欧美日韩一二三区| 亚洲国产精品久久人人爱| 欧美亚洲综合另类| 亚洲综合丝袜美腿| 欧美在线不卡一区| 亚洲专区一二三| 欧美日韩电影在线| 免费成人小视频| 日韩欧美一区中文| 韩国v欧美v日本v亚洲v| 337p粉嫩大胆噜噜噜噜噜91av| av在线播放不卡| 综合自拍亚洲综合图不卡区| 91免费观看在线| 亚洲影视在线观看| 9191精品国产综合久久久久久 | 国产精品久久久久久久午夜片| 国产精品99久久久久| 国产视频一区二区在线| 91麻豆免费观看| 亚洲电影第三页| 亚洲精品在线三区| 9i在线看片成人免费| 一区二区三区中文在线观看| 欧美人与禽zozo性伦| 日本亚洲天堂网| 国产亚洲精品bt天堂精选| 一本色道久久综合亚洲aⅴ蜜桃 | 国产成人aaa| 亚洲欧美成aⅴ人在线观看| 欧美三区在线观看| 亚洲女人小视频在线观看| 国产精品1区2区| 亚洲国产精品视频| 久久先锋资源网| 99国产精品久久久久久久久久久| 亚洲伊人伊色伊影伊综合网 | 欧美三级电影网| 美女任你摸久久 | 色哟哟国产精品| 久久er精品视频| 亚洲美女精品一区| 日韩欧美一二区| 97久久超碰国产精品| 麻豆91免费观看| 一区二区三区免费| 久久久久青草大香线综合精品| 日本韩国一区二区三区视频| 国产乱码精品一区二区三| 亚洲精品国产a| 久久久久久久久久看片| 欧美三级欧美一级| 99久久综合国产精品| 老司机免费视频一区二区三区| 成人免费一区二区三区视频| 精品欧美黑人一区二区三区| 色香蕉久久蜜桃| 丁香激情综合五月| 免费在线观看日韩欧美| 一区二区三区欧美视频| 国产精品久久久久一区二区三区共 | 91麻豆精品国产91久久久久久久久 | 久久97超碰国产精品超碰| 亚洲少妇屁股交4| 国产校园另类小说区| 欧美一卡二卡在线| 欧美性猛交xxxx黑人交| 国产91丝袜在线播放0| 国产专区综合网| 久久精品国产久精国产爱| 亚洲va天堂va国产va久| 亚洲精品高清在线观看| 久久99精品国产麻豆不卡| 亚洲精品福利视频网站| 亚洲欧洲av在线| 国产精品视频yy9299一区| 久久精品亚洲精品国产欧美 | 亚洲欧美电影院| 国产精品久久看| 国产精品伦一区二区三级视频| 国产色91在线| 久久嫩草精品久久久久| 久久久久久久久久久电影| 精品久久久久香蕉网| 精品国产一二三区| 久久亚区不卡日本| 国产欧美日韩不卡| 欧美激情在线免费观看| 亚洲国产精品黑人久久久| 国产精品视频第一区| 亚洲视频一区二区免费在线观看| 日韩美女久久久| 亚洲精品国产精华液| 亚洲电影中文字幕在线观看| 午夜成人免费电影| 免费美女久久99| 国产尤物一区二区| 国产高清在线观看免费不卡| 国产成人一区在线| 成人高清视频免费观看| 色先锋aa成人| 欧美日韩不卡在线| 日韩欧美第一区| 国产精品久久夜| 婷婷综合另类小说色区| 美国av一区二区| 国产盗摄一区二区| 色欧美乱欧美15图片| 欧美丰满美乳xxx高潮www| 日韩一区二区在线观看| 久久精品人人爽人人爽| 亚洲蜜臀av乱码久久精品| 三级成人在线视频| 国产精品资源网| 欧美性猛交xxxx乱大交退制版| 欧美v亚洲v综合ⅴ国产v| 中文字幕一区日韩精品欧美| 亚洲第一成人在线| 国产成人亚洲综合a∨婷婷图片| 色综合久久久久网| 欧美tickling网站挠脚心| 国产精品理论片| 日本不卡中文字幕| 成人黄页毛片网站| 亚洲精品一二三| 日韩国产欧美在线观看| 成人综合婷婷国产精品久久蜜臀| 欧美色涩在线第一页| 国产欧美视频在线观看| 午夜影院久久久| 99国产精品视频免费观看| 精品日产卡一卡二卡麻豆| 亚洲精品欧美激情| 国产一区二区免费看| 欧美视频一区在线观看| 欧美国产精品一区| 美脚の诱脚舐め脚责91| 在线观看中文字幕不卡| 国产精品理伦片| 国产精品一二三四区| 欧美一区二区视频在线观看2022| 亚洲欧美日韩在线| 国产成人在线视频免费播放| 欧美一区二区三区影视| 亚洲综合网站在线观看| 99久久777色| 久久久久国产成人精品亚洲午夜| 性感美女久久精品| 一本久久精品一区二区| 日本一区二区视频在线观看| 久久电影网电视剧免费观看| 6080亚洲精品一区二区| 亚洲国产一二三| 在线观看国产精品网站| 亚洲欧美另类小说| 91视频免费看| 一区二区国产盗摄色噜噜| 色综合久久综合中文综合网| 亚洲欧洲日韩av| 99re视频精品| 亚洲欧美日韩精品久久久久| 不卡欧美aaaaa| 亚洲欧美怡红院| 成人免费视频一区| 国产精品三级av在线播放| 成人一区二区三区中文字幕| 国产欧美一区二区在线观看| 国产精品 日产精品 欧美精品| 久久久青草青青国产亚洲免观| 国产成人8x视频一区二区| 国产精品传媒视频| 91黄色免费版|