婷婷综合国产,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| 午夜激情综合网| 欧美一区日本一区韩国一区| 一本大道综合伊人精品热热| 成人午夜免费av| 东方aⅴ免费观看久久av| 国产成人三级在线观看| 岛国精品在线播放| 成人网页在线观看| av电影一区二区| 成人免费福利片| 成人深夜视频在线观看| 99视频热这里只有精品免费| 91影院在线免费观看| 色婷婷亚洲婷婷| 欧洲一区二区av| 欧美精品国产精品| 精品少妇一区二区三区在线播放| 日韩欧美一二三| 日韩欧美的一区二区| 久久久精品2019中文字幕之3| 国产日韩成人精品| 亚洲一区二区精品久久av| 无码av中文一区二区三区桃花岛| 日韩电影在线免费观看| 久久99精品国产麻豆婷婷| 国产一区二区三区四区在线观看| 风间由美一区二区三区在线观看| 国产99久久精品| 欧洲人成人精品| 日韩欧美一区二区视频| 国产日韩欧美高清| 一区二区三区在线看| 蜜桃视频在线一区| av亚洲产国偷v产偷v自拍| 欧美一区二区视频网站| 国产欧美一区二区精品婷婷| 亚洲一二三级电影| 国产老妇另类xxxxx| 欧美专区日韩专区| 日本一区二区视频在线| 亚洲高清免费在线| 国产精品影视在线| 欧美色图天堂网| 久久久久久久久岛国免费| 亚洲一区二区三区中文字幕| 国产精品一区三区| 欧美日韩一区成人| 国产精品每日更新在线播放网址 | 精品一区二区在线视频| 99精品国产视频| 精品久久久久久最新网址| 亚洲三级久久久| 国产成人免费高清| 日韩欧美一二区| 亚洲一区二区不卡免费| 91污在线观看| 国产欧美日韩精品a在线观看| 天天操天天色综合| 色诱视频网站一区| 国产欧美日韩视频在线观看| 久久精品国产免费看久久精品| 欧美主播一区二区三区| 国产精品无遮挡| 国产一区二区在线视频| 欧美丰满少妇xxxxx高潮对白| 亚洲日本va在线观看| 国产91丝袜在线18| 精品日产卡一卡二卡麻豆| 麻豆国产精品一区二区三区| 欧美日韩在线观看一区二区| 亚洲特黄一级片| 99精品国产视频| 1024精品合集| 91麻豆精东视频| 国产精品久久久久毛片软件| 成人性生交大片免费看中文| 日本一区二区成人| 成人黄色av网站在线| 欧美激情一区二区| 丁香啪啪综合成人亚洲小说 | 欧美日韩精品欧美日韩精品| 亚洲女性喷水在线观看一区| 99视频有精品| 一区二区久久久久| 欧美日韩亚洲综合在线 | 亚洲乱码国产乱码精品精的特点| eeuss鲁片一区二区三区| 国产欧美一区二区三区在线看蜜臀 | av一区二区不卡| 亚洲日本va在线观看| 欧洲亚洲精品在线| 日本一道高清亚洲日美韩| 欧美大片日本大片免费观看| 国产在线观看免费一区| 欧美高清一级片在线观看| 9色porny自拍视频一区二区| 亚洲欧洲日产国码二区| 色88888久久久久久影院按摩 | 欧美高清视频一二三区 | 中文字幕在线观看一区| 91在线你懂得| 天天综合网天天综合色| 精品日韩一区二区三区免费视频| 国产91富婆露脸刺激对白| 亚洲色图一区二区三区| 欧美日韩在线一区二区| 国产中文字幕精品| 一区二区三区电影在线播| 91精品国产综合久久久蜜臀图片| 另类中文字幕网| 亚洲欧美日韩一区| 911精品国产一区二区在线| 国产一区二区久久| 一区二区三区四区不卡在线 | 欧美激情综合网| 色丁香久综合在线久综合在线观看| 偷偷要91色婷婷| 中文字幕欧美三区| 91精品国产欧美一区二区成人 | 国产精品电影院| 91精品国产福利在线观看| 99精品视频一区二区三区| 精品一区二区在线免费观看| 亚洲最大的成人av| 国产精品国产三级国产有无不卡 | 本田岬高潮一区二区三区| 亚洲国产欧美在线| 国产精品天天摸av网| 欧美人xxxx| 成人精品一区二区三区四区| 日韩av电影免费观看高清完整版 | 午夜激情久久久| 国产精品家庭影院| 久久人人爽人人爽| 日韩一区二区三区av| 欧美影视一区在线| 91视频一区二区| 成人免费高清在线观看| 国产一区二区三区四区五区美女| 日韩电影一区二区三区四区| 亚洲女同一区二区| 亚洲日本在线a| 亚洲欧洲精品一区二区三区不卡| 亚洲精品在线三区| 日韩午夜在线观看视频| 欧美在线观看禁18| 在线观看91视频| 欧美亚洲自拍偷拍| 欧美日韩不卡视频| 91精品视频网| 日韩欧美激情在线| 日韩视频在线一区二区| 欧美精品在线观看一区二区| 精品视频免费看| 欧美性一二三区| 欧洲一区二区三区免费视频| 色综合久久88色综合天天| 色视频成人在线观看免| 色综合婷婷久久| 一本一道久久a久久精品 | 久久在线免费观看| 欧美精品一区二区三区一线天视频| 日韩一级片在线观看| 日韩手机在线导航| 国产网站一区二区| 亚洲欧美在线观看| 亚洲一区影音先锋| 日韩精品一级二级 | 久久成人免费网| 国产乱色国产精品免费视频| 岛国精品一区二区| 日本乱人伦一区| 日韩欧美中文字幕公布| 国产欧美一区二区三区在线看蜜臀| 中文字幕日韩一区二区| 亚洲午夜在线视频| 久国产精品韩国三级视频| 高清国产一区二区| 欧美午夜免费电影| 欧美精品一区二区三区四区 | 国产精品电影院| 亚洲成精国产精品女| 精品一区二区久久久| www.亚洲免费av| 欧美日韩精品一区视频| 国产欧美日韩在线| 日欧美一区二区| 成人性生交大片免费看中文| 欧美日韩小视频| 国产精品欧美极品| 免费在线看成人av| 91在线视频观看| 久久久久久久国产精品影院| 亚洲h在线观看| 国产一区二三区好的| 欧美高清精品3d| 亚洲男人的天堂在线观看| 久久99国产精品久久99果冻传媒| 日本高清成人免费播放|