婷婷综合国产,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| 欧美色综合网站| 国产在线精品一区二区不卡了| 亚洲国产成人精品视频| 亚洲国产wwwccc36天堂| 丝袜诱惑亚洲看片| 日韩成人精品视频| 久久国产夜色精品鲁鲁99| 国产资源精品在线观看| 国产精品一卡二| 97久久久精品综合88久久| 欧美在线观看视频在线| 91精品免费在线| 久久亚洲一级片| 亚洲视频图片小说| 亚洲第一狼人社区| 国产麻豆91精品| 成人avav影音| 欧美日韩国产天堂| www成人在线观看| 亚洲人成精品久久久久| 日韩电影在线观看网站| 国产激情一区二区三区| 在线观看av不卡| 精品88久久久久88久久久| 国产精品三级电影| 免费高清在线一区| 91无套直看片红桃| 日韩网站在线看片你懂的| 国产精品久久久久aaaa| 日本欧美一区二区三区| 97久久人人超碰| 日韩你懂的在线播放| 亚洲免费观看高清完整| 美腿丝袜亚洲三区| 在线观看一区二区精品视频| 欧美xxxxx牲另类人与| 亚洲你懂的在线视频| 美脚の诱脚舐め脚责91 | 色婷婷精品久久二区二区蜜臀av| 欧美一级黄色录像| 亚洲久本草在线中文字幕| 国产在线精品一区二区三区不卡 | 亚洲一级片在线观看| 韩国中文字幕2020精品| 欧美日韩国产大片| 亚洲欧洲精品成人久久奇米网| 日本系列欧美系列| 在线观看网站黄不卡| 国产精品久久久久久久久搜平片| 蜜臀精品一区二区三区在线观看| 91福利视频在线| 成人欧美一区二区三区白人| 韩国中文字幕2020精品| 日韩午夜中文字幕| 舔着乳尖日韩一区| 欧美色男人天堂| 亚洲综合一二区| 在线免费观看日韩欧美| 亚洲欧美激情插| 91丨九色丨尤物| 国产精品久久三| 成人激情免费视频| 国产人久久人人人人爽| 国产精品一区二区三区99| 久久亚洲综合色一区二区三区 | 亚洲欧美日韩中文播放| 成人晚上爱看视频| 1000部国产精品成人观看| 不卡区在线中文字幕| 中文字幕人成不卡一区| 91蜜桃婷婷狠狠久久综合9色| 欧美国产日韩精品免费观看| 国产精品一区二区果冻传媒| 国产婷婷色一区二区三区四区 | 国产精品久久久久久久久晋中| 国产精品亚洲一区二区三区在线| 久久综合久久综合久久| 成人影视亚洲图片在线| 国产精品护士白丝一区av| 成人动漫一区二区三区| 亚洲精品国产无天堂网2021 | 久久久精品综合| 风间由美中文字幕在线看视频国产欧美| 国产午夜亚洲精品理论片色戒| 福利电影一区二区三区| 亚洲婷婷综合久久一本伊一区| 91福利视频久久久久| 丝袜美腿一区二区三区| 精品国产一区二区精华| 国产成人精品亚洲日本在线桃色 | 日本在线不卡视频一二三区| 日韩亚洲欧美一区| 成人夜色视频网站在线观看| 亚洲久草在线视频| 精品日韩一区二区三区| 成人免费视频app| 婷婷综合另类小说色区| 国产午夜精品一区二区三区视频| 北条麻妃国产九九精品视频| 亚洲一区二区三区视频在线| 26uuu色噜噜精品一区| 91丨九色丨黑人外教| 奇米在线7777在线精品| 亚洲欧洲国产专区| 精品久久久久久久一区二区蜜臀| 成人av电影免费在线播放| 天天综合色天天综合| 欧美—级在线免费片| 精品1区2区3区| 波多野结衣一区二区三区 | 91精品91久久久中77777| 九九**精品视频免费播放| 亚洲欧美日韩国产手机在线| 精品区一区二区| 欧美午夜精品久久久久久超碰| 国产高清在线精品| 免费精品99久久国产综合精品| 国产精品色在线观看| 日韩视频不卡中文| 欧美情侣在线播放| 色综合久久中文字幕综合网 | 日韩国产欧美在线视频| 中文字幕一区免费在线观看| 日韩午夜av电影| 欧美色倩网站大全免费| 97国产一区二区| 成人在线视频首页| 国产精品系列在线观看| 美美哒免费高清在线观看视频一区二区| 亚洲啪啪综合av一区二区三区| 欧美—级在线免费片| 久久亚洲春色中文字幕久久久| 911国产精品| 7777女厕盗摄久久久| 欧美三级电影在线看| 欧美伊人久久久久久久久影院| 成人精品国产免费网站| 国产69精品久久久久毛片| 国产在线精品一区二区不卡了| 麻豆91精品91久久久的内涵| 亚洲成人av在线电影| 日精品一区二区三区| 日韩在线卡一卡二| 日本va欧美va精品发布| 日韩不卡一二三区| 日韩黄色免费电影| 久久精品国产亚洲5555| 国模无码大尺度一区二区三区| 国产在线一区二区| 国产91精品精华液一区二区三区| 成人久久久精品乱码一区二区三区| 风间由美一区二区av101| 99免费精品视频| 色综合 综合色| 欧美日韩激情一区| 日韩欧美资源站| 亚洲国产精品二十页| 中文在线一区二区| 夜夜嗨av一区二区三区网页| 天天综合色天天| 国产精品亚洲综合一区在线观看| 国产91清纯白嫩初高中在线观看 | 亚洲尤物视频在线| 日韩高清不卡一区| 狠狠久久亚洲欧美| 91免费版在线看| 日韩三区在线观看| 国产精品国产三级国产| 午夜久久久久久久久| 国产综合色视频| 色综合久久天天| 欧美第一区第二区| 中文字幕亚洲综合久久菠萝蜜| 午夜精品一区二区三区电影天堂| 老司机免费视频一区二区| va亚洲va日韩不卡在线观看| 欧美精品在欧美一区二区少妇| 久久人人97超碰com| 一区二区三区四区激情 | 成人免费小视频| 婷婷成人激情在线网| 不卡电影免费在线播放一区| 欧美日韩高清影院| 国产精品污www在线观看| 日韩精品电影在线| 成人av网在线| 亚洲精品一区二区三区精华液| 日韩美女啊v在线免费观看| 美女脱光内衣内裤视频久久网站| 91网站在线观看视频| 欧美电影免费观看高清完整版在| 亚洲免费高清视频在线| 国产伦精品一区二区三区在线观看| 在线区一区二视频| 国产日韩欧美在线一区| 亚洲成人av电影在线| 色综合一个色综合| 亚洲国产精品精华液2区45| 美女在线视频一区|