婷婷综合国产,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
    国产精品夜夜嗨| 日韩一级免费一区| 麻豆视频观看网址久久| 亚洲色图色小说| 国产欧美精品国产国产专区| 日韩三级.com| 亚洲在线一区二区三区| 裸体在线国模精品偷拍| av电影天堂一区二区在线| 国产精品你懂的| 播五月开心婷婷综合| 亚洲超碰精品一区二区| av男人天堂一区| 欧美一区二区三区免费大片| 国产精品午夜免费| 丝袜美腿亚洲综合| 国产综合久久久久影院| 日韩三区在线观看| 亚洲一区二区高清| www.日韩在线| 国产精品电影一区二区| 国产精品77777| 国产亚洲一本大道中文在线| 精品一区二区三区在线观看国产| 国产日韩精品久久久| 久久精品72免费观看| 欧美亚洲综合在线| 亚洲午夜精品在线| 日韩欧美中文字幕一区| 国产在线国偷精品产拍免费yy| 精品电影一区二区| 不卡的电影网站| 亚洲午夜久久久久中文字幕久| 欧美精品丝袜久久久中文字幕| 国内精品第一页| 洋洋成人永久网站入口| 精品剧情v国产在线观看在线| 精品写真视频在线观看| 丝瓜av网站精品一区二区| 国产亚洲综合色| 欧美一区二区三区白人| av电影一区二区| 麻豆精品一区二区av白丝在线| 国产清纯白嫩初高生在线观看91| 欧美日韩亚洲综合一区二区三区| 国产一区二区三区日韩| 日韩一区二区三区免费看| 91精品国产乱| 精品视频一区 二区 三区| 丁香激情综合国产| 国产一区二区网址| 石原莉奈在线亚洲二区| 一区二区欧美在线观看| 国产精品美女久久久久久久网站| 日韩一级大片在线| 日韩欧美国产精品| 91精品福利在线一区二区三区| 91丨porny丨在线| 风流少妇一区二区| 国内精品久久久久影院薰衣草| 麻豆精品久久精品色综合| 丝袜美腿亚洲综合| 本田岬高潮一区二区三区| 国产91丝袜在线播放| 波多野结衣在线一区| 一本久久a久久精品亚洲| 精品视频在线看| 欧美精品一区二区三区一线天视频| 精品国精品自拍自在线| 中文字幕一区二区三区蜜月| 亚洲国产毛片aaaaa无费看| 国内一区二区在线| 91国产丝袜在线播放| 久久综合色播五月| 一区二区三区在线观看动漫| 蜜臀av一区二区在线免费观看| 久久99蜜桃精品| 欧美日韩亚洲综合一区| 国产精品丝袜一区| 久久se精品一区二区| 9色porny自拍视频一区二区| 欧美区在线观看| 最新中文字幕一区二区三区| 国产精品激情偷乱一区二区∴| 亚洲天堂网中文字| 粉嫩蜜臀av国产精品网站| 国产精品欧美综合在线| 久久蜜桃一区二区| 一区二区免费视频| 不卡电影一区二区三区| 555www色欧美视频| 欧美国产成人精品| 肉丝袜脚交视频一区二区| 国产米奇在线777精品观看| 91天堂素人约啪| 国产亚洲精品精华液| 日本欧美一区二区在线观看| 国产成人精品免费网站| 精品久久久久久久久久久院品网| 亚洲精品乱码久久久久久久久| 国产乱子伦视频一区二区三区| 91美女片黄在线观看| 国产精品网站在线| 国产麻豆日韩欧美久久| 欧美日韩成人综合在线一区二区| 自拍偷拍欧美精品| 成人激情黄色小说| 国产精品免费看片| 94-欧美-setu| 亚洲人成网站影音先锋播放| 国产精品一区二区不卡| 久久久久国产一区二区三区四区| 天天影视涩香欲综合网| 欧美一区二区三区性视频| 免费人成在线不卡| 精品国产乱码久久久久久图片| 日本va欧美va瓶| 久久久噜噜噜久噜久久综合| 国产二区国产一区在线观看| 国产免费观看久久| 在线观看亚洲精品| 蜜桃精品在线观看| 中文字幕一区二区视频| 欧美日韩一区在线观看| 黄色成人免费在线| 亚洲欧美日韩中文播放| 日韩欧美另类在线| 中文在线一区二区| 不卡一区中文字幕| 日韩在线一区二区| 久久久天堂av| 欧洲色大大久久| 成人av网址在线| 国产在线一区二区| 免费看欧美女人艹b| 亚洲视频图片小说| 日韩免费电影网站| 欧美sm极限捆绑bd| 欧美一区二区私人影院日本| 91视频在线看| 不卡一区二区三区四区| 粉嫩av一区二区三区粉嫩 | 欧亚洲嫩模精品一区三区| 成人h精品动漫一区二区三区| av一二三不卡影片| 国产精品996| a4yy欧美一区二区三区| 99国产精品久久久久久久久久久| 国产福利一区二区三区视频在线| 国产精品综合视频| 成人国产精品免费观看视频| 成人97人人超碰人人99| 国产91丝袜在线播放九色| 高清在线不卡av| 91豆麻精品91久久久久久| 欧美色中文字幕| 日韩欧美美女一区二区三区| 日韩免费看的电影| 亚洲人成网站色在线观看| 一级做a爱片久久| 国产精选一区二区三区| 日本精品一级二级| 26uuu国产一区二区三区| 一区二区三区免费在线观看| 精品一区二区在线看| 91网站在线播放| 国产调教视频一区| 性欧美疯狂xxxxbbbb| 国产69精品久久久久毛片| 91色porny在线视频| 精品国一区二区三区| 亚洲成av人影院在线观看网| 亚洲品质自拍视频网站| 国产xxx精品视频大全| 91精品国产91热久久久做人人 | 国产成人丝袜美腿| 欧美一区二区福利在线| 亚洲男人的天堂av| 国产成人a级片| 国产精品黄色在线观看| 成人综合婷婷国产精品久久| 国产亚洲精品中文字幕| 国产成人在线看| 久久精品人人做人人爽人人 | 天天综合色天天| 欧美亚男人的天堂| 男女视频一区二区| 国产欧美日产一区| 色婷婷国产精品久久包臀 | 国产偷国产偷亚洲高清人白洁 | 免费的成人av| 日韩欧美亚洲另类制服综合在线| 精品亚洲国内自在自线福利| 精品国产精品一区二区夜夜嗨| 日韩成人精品视频| 国产三级一区二区三区| 91在线视频在线| 免费看欧美女人艹b| 亚洲精品欧美二区三区中文字幕| 欧美性做爰猛烈叫床潮|