亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 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詳解(什么是系統調用)的相關信息資訊供網民參考!
  • 推薦文章
    999精品在线| 黄视频网站免费观看| 一级女性大黄生活片免费| 国产成人欧美一区二区三区的| 国产精品免费精品自在线观看| 91麻豆爱豆果冻天美星空| 国产精品自拍亚洲| 午夜欧美成人久久久久久| 欧美激情一区二区三区在线播放 | 日本伦理片网站| 香蕉视频久久| 台湾毛片| 国产伦精品一区二区三区无广告 | 黄色福利| 国产亚洲精品aaa大片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产视频一区在线| 四虎影视久久久| 日韩免费在线| 欧美一区二区三区在线观看| 免费一级片在线观看| 高清一级毛片一本到免费观看| 国产一区二区福利久久| 日日夜夜婷婷| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 可以免费看毛片的网站| 日本在线不卡免费视频一区| 九九九国产| 久久成人综合网| 国产高清视频免费观看| 日韩字幕在线| 91麻豆精品国产自产在线观看一区| 亚洲天堂免费| 精品在线观看国产| 色综合久久天天综合观看| 日韩综合| 国产综合成人观看在线| 精品视频免费观看| 午夜在线影院| 日韩专区一区| 精品国产一区二区三区国产馆 | 国产成人欧美一区二区三区的| 久久国产精品永久免费网站| 日韩专区第一页| 欧美激情一区二区三区视频 | 日韩中文字幕一区| 欧美大片aaaa一级毛片| 国产伦精品一区二区三区无广告| 99热精品在线| 亚洲 国产精品 日韩| 九九久久国产精品大片| 香蕉视频久久| 美女免费黄网站| 青青久热| 日本特黄特黄aaaaa大片| 亚欧成人乱码一区二区| 成人免费观看视频| 亚洲女人国产香蕉久久精品| 国产亚洲精品aaa大片| 成人av在线播放| 国产极品白嫩美女在线观看看| 久久国产一区二区| 国产成人精品综合在线| 日韩免费在线| 一级女性全黄生活片免费| 九九干| 国产伦久视频免费观看视频| 国产不卡在线观看视频| 精品国产香蕉伊思人在线又爽又黄| 成人高清视频免费观看| 一级女性全黄久久生活片| 欧美国产日韩一区二区三区| 国产91精品一区二区| 国产一区二区精品久久91| 精品久久久久久影院免费| 亚洲第一页色| 一级女性大黄生活片免费| 九九热国产视频| 亚欧乱色一区二区三区| 国产伦精品一区二区三区无广告| 黄视频网站在线免费观看| 欧美激情在线精品video| 欧美激情一区二区三区在线| 中文字幕一区二区三区精彩视频| 国产高清在线精品一区a| 久久精品欧美一区二区| 国产高清视频免费观看| 免费的黄视频| 欧美日本国产| 国产美女在线一区二区三区| 久久精品店| 香蕉视频久久| a级精品九九九大片免费看| 精品国产亚洲一区二区三区| 台湾毛片| 成人免费一级纶理片| 日日日夜夜操| 夜夜操网| 日韩av成人| 国产一区二区精品久久91| 久久99欧美| 国产成人精品综合久久久| 国产国产人免费视频成69堂| 999精品影视在线观看| 999精品视频在线| 欧美激情中文字幕一区二区| 高清一级片| 一级女性全黄久久生活片| 亚欧乱色一区二区三区| 国产网站免费观看| 精品视频免费观看| 精品国产一区二区三区久| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产极品白嫩美女在线观看看| 黄视频网站免费| 日韩专区第一页| 韩国三级视频在线观看| 国产一区精品| 欧美日本二区| 精品国产香蕉在线播出| 精品国产一区二区三区国产馆 | 国产成人精品综合| 精品久久久久久中文字幕2017| 精品在线免费播放| 欧美1区| 精品国产一区二区三区精东影业 | 日韩av片免费播放| 精品视频一区二区| 欧美国产日韩一区二区三区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美1区2区3区| 成人高清视频在线观看| 亚欧乱色一区二区三区| 日本免费区| 国产原创中文字幕| 精品视频在线观看一区二区| 亚洲精品中文一区不卡| 久久成人综合网| 国产极品精频在线观看| 国产91丝袜高跟系列| 午夜激情视频在线播放| 国产视频一区二区在线观看| 青青久热| 毛片高清| 国产91精品一区| 久久精品人人做人人爽97| 免费国产一级特黄aa大片在线| 国产成a人片在线观看视频| 亚久久伊人精品青青草原2020| 欧美激情一区二区三区视频| 九九久久国产精品| 日日爽天天| 黄视频网站免费| 国产亚洲精品成人a在线| 四虎影视久久| 色综合久久手机在线| 欧美激情一区二区三区视频| 欧美激情一区二区三区视频高清 | 色综合久久天天综合绕观看 | 日韩中文字幕一区| 欧美大片一区| 国产精品1024在线永久免费| 国产一区二区精品久久| 一级毛片看真人在线视频| 九九干| 亚洲天堂在线播放| 久久久成人影院| 国产91精品一区二区| 国产成人精品综合在线| 午夜在线影院| 天天做人人爱夜夜爽2020毛片| 久久精品店| 日本在线www| 国产麻豆精品| 精品国产香蕉在线播出| 国产a视频| 一本高清在线| 四虎影视久久久| 999久久狠狠免费精品| 日韩女人做爰大片| 二级片在线观看| a级精品九九九大片免费看| 精品视频在线看 | 999精品视频在线| 欧美大片a一级毛片视频| 久久精品免视看国产明星| 国产麻豆精品高清在线播放| 毛片电影网| 久久国产精品自由自在| 久久久久久久男人的天堂| 国产福利免费观看| 日韩在线观看免费完整版视频| 尤物视频网站在线| a级精品九九九大片免费看| 成人免费网站久久久| 日日日夜夜操| 国产国产人免费视频成69堂| 亚洲 国产精品 日韩| 欧美激情一区二区三区在线播放 | 日韩在线观看免费|