婷婷综合国产,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
    高清shemale亚洲人妖| 亚洲人123区| 日韩精品一级二级| 国内精品国产成人| 亚洲一区二区影院| 国产精品 日产精品 欧美精品| 国产在线精品一区二区不卡了| 欧美精品1区2区3区| 久久久99精品久久| 欧美日韩久久不卡| 玉米视频成人免费看| 国产精品嫩草影院av蜜臀| 91精品国产综合久久久久| 精品国偷自产国产一区| 玉足女爽爽91| 国产不卡视频在线观看| 国产欧美日本一区二区三区| 亚洲欧美另类久久久精品2019| 99精品视频在线观看| 日韩欧美一二三| 一区免费观看视频| 国产高清亚洲一区| 色老汉一区二区三区| 91精品国产一区二区人妖| 99久久精品99国产精品 | 肉丝袜脚交视频一区二区| 肉肉av福利一精品导航| 国产一区二区三区精品视频| 欧美亚洲动漫制服丝袜| 国产欧美一区二区三区网站 | 成人爽a毛片一区二区免费| 在线日韩一区二区| 久久影院午夜论| 日本在线不卡视频| 欧美色视频在线观看| 亚洲激情综合网| 91视频你懂的| 久久久久国产精品厨房| 91美女在线观看| 亚洲国产激情av| 激情小说欧美图片| 91.xcao| 国产三区在线成人av| 一区二区欧美在线观看| 国产高清在线精品| 日韩精品一区二区三区视频| 麻豆一区二区三区| 欧美视频自拍偷拍| 午夜精品影院在线观看| 日本韩国欧美一区| 欧美一级日韩不卡播放免费| 亚洲午夜一区二区| 亚洲精品免费在线观看| 国产自产2019最新不卡| 日本成人在线网站| 国产欧美一区二区精品性色| 亚洲一区二区三区在线看| 韩国欧美一区二区| 97久久精品人人做人人爽| 久久亚洲欧美国产精品乐播 | av电影天堂一区二区在线| 久久综合狠狠综合久久激情| 精品国产伦一区二区三区免费| 韩国精品一区二区| 久久精品在这里| 国产欧美一区二区精品性| 不卡视频一二三| 日韩国产欧美一区二区三区| 日韩精品一区二区三区四区视频 | 欧美亚洲一区二区在线观看| 亚洲成人av福利| 高清国产午夜精品久久久久久| 欧美日韩成人综合| 久久99国产精品麻豆| 99久久综合狠狠综合久久| 亚洲亚洲精品在线观看| av在线综合网| 久久精品视频网| 国产精一区二区三区| 欧美日韩在线免费视频| 日韩激情中文字幕| 久久美女高清视频 | 精品国产麻豆免费人成网站| 成人动漫一区二区在线| 日韩电影在线免费看| 欧美国产激情二区三区| 欧美三级在线播放| 国产精品12区| 日韩精品一二三区| 亚洲精品乱码久久久久久| 精品国产免费视频| 中文字幕一区日韩精品欧美| 日韩亚洲欧美高清| 91在线播放网址| 久久99热狠狠色一区二区| 久久九九99视频| 日韩精品一区二区三区四区视频| 国产欧美一区二区精品婷婷| 亚洲成a人在线观看| 国产精品美女www爽爽爽| 国产亚洲精品久| 日韩欧美国产1| 欧美国产精品v| 久久久久久久综合日本| 一区二区在线电影| 亚洲男人的天堂在线aⅴ视频| 丁香一区二区三区| 国内精品国产三级国产a久久| 久久亚洲一级片| 亚洲综合精品久久| 26uuu国产日韩综合| 一本到三区不卡视频| 亚洲一级在线观看| 日韩一区二区三区四区五区六区 | av中文一区二区三区| 国产91精品精华液一区二区三区 | 国产资源精品在线观看| 在线观看视频一区二区| 91在线国产福利| 精品久久国产97色综合| 在线综合+亚洲+欧美中文字幕| 国产欧美一区二区三区鸳鸯浴| 国产午夜亚洲精品午夜鲁丝片 | 色婷婷亚洲一区二区三区| 日韩欧美二区三区| 国产日韩av一区二区| 国产精品的网站| 久久不见久久见中文字幕免费| 久久精品国产999大香线蕉| 国产精品久久久久久妇女6080| 欧美一二区视频| 欧美丰满少妇xxxbbb| 欧美日韩视频在线观看一区二区三区| 在线免费观看成人短视频| 99精品偷自拍| 91精品国产欧美日韩| 欧美哺乳videos| 久久精品欧美日韩| 亚洲精品亚洲人成人网| 蜜桃一区二区三区在线观看| 免费看日韩a级影片| 国产成人精品综合在线观看| 91蜜桃网址入口| 欧美日韩精品高清| 精品欧美乱码久久久久久1区2区| 99国产精品久| 日韩午夜精品视频| 国产精品白丝在线| 一区二区欧美精品| 国产一区二区美女| 麻豆精品一区二区av白丝在线| 欧美亚洲禁片免费| 亚洲一区二区三区视频在线| 亚洲欧美激情插| 国产精品动漫网站| 日韩欧美视频在线 | 五月综合激情网| 国产永久精品大片wwwapp| 丁香六月久久综合狠狠色| 欧美亚洲国产怡红院影院| 久久久www成人免费毛片麻豆| 综合激情网...| 国产一区二区三区黄视频| 欧美日韩激情一区二区| 国产午夜亚洲精品不卡| 久久精品999| 91成人免费电影| 久久精品日韩一区二区三区| 亚洲一区二区欧美日韩| 国产成人在线网站| 欧美日韩精品一区二区三区蜜桃| 中文久久乱码一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅| 色呦呦国产精品| 欧美高清在线一区二区| 激情文学综合丁香| 国精产品一区一区三区mba视频| 韩国一区二区视频| 色综合天天综合| 26uuu亚洲| 欧美α欧美αv大片| 亚洲另类色综合网站| 一区二区三区产品免费精品久久75| 久久电影国产免费久久电影| 在线一区二区三区做爰视频网站| 日本欧美肥老太交大片| 亚洲第一主播视频| 午夜电影一区二区三区| 欧美精品自拍偷拍| 欧美大度的电影原声| 午夜激情一区二区三区| 91亚洲男人天堂| 欧美国产日韩亚洲一区| 国产一区在线观看视频| 久久久精品影视| 欧美xxxxxxxx| 国产精品中文欧美| 国产精品久久久一区麻豆最新章节| 久久av中文字幕片| 国产欧美日韩视频一区二区|