婷婷综合国产,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
    一区二区三区四区不卡在线| 26uuu亚洲综合色| 国产福利一区二区三区视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲电影你懂得| 亚洲国产中文字幕| 天天色图综合网| 视频一区二区中文字幕| 日日噜噜夜夜狠狠视频欧美人| 日韩电影在线观看一区| 久久精品国产精品亚洲综合| 麻豆成人综合网| 成人免费高清在线| 色8久久人人97超碰香蕉987| 欧美日韩久久久| 欧美成人免费网站| 欧美激情自拍偷拍| 亚洲欧美日韩精品久久久久| 五月激情丁香一区二区三区| 免费在线一区观看| 成人动漫一区二区三区| 欧美亚洲综合在线| 久久综合中文字幕| 一区二区三区欧美在线观看| 视频在线观看一区二区三区| 久久91精品久久久久久秒播| www.欧美色图| 91精品国产综合久久久久久漫画| 欧美成人伊人久久综合网| 中文字幕日韩一区二区| 日韩电影在线看| 色呦呦网站一区| 26uuu久久天堂性欧美| 亚洲欧美激情视频在线观看一区二区三区| 亚洲国产成人精品视频| 国产精品12区| 911国产精品| 亚洲精品成人精品456| 韩国毛片一区二区三区| 91福利精品第一导航| 精品美女一区二区| 一区二区国产盗摄色噜噜| 国精产品一区一区三区mba视频 | 久久欧美中文字幕| 亚洲成人av免费| 色婷婷av一区| 中文字幕乱码一区二区免费| 日韩电影免费一区| 91久久精品网| 最新国产の精品合集bt伙计| 国产在线精品一区二区夜色 | 免费成人av在线| 在线观看91视频| 国产精品美女视频| 国产精品一区二区91| 日韩久久精品一区| 蜜桃av一区二区| 欧美日韩aaa| 亚洲1区2区3区4区| 欧美日韩亚洲综合在线| 亚洲免费观看在线观看| 91影视在线播放| 国产精品午夜免费| 成人av中文字幕| 国产精品久久久久天堂| 国产成人午夜99999| 国产午夜精品一区二区三区嫩草| 久久99精品视频| 久久婷婷久久一区二区三区| 狠狠色丁香久久婷婷综合_中 | 粉嫩一区二区三区在线看| 精品国产一区a| 激情六月婷婷综合| 欧美国产一区二区在线观看| 国产99久久精品| 国产精品国产三级国产| 91视视频在线观看入口直接观看www | 蜜臀久久99精品久久久久宅男 | 日韩欧美视频一区| 免费在线观看一区二区三区| 日韩欧美一区在线观看| 黄页网站大全一区二区| 久久久国产精华| 不卡一区中文字幕| 亚洲男人的天堂网| 欧美女孩性生活视频| 蜜桃视频在线一区| 久久久久久久久伊人| thepron国产精品| 亚洲成人综合网站| 日韩限制级电影在线观看| 国内精品在线播放| 亚洲色图在线看| 88在线观看91蜜桃国自产| 国产在线一区观看| 中文字幕在线观看一区二区| 在线视频国内自拍亚洲视频| 日韩在线a电影| 国产精品久久午夜| 欧美精品丝袜中出| 国产在线国偷精品产拍免费yy| 中文字幕一区免费在线观看| 欧美在线免费播放| 国产一区久久久| 亚洲另类在线制服丝袜| 欧美成人午夜电影| 在线观看亚洲一区| 国产一区二区视频在线播放| 综合av第一页| 欧美精品一区二区三区高清aⅴ| 91在线视频官网| 精品在线一区二区| 亚洲午夜激情网页| 国产精品萝li| 精品成人一区二区| 欧美日韩一区二区在线视频| 国产精品一区二区三区网站| 亚洲成a人在线观看| 中文字幕乱码久久午夜不卡 | 欧美色欧美亚洲另类二区| 香蕉成人啪国产精品视频综合网| 精品久久久久久久久久久院品网 | 亚洲第一成人在线| 国产欧美一区二区精品久导航| 欧美日韩国产精品自在自线| 成人福利视频网站| 国产在线播放一区| 麻豆极品一区二区三区| 一区二区三区国产精品| 国产精品欧美一级免费| 精品免费日韩av| 日韩欧美二区三区| 欧美精品xxxxbbbb| 在线免费观看成人短视频| 成人av电影在线播放| 国产一区二区三区不卡在线观看| 日本不卡在线视频| 亚洲成人黄色小说| 夜夜夜精品看看| 亚洲视频一二三区| 中文字幕在线不卡| 国产精品久久三区| 国产精品久久三| 亚洲国产精品成人久久综合一区| 欧美xxxx老人做受| 精品成人一区二区三区四区| 欧美精品一区二区三区在线 | 成人av网址在线观看| 国产高清久久久| 国产69精品久久久久777| 国产mv日韩mv欧美| www.66久久| 欧美视频三区在线播放| 欧美另类videos死尸| 日韩三级av在线播放| 26uuu亚洲综合色欧美| 国产女人aaa级久久久级| 国产精品美女久久久久久久久| 欧美激情艳妇裸体舞| 1024成人网| 亚洲午夜精品网| 免费精品99久久国产综合精品| 美女mm1313爽爽久久久蜜臀| 国产一区二区三区黄视频| 国产91精品在线观看| 91麻豆123| 91精品国产一区二区三区蜜臀| 欧美成人国产一区二区| 国产精品美女久久久久aⅴ| 亚洲麻豆国产自偷在线| 免费观看日韩电影| 懂色av一区二区三区蜜臀| 欧美视频一区二区在线观看| 日韩三级av在线播放| 国产精品视频线看| 亚洲中国最大av网站| 国内久久精品视频| 色综合色综合色综合| 日韩一区和二区| 国产精品第13页| 欧美a一区二区| 91浏览器在线视频| 久久久91精品国产一区二区三区| 亚洲精品免费看| 国产夫妻精品视频| 欧美精品第一页| 一区二区三区在线播| 国产精品一区久久久久| 欧美日韩国产天堂| 中文字幕一区二区三区在线观看 | 美女mm1313爽爽久久久蜜臀| 99精品国产一区二区三区不卡| 91精品国产麻豆| 亚洲精品乱码久久久久久| 国内精品写真在线观看| 欧美精品亚洲一区二区在线播放| 国产精品久久久久影院色老大| 久久国产剧场电影| 欧美卡1卡2卡| 亚洲在线视频网站|