婷婷综合国产,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看片淫黄大片一级在线观看| 亚洲日本在线看| 91精品国产综合久久久久久久久久 | 欧美日韩一区视频| 欧美老女人在线| 97se亚洲国产综合自在线| 久久成人av少妇免费| 日韩av在线发布| 国产一区二区在线观看视频| 极品少妇一区二区三区精品视频| 亚洲国产精品影院| 久久99久久久欧美国产| 青青草91视频| 99久久婷婷国产综合精品| 欧美视频中文字幕| 久久综合九色综合欧美就去吻| 欧美成人高清电影在线| 中文字幕欧美日本乱码一线二线| 国产精品久久久久久久久图文区| 国产精品无遮挡| 亚洲成人1区2区| 国产精品一区二区在线观看网站| 国产999精品久久| 91亚洲国产成人精品一区二区三 | 日日夜夜一区二区| 成人伦理片在线| 欧美日韩免费在线视频| 欧美性生活久久| 777午夜精品免费视频| 久久人人爽人人爽| 蜜芽一区二区三区| 91在线国产福利| 成人av免费在线播放| 日韩精品专区在线| 一区二区三区在线观看网站| 亚洲成av人片在线| 在线亚洲一区观看| 亚洲欧美日韩在线不卡| 成人高清在线视频| 亚洲同性gay激情无套| 日本在线不卡一区| 国产精品一区二区久久不卡| 欧美一区二区三区成人| 亚洲aaa精品| 欧美mv和日韩mv国产网站| 婷婷成人激情在线网| 欧美视频一区二区三区四区| 亚洲丝袜精品丝袜在线| 色吊一区二区三区| 日韩毛片在线免费观看| 日本91福利区| 日韩视频123| 粉嫩蜜臀av国产精品网站| 日产欧产美韩系列久久99| 94色蜜桃网一区二区三区| 美女一区二区视频| 亚洲欧美怡红院| 欧美日韩精品免费观看视频| 日本不卡的三区四区五区| 国产亚洲精品精华液| 色婷婷av一区| 国产成人免费视频精品含羞草妖精| 国产喷白浆一区二区三区| 国产精品污www在线观看| 91精品1区2区| 成人av手机在线观看| 亚洲美女在线国产| 亚洲成年人影院| 精品成人一区二区三区四区| 亚洲女子a中天字幕| 亚洲国产精品激情在线观看| 在线视频欧美精品| 色综合天天做天天爱| 精东粉嫩av免费一区二区三区| 亚洲精品国久久99热| 久久女同精品一区二区| 久久综合九色综合97婷婷女人| 麻豆精品在线视频| 亚洲h在线观看| 性欧美大战久久久久久久久| 亚洲免费资源在线播放| 一区二区免费在线播放| 欧美一区二区三区视频在线| 欧美做爰猛烈大尺度电影无法无天| 色综合久久中文字幕| 成人app在线观看| 色8久久精品久久久久久蜜| 成人午夜电影小说| 成人性视频免费网站| 奇米精品一区二区三区在线观看一| 欧美一级专区免费大片| 午夜天堂影视香蕉久久| 天天色 色综合| 国产成人午夜精品影院观看视频| 成人福利视频在线| 2欧美一区二区三区在线观看视频| 一区二区三区日韩欧美精品| 欧美刺激午夜性久久久久久久 | 亚洲一区二区黄色| 丰满少妇在线播放bd日韩电影| 91蝌蚪porny| 欧美电视剧在线看免费| 国产精品久久久一区麻豆最新章节| 中文乱码免费一区二区| 婷婷综合五月天| 色婷婷av一区| 国产一区在线不卡| 在线成人小视频| 国产精品久久国产精麻豆99网站| 国产精品国产自产拍高清av| 风间由美一区二区三区在线观看| 国产一区二区精品久久| 欧美日韩综合一区| 国产午夜精品久久久久久免费视 | 日韩毛片在线免费观看| 国产传媒欧美日韩成人| 日韩一级完整毛片| 午夜精品福利一区二区三区蜜桃| 久久久99久久| 99视频超级精品| 一区二区久久久久| 91精品一区二区三区久久久久久 | 日本一区二区三区四区| 自拍偷拍国产亚洲| 99国产精品国产精品毛片| 91精品国产手机| 久久久影院官网| 成人性生交大合| 亚洲天堂2016| 精品电影一区二区| 99re热这里只有精品视频| 亚洲国产一区二区在线播放| 欧美日韩一区在线| 中文字幕一区二区在线观看| 在线看国产一区| 国产成人综合自拍| 一区二区三区免费在线观看| 精品久久久久99| 欧美最猛性xxxxx直播| 亚洲一区视频在线观看视频| 久久亚洲精精品中文字幕早川悠里| 99热精品国产| www.欧美亚洲| 高清不卡在线观看av| 蜜桃av一区二区三区电影| 亚洲三级电影全部在线观看高清| 日韩三级.com| 日韩欧美一区二区不卡| 99r国产精品| 亚洲黄色在线视频| 色伊人久久综合中文字幕| 国产精品综合在线视频| 午夜精品久久久久久久99水蜜桃| 国产精品久久久久桃色tv| 国产三级一区二区| 亚洲丝袜自拍清纯另类| 欧美激情综合五月色丁香小说| 欧美人体做爰大胆视频| 欧美日韩一区 二区 三区 久久精品| 91亚洲精品乱码久久久久久蜜桃| 不卡视频一二三四| 色综合天天视频在线观看| 色国产综合视频| 日韩三级视频在线看| 久久一区二区三区国产精品| 亚洲最大成人综合| 国产不卡在线视频| 日韩午夜精品视频| 678五月天丁香亚洲综合网| 一区二区三区中文免费| 国产精品99久久久久久有的能看| 久久久国产精品不卡| 亚洲三级在线观看| 亚洲v中文字幕| 国产无人区一区二区三区| 亚洲高清免费视频| 日韩一区二区在线看| 国产黄色成人av| 亚洲欧美日韩一区| 欧美va在线播放| av电影天堂一区二区在线| 一区二区在线观看免费| 欧美一区二区三区在线观看视频| 亚洲成av人片在线| 亚洲国产成人私人影院tom| 在线视频欧美精品| 不卡一区二区在线| 日韩黄色片在线观看| 亚洲综合丝袜美腿| 国产呦精品一区二区三区网站| www.成人网.com| 欧美一级精品在线| 国产精品久久久久三级| 青青草国产精品亚洲专区无| 99在线精品一区二区三区| 精品国产制服丝袜高跟| 亚洲精品免费播放| 色婷婷久久一区二区三区麻豆| 麻豆91免费看|