婷婷综合国产,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
    国产精品久久久久久久久免费樱桃 | 欧美色综合影院| 国产美女一区二区| 久久超碰97中文字幕| 日本伊人精品一区二区三区观看方式| 亚洲一区二区在线免费观看视频| 亚洲精品成人天堂一二三| 国产精品你懂的在线| 中文字幕av资源一区| 国产精品剧情在线亚洲| 最新国产精品久久精品| 亚洲激情在线激情| 亚洲成人1区2区| 久久福利资源站| 激情综合色综合久久| 国产一区二区美女| 成人av电影观看| 91精彩视频在线观看| 欧美精品一级二级三级| 欧美刺激脚交jootjob| 欧美国产视频在线| 亚洲午夜免费电影| 看片网站欧美日韩| 成人丝袜高跟foot| 欧美视频你懂的| 精品国产91乱码一区二区三区| 日本一区二区三区dvd视频在线| 亚洲欧美视频在线观看| 日本三级亚洲精品| 成人精品在线视频观看| 欧美在线观看一区二区| 日韩精品自拍偷拍| 亚洲色图制服丝袜| 国产在线乱码一区二区三区| 91丨九色丨蝌蚪富婆spa| 欧美日韩大陆一区二区| 国产日韩欧美电影| 午夜精品久久久久影视| 粉嫩欧美一区二区三区高清影视| 欧美写真视频网站| 欧美精彩视频一区二区三区| 五月婷婷久久丁香| 99国内精品久久| 久久综合久色欧美综合狠狠| 亚洲五码中文字幕| 国产成人午夜99999| 欧美精品久久99| 亚洲私人影院在线观看| 国产精品资源网站| 在线播放亚洲一区| 尤物在线观看一区| 成人免费电影视频| 2020国产精品自拍| 蜜桃视频免费观看一区| 91欧美激情一区二区三区成人| 久久理论电影网| 免费看日韩a级影片| 色婷婷av一区二区三区软件| 久久久久一区二区三区四区| 免费看欧美女人艹b| 欧美日韩一区二区三区高清 | 99久久国产综合精品女不卡| 精品国产伦一区二区三区免费| 性久久久久久久久| 在线亚洲一区观看| 亚洲美女偷拍久久| av在线不卡免费看| 国产精品看片你懂得| 成人小视频免费在线观看| 精品sm捆绑视频| 九九**精品视频免费播放| 日韩欧美一区在线| 免费观看30秒视频久久| 日韩欧美在线观看一区二区三区| 日韩精品午夜视频| 欧美日韩午夜影院| 免费观看成人鲁鲁鲁鲁鲁视频| 91麻豆精品国产| 五月激情丁香一区二区三区| 欧美日韩精品欧美日韩精品一| 亚洲午夜三级在线| 91精品国产综合久久精品图片| 亚洲成人一区二区在线观看| 欧美午夜精品免费| 天堂蜜桃一区二区三区| 欧美日韩亚洲高清一区二区| 蜜桃在线一区二区三区| www国产精品av| av中文字幕一区| 亚洲一区在线看| 91精品视频网| 国内不卡的二区三区中文字幕| 久久婷婷一区二区三区| 成人高清伦理免费影院在线观看| 亚洲三级理论片| 欧美日韩精品二区第二页| 免费人成精品欧美精品| 国产欧美日韩另类一区| 91福利区一区二区三区| 日本欧美加勒比视频| 久久久久久一二三区| 色综合久久久久久久久| 蜜桃免费网站一区二区三区| 国产女人aaa级久久久级| 在线精品视频小说1| 看电视剧不卡顿的网站| 亚洲欧美日韩中文播放 | 欧美色男人天堂| 九九视频精品免费| 亚洲三级理论片| 91精品国产aⅴ一区二区| www.视频一区| 蜜臀久久99精品久久久久宅男 | 欧美日韩在线直播| 国产精品综合一区二区三区| 亚洲欧美成aⅴ人在线观看| 欧美成人激情免费网| 91丝袜国产在线播放| 精品一区二区三区在线播放视频 | 日本va欧美va欧美va精品| 欧美国产精品劲爆| 日韩三级av在线播放| 色偷偷88欧美精品久久久| 国产在线国偷精品产拍免费yy| 亚洲综合久久久久| 国产精品国产精品国产专区不蜜| 日韩欧美一区二区三区在线| 91精品福利视频| 99re视频精品| 成人午夜免费av| 国产麻豆精品在线| 九九视频精品免费| 日本欧美一区二区三区| 香蕉久久一区二区不卡无毒影院| 中文字幕免费在线观看视频一区| 欧美一级在线视频| 在线观看91av| 欧美另类z0zxhd电影| 欧美日韩另类一区| 在线观看欧美精品| 色欧美片视频在线观看在线视频| 成人精品电影在线观看| 成人黄色免费短视频| 高清成人免费视频| 国产精品 欧美精品| 国产一区二区三区黄视频| 国产又粗又猛又爽又黄91精品| 日本va欧美va欧美va精品| 石原莉奈在线亚洲三区| 亚洲国产精品久久不卡毛片| 亚洲黄色免费网站| 亚洲一卡二卡三卡四卡| 亚洲一区在线播放| 日韩精品久久久久久| 午夜久久久久久| 日韩国产在线一| 免费高清视频精品| 国产一区二区三区在线看麻豆| 久久99精品国产91久久来源| 国产一区二区三区免费观看| 国产成人自拍网| 99久久夜色精品国产网站| 一本色道亚洲精品aⅴ| 欧美日韩亚洲综合| 日韩精品一区国产麻豆| 久久嫩草精品久久久久| 亚洲日本护士毛茸茸| 午夜欧美电影在线观看| 久久se精品一区二区| 国产69精品久久久久毛片| 97精品久久久久中文字幕| 欧美精品色一区二区三区| 精品日韩av一区二区| 欧美国产日本视频| 亚洲一区二区三区在线播放| 日韩高清不卡一区二区三区| 国产精品一级片| 欧美日韩午夜精品| 久久久精品tv| 亚洲综合一二三区| 韩国精品主播一区二区在线观看| www.欧美色图| 欧美一卡2卡3卡4卡| 中文字幕精品一区二区三区精品| 一区二区三区久久| 国产毛片精品国产一区二区三区| 在线观看亚洲a| 久久久91精品国产一区二区三区| 亚洲色图欧洲色图婷婷| 老鸭窝一区二区久久精品| 色婷婷精品大在线视频| 久久久.com| 美女视频免费一区| 一本大道久久a久久综合| 久久伊99综合婷婷久久伊| 亚洲影院久久精品| 成人理论电影网| 久久综合久久99| 秋霞国产午夜精品免费视频| 91免费观看视频|