婷婷综合国产,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
    亚洲欧洲av在线| 91精品国产一区二区三区香蕉| 亚洲成va人在线观看| |精品福利一区二区三区| 精品久久久久久久久久久久久久久久久 | 91视频在线看| 成人一区二区视频| 日本中文一区二区三区| 天天亚洲美女在线视频| 五月天激情小说综合| 亚洲成av人片在线| 天堂精品中文字幕在线| 日韩精品91亚洲二区在线观看| 日本美女一区二区三区视频| 免费观看成人鲁鲁鲁鲁鲁视频| 日韩激情视频在线观看| 麻豆91免费观看| 成人毛片在线观看| 在线观看免费成人| 精品国产成人系列| 亚洲精品视频一区二区| 日本va欧美va精品| 成人一区二区三区在线观看| 一本色道久久综合狠狠躁的推荐| 欧美日韩色综合| 久久夜色精品一区| 亚洲一区二区欧美激情| 国产在线视频一区二区三区| 91麻豆精品在线观看| 一区二区三区四区在线| 亚洲一区二区综合| 国产综合成人久久大片91| 99精品国产99久久久久久白柏| 欧美日本在线一区| 国产精品区一区二区三| 美国三级日本三级久久99| 91视频在线观看免费| 精品第一国产综合精品aⅴ| 亚洲欧美日韩一区二区| 国产一区二区三区四| 欧美日韩黄色一区二区| 国产精品欧美精品| 日韩不卡一区二区| 色狠狠一区二区三区香蕉| 国产亚洲综合性久久久影院| 日韩av电影天堂| 日本道色综合久久| 欧美激情一区二区三区四区| 日本中文字幕一区二区有限公司| 99麻豆久久久国产精品免费优播| 亚洲精品一线二线三线无人区| 一区二区三区四区不卡视频 | 国产+成+人+亚洲欧洲自线| 欧美午夜不卡在线观看免费| 欧美高清在线视频| 国产在线精品免费av| 欧美一区二区视频在线观看2020 | av电影在线观看完整版一区二区| 91精品国产全国免费观看| 亚洲成人综合视频| 欧美专区在线观看一区| 亚洲美女一区二区三区| 一本色道久久综合亚洲aⅴ蜜桃| 欧美国产精品久久| 成人免费视频caoporn| 久久综合九色综合欧美就去吻| 强制捆绑调教一区二区| 在线综合视频播放| 亚洲第一av色| 蜜桃av一区二区| 国产aⅴ精品一区二区三区色成熟| 欧美无砖专区一中文字| 亚洲男女一区二区三区| 色综合色综合色综合色综合色综合 | 99视频一区二区三区| 国产偷国产偷精品高清尤物| 国产乱码精品一区二区三| 久久久久久亚洲综合| 国产精品69毛片高清亚洲| 久久久久国色av免费看影院| 丁香激情综合国产| 亚洲欧美另类在线| 欧美日韩国产一二三| 免费看欧美美女黄的网站| 精品国产乱码久久久久久蜜臀| 韩国欧美国产1区| 国产免费久久精品| 色爱区综合激月婷婷| 亚洲国产成人av好男人在线观看| 欧美日韩国产综合一区二区三区 | 精品中文字幕一区二区小辣椒| 日韩一区二区三免费高清| 精品一区二区三区视频 | 在线观看一区日韩| 日韩国产在线一| www国产成人| 99精品视频一区二区三区| 亚洲成人黄色影院| 久久久精品免费免费| 色婷婷精品大在线视频| 日本aⅴ亚洲精品中文乱码| 国产午夜久久久久| 在线亚洲一区二区| 激情综合网av| 亚洲伦在线观看| 日韩免费在线观看| 色综合天天综合网天天看片| 日本成人在线网站| 国产精品久久久99| 91精品国产91热久久久做人人 | 精品国产乱码久久久久久久| www.欧美.com| 国产在线精品一区二区夜色| 亚洲色图欧美在线| 久久久久国产精品麻豆ai换脸 | 久久91精品国产91久久小草| 中文字幕一区二区日韩精品绯色| 欧美精品日韩一区| 成人高清伦理免费影院在线观看| 奇米色一区二区| 亚洲精品视频在线看| 欧美激情中文字幕一区二区| 欧美一区二区播放| 欧洲亚洲精品在线| 国产 日韩 欧美大片| 激情文学综合丁香| 日韩电影在线看| 亚洲成人中文在线| 1024精品合集| 亚洲欧洲av色图| 中文字幕在线不卡| 国产精品无人区| 中文字幕av一区二区三区免费看| 欧美不卡一二三| 欧美一级黄色录像| 91精品国产福利在线观看| 欧美精三区欧美精三区| 欧美在线看片a免费观看| 色婷婷av一区二区| 91精彩视频在线观看| 91性感美女视频| 91丨九色丨尤物| 91麻豆免费观看| 欧美在线不卡视频| 色噜噜夜夜夜综合网| 色嗨嗨av一区二区三区| 一本大道av伊人久久综合| 不卡一卡二卡三乱码免费网站| 高清在线不卡av| 99免费精品在线观看| 色诱亚洲精品久久久久久| 色狠狠色狠狠综合| 欧美日韩国产一级片| 91精品国产综合久久精品图片| 日韩欧美视频一区| 久久欧美中文字幕| 国产精品成人一区二区艾草| 亚洲免费观看在线视频| 午夜私人影院久久久久| 日韩精品亚洲专区| 国模套图日韩精品一区二区| 国产美女主播视频一区| av亚洲精华国产精华精| 在线观看亚洲a| 日韩一区二区免费在线电影| 久久久国产午夜精品| 综合久久久久综合| 水野朝阳av一区二区三区| 老司机精品视频在线| 成人h动漫精品一区二区| 欧美在线你懂得| 欧美精品一区二区三区高清aⅴ | 亚洲小少妇裸体bbw| 老司机一区二区| 99久久国产免费看| 91精品国产综合久久香蕉麻豆| 国产亚洲制服色| 亚洲成a人片综合在线| 精品一区精品二区高清| 色婷婷激情久久| 久久一区二区三区四区| 玉米视频成人免费看| 国产中文字幕精品| 91在线你懂得| 久久久精品影视| 日韩av网站免费在线| 91免费国产在线| 欧美成人女星排行榜| 亚洲综合男人的天堂| 成人免费黄色大片| 欧美一级片在线看| 亚洲综合在线免费观看| 国产黑丝在线一区二区三区| 欧美日本在线播放| 亚洲美女少妇撒尿| 播五月开心婷婷综合| 久久久久久久久免费| 人人狠狠综合久久亚洲| 在线亚洲+欧美+日本专区| 国产精品久久久久国产精品日日|