婷婷综合国产,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亚洲精品一区二区乱码| 国产成人免费视频精品含羞草妖精| 久久蜜桃av一区精品变态类天堂| 欧美三级乱人伦电影| www.欧美.com| 色综合一区二区三区| www.日韩大片| 色菇凉天天综合网| 欧美写真视频网站| 欧美高清一级片在线| 欧美日韩成人在线一区| 在线成人免费视频| 欧美变态tickling挠脚心| 91精品国产麻豆| 久久亚洲精精品中文字幕早川悠里| 久久综合久久综合久久综合| 欧美国产日韩a欧美在线观看| 国产亚洲精品免费| 日韩一区中文字幕| 亚洲国产视频网站| 奇米四色…亚洲| 国产不卡视频在线播放| 99这里只有久久精品视频| 在线视频亚洲一区| www国产精品av| 中文字幕一区av| 亚洲一区影音先锋| 久久精品99久久久| 不卡av在线免费观看| 欧美午夜寂寞影院| 精品盗摄一区二区三区| 国产日韩欧美一区二区三区综合| 国产精品第五页| 午夜亚洲福利老司机| 国产经典欧美精品| 欧美在线视频不卡| 精品久久久久香蕉网| 综合久久久久久久| 国产一区二区在线看| 色香蕉久久蜜桃| 欧美电视剧免费观看| 国产精品成人在线观看| 免费高清视频精品| 99久久99久久综合| 精品国产百合女同互慰| 亚洲精品国产视频| 久草中文综合在线| 在线视频亚洲一区| 自拍偷拍国产亚洲| 韩国三级电影一区二区| 欧美日韩大陆一区二区| 国产精品电影一区二区三区| 韩国欧美国产一区| 欧美久久久久久久久久| 亚洲美女屁股眼交3| 国产福利91精品一区| 日韩一区国产二区欧美三区| 一级日本不卡的影视| 成人va在线观看| 久久亚洲精精品中文字幕早川悠里| 亚洲成人免费影院| 色噜噜狠狠色综合中国| 国产精品日韩成人| 国产精华液一区二区三区| 欧美大片一区二区三区| 奇米精品一区二区三区在线观看 | 欧美日韩国产小视频在线观看| 国产精品三级久久久久三级| 国产馆精品极品| 精品88久久久久88久久久 | 337p粉嫩大胆噜噜噜噜噜91av | 欧美亚州韩日在线看免费版国语版| 欧美激情在线一区二区| 国产成人鲁色资源国产91色综| 精品少妇一区二区三区免费观看 | 亚洲国产精品久久不卡毛片| 欧美中文一区二区三区| 午夜精品久久久久久久久久久| 欧美乱妇15p| 日韩国产精品久久| 精品久久国产老人久久综合| 卡一卡二国产精品| 久久婷婷成人综合色| 国产99久久久国产精品| 国产精品丝袜久久久久久app| 成人永久免费视频| 亚洲男同1069视频| 69成人精品免费视频| 激情五月激情综合网| 国产精品的网站| 欧美日韩在线综合| 美女久久久精品| 国产亚洲精品福利| 97se狠狠狠综合亚洲狠狠| 亚洲一区在线观看免费 | 国产福利一区二区三区在线视频| 国产亚洲欧美日韩俺去了| 99麻豆久久久国产精品免费| 亚洲国产日韩a在线播放性色| 日韩欧美aaaaaa| 成人黄动漫网站免费app| 一区二区三区影院| 欧美成人官网二区| 99re成人精品视频| 麻豆91在线看| 亚洲欧洲一区二区三区| 欧美精品久久一区二区三区| 麻豆精品在线看| 亚洲手机成人高清视频| 日韩色视频在线观看| 99免费精品在线| 精品亚洲aⅴ乱码一区二区三区| 国产精品乱码人人做人人爱| 69堂成人精品免费视频| 99久久综合99久久综合网站| 日韩国产欧美三级| 伊人一区二区三区| 久久久91精品国产一区二区精品| 一本色道亚洲精品aⅴ| 狠狠狠色丁香婷婷综合激情| 亚洲一二三四在线| 中文字幕高清一区| 欧美tk—视频vk| 欧美日韩专区在线| 成人av高清在线| 精品午夜久久福利影院| 性欧美大战久久久久久久久| 国产精品水嫩水嫩| 久久九九全国免费| 欧美不卡一区二区| 日韩西西人体444www| 在线观看www91| 91在线无精精品入口| 盗摄精品av一区二区三区| 老司机精品视频在线| 肉色丝袜一区二区| 五月综合激情网| 亚洲精品视频观看| 亚洲欧美日韩国产综合| 国产日韩欧美激情| 日本一区二区三级电影在线观看| 日韩欧美第一区| 日韩精品一区二区三区三区免费 | 国产一区二区视频在线| 日本视频免费一区| 毛片一区二区三区| 另类小说一区二区三区| 青椒成人免费视频| 秋霞国产午夜精品免费视频| 视频精品一区二区| 日韩电影免费在线看| 日韩av在线播放中文字幕| 日韩专区在线视频| 免费人成网站在线观看欧美高清| 日本一道高清亚洲日美韩| 麻豆国产精品一区二区三区| 美女尤物国产一区| 国产精品白丝av| 成人国产视频在线观看| 91在线你懂得| 欧美午夜免费电影| 日韩一二三四区| 久久久99精品免费观看不卡| 国产精品不卡一区二区三区| 国产精品不卡一区| 亚洲一区二区黄色| 国精产品一区一区三区mba视频| 国产一区二区在线影院| jvid福利写真一区二区三区| 色综合久久中文综合久久牛| 欧美三级电影在线观看| 精品乱人伦小说| 国产精品视频在线看| 亚洲高清久久久| 国内精品视频666| 99久久精品免费看国产| 欧美日韩高清在线| 国产欧美一区在线| 亚洲欧美自拍偷拍| 麻豆91在线播放| 91偷拍与自偷拍精品| 91精品国产综合久久国产大片 | 顶级嫩模精品视频在线看| 色成人在线视频| 久久久久国产一区二区三区四区| 国产精品盗摄一区二区三区| 亚洲v日本v欧美v久久精品| 国产美女精品人人做人人爽| 色综合欧美在线| 精品久久久久香蕉网| 亚洲靠逼com| 国产精品一二二区| 欧美挠脚心视频网站| 亚洲国产成人私人影院tom| 午夜久久久久久| 91香蕉国产在线观看软件| 久久综合狠狠综合久久综合88| 亚洲一区二区三区在线| 成人精品国产免费网站| 精品久久久久久久人人人人传媒|