婷婷综合国产,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
    精品视频在线看| 成人18精品视频| 亚洲黄一区二区三区| 国产精品久久久久久久午夜片| 日韩精品一区二区三区老鸭窝| 日韩午夜在线影院| 精品久久久久久久久久久久久久久| 欧美日韩一区 二区 三区 久久精品| 色综合天天在线| 欧美色图天堂网| 精品视频一区二区不卡| 欧美卡1卡2卡| 日韩欧美电影在线| 欧美精品一区二区三| 久久久亚洲午夜电影| 亚洲国产精品二十页| **欧美大码日韩| 亚洲成av人片在线| 美女爽到高潮91| 国产成人在线免费观看| 色哟哟一区二区三区| 欧美日韩一区久久| 精品入口麻豆88视频| 国产亚洲女人久久久久毛片| 国产精品久久久99| 亚洲自拍偷拍综合| 美女网站在线免费欧美精品| 成人一区二区三区| 欧美影院一区二区| 精品第一国产综合精品aⅴ| 国产精品人成在线观看免费| 午夜欧美电影在线观看| 老司机精品视频线观看86| 国产精品综合二区| 日本乱人伦aⅴ精品| 在线成人免费视频| 中文一区二区在线观看| 日韩精品乱码免费| 国产91综合一区在线观看| 欧美色精品在线视频| 欧美激情中文字幕一区二区| 亚洲大尺度视频在线观看| 国产成人精品综合在线观看| 欧美日韩国产美| 中文字幕一区二区不卡 | 中文字幕国产一区二区| 亚洲综合一区在线| 国产不卡在线一区| 日韩欧美激情在线| 一区二区三区四区视频精品免费| 美女一区二区在线观看| 欧美中文一区二区三区| 日本一区二区免费在线| 久久精品免费看| 欧美日韩国产片| 日韩毛片在线免费观看| 国产福利91精品| 日韩一区二区中文字幕| 亚洲一区二区在线观看视频| 成人开心网精品视频| 国产亚洲视频系列| 激情综合五月天| 91精品国产综合久久国产大片| 亚洲三级在线看| 99久久久无码国产精品| 亚洲国产精品成人综合| 国产精品白丝av| 精品精品欲导航| 精品中文字幕一区二区| 91精品福利在线一区二区三区 | 性感美女久久精品| 色先锋久久av资源部| 日韩码欧中文字| jlzzjlzz亚洲女人18| 欧美激情在线观看视频免费| 国产一区二区三区精品欧美日韩一区二区三区 | 一区二区三区四区五区视频在线观看| 国产成人精品网址| 久久精品亚洲国产奇米99| 极品尤物av久久免费看| 久久久噜噜噜久噜久久综合| 国产成人综合在线观看| 日本一区二区免费在线| 不卡在线视频中文字幕| 日韩伦理电影网| 欧美日韩一二三区| 日韩av高清在线观看| 日韩精品一区国产麻豆| 国产在线精品一区在线观看麻豆| 欧美精品一区二| 成人黄色软件下载| 亚洲综合免费观看高清完整版 | 国产情人综合久久777777| 波多野洁衣一区| 亚洲综合色婷婷| 日韩欧美激情一区| 不卡大黄网站免费看| 一区二区三区在线不卡| 91精品国产乱| 成人一区二区三区视频在线观看| 亚洲日本va午夜在线影院| 欧美日韩国产123区| 国产在线精品视频| 亚洲蜜臀av乱码久久精品 | 久久免费精品国产久精品久久久久| 国产.欧美.日韩| 亚洲成人av资源| 久久丝袜美腿综合| 色婷婷综合久久久久中文| 老司机精品视频导航| 亚洲欧洲另类国产综合| 欧美一区二区三区四区五区| 成人va在线观看| 老司机精品视频在线| 亚洲欧洲成人自拍| 日韩精品一区二区三区中文不卡 | 欧美日韩高清影院| 国产成人激情av| 热久久国产精品| 亚洲日本中文字幕区| 亚洲精品一区二区在线观看| 欧美视频一区二区在线观看| 国产精品一二三四区| 日韩av中文字幕一区二区三区| 国产精品女人毛片| 欧美精品一区二| 欧美日韩亚洲国产综合| 99久久夜色精品国产网站| 久久狠狠亚洲综合| 亚洲成av人综合在线观看| 综合色天天鬼久久鬼色| 国产欧美精品区一区二区三区| 欧美一区2区视频在线观看| 91精品办公室少妇高潮对白| 成人免费视频播放| 国产一区二区在线视频| 另类综合日韩欧美亚洲| 日本午夜一本久久久综合| 亚洲一区二区三区四区五区黄 | 精品少妇一区二区三区| 欧美无砖专区一中文字| 99久久国产综合精品色伊| 大胆亚洲人体视频| 国产在线视频不卡二| 久久国产尿小便嘘嘘| 奇米影视一区二区三区| 天天综合日日夜夜精品| 午夜久久久久久久久| 亚洲成人一区二区在线观看| 亚洲成人久久影院| 五月激情综合网| 日本欧美韩国一区三区| 免费成人性网站| 久久99精品久久久久久| 国产美女视频91| 国产a精品视频| www.成人网.com| 一本大道久久a久久精品综合| 色婷婷激情综合| 欧美乱熟臀69xxxxxx| 欧美顶级少妇做爰| 精品福利av导航| 久久久久久久综合色一本| 欧美国产日韩a欧美在线观看| 亚洲欧美在线视频观看| 一区二区在线观看视频在线观看| 亚洲国产一区二区三区| 日韩av网站免费在线| 国产一区视频导航| 99在线精品一区二区三区| 欧美视频日韩视频在线观看| 欧美一级电影网站| 国产欧美日本一区二区三区| 亚洲女子a中天字幕| 丝袜美腿成人在线| 国产精品一区在线观看乱码| 色婷婷综合视频在线观看| 欧美日本不卡视频| 久久久精品国产免费观看同学| 中文字幕亚洲在| 日韩二区三区在线观看| 国产丶欧美丶日本不卡视频| 日本电影欧美片| 久久蜜桃香蕉精品一区二区三区| 亚洲色图视频网| 精品在线观看视频| 99精品视频在线观看免费| 欧美日韩久久久| 国产蜜臀av在线一区二区三区| 夜夜精品视频一区二区| 国产成人av网站| 欧美日韩一区精品| 国产精品每日更新| 日本不卡视频在线| 日本精品裸体写真集在线观看 | 欧美一区二区福利视频| 中文字幕日韩一区二区| 久久se这里有精品| 91蝌蚪porny| 国产精品午夜春色av|