婷婷综合国产,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一区二区三区| 中文字幕va一区二区三区| 国产色91在线| 中文字幕一区三区| 亚洲日本在线看| 亚洲乱码国产乱码精品精的特点| 亚洲天堂2016| 亚洲主播在线播放| 日韩不卡手机在线v区| 全国精品久久少妇| 激情综合色丁香一区二区| 蜜桃久久久久久| 国产一区亚洲一区| 粉嫩高潮美女一区二区三区| 色先锋aa成人| 制服丝袜亚洲精品中文字幕| 日韩精品一区二区在线| 国产欧美日韩麻豆91| 亚洲精品国产a| 日韩av电影免费观看高清完整版 | 国产一区二区成人久久免费影院 | 日本精品一区二区三区四区的功能| 91麻豆免费看| 日韩一二三区视频| 久久影院午夜论| 亚洲欧洲另类国产综合| 一区二区三区免费在线观看| 日韩不卡免费视频| 成人av综合一区| 欧美久久久一区| 久久精品亚洲精品国产欧美| 亚洲一区二区三区三| 久久国产精品无码网站| av一区二区三区| 欧美岛国在线观看| 1区2区3区国产精品| 久草中文综合在线| 色综合激情五月| 久久精品免费在线观看| 亚洲在线视频免费观看| 国产在线播放一区| 欧美美女一区二区在线观看| 国产精品国产自产拍高清av| 青青草成人在线观看| 91热门视频在线观看| 国产亚洲成av人在线观看导航| 午夜亚洲国产au精品一区二区| 国产不卡一区视频| 日韩欧美电影一二三| 亚洲线精品一区二区三区| 国产a区久久久| 欧美成人国产一区二区| 偷拍日韩校园综合在线| 一本色道久久综合狠狠躁的推荐| 久久久久88色偷偷免费| 日精品一区二区三区| 色天天综合久久久久综合片| 中文字幕成人在线观看| 国产精品乡下勾搭老头1| 日韩一区二区电影网| 视频在线观看91| 欧美久久久久中文字幕| 亚洲风情在线资源站| 色婷婷综合视频在线观看| 国产精品区一区二区三| 国产激情一区二区三区四区| 26uuu另类欧美| 国产盗摄视频一区二区三区| 久久久不卡网国产精品二区| 国产精品综合二区| 久久久久久一级片| 国产黄人亚洲片| 久久精品欧美一区二区三区不卡| 国产一区二区在线电影| 精品久久久久久久人人人人传媒 | 国产一区二区主播在线| 精品日产卡一卡二卡麻豆| 裸体一区二区三区| 欧美成人video| 国产一区二区三区观看| 国产日韩高清在线| av资源网一区| 亚洲最新在线观看| 欧美区在线观看| 韩国女主播成人在线观看| 国产午夜亚洲精品羞羞网站| 国产成人在线看| 亚洲欧美国产77777| 欧美体内she精视频| 美腿丝袜亚洲综合| 亚洲国产精品精华液2区45| 99久久久精品免费观看国产蜜| 亚洲一区二区三区四区在线观看 | 亚洲午夜久久久久久久久电影网 | 久久精品久久久精品美女| 精品国产露脸精彩对白 | 亚洲人精品午夜| 欧美日韩国产电影| 久久精品国产亚洲aⅴ | 日本美女一区二区| 亚洲精品一区在线观看| av激情综合网| 日韩电影在线免费看| 久久精品亚洲精品国产欧美 | 久久午夜老司机| 一本久道久久综合中文字幕| 午夜成人免费电影| 久久久久国产精品麻豆| 欧美专区在线观看一区| 国产一区二区三区免费观看| 亚洲欧美日韩国产成人精品影院| 日韩欧美自拍偷拍| 一本大道久久a久久精品综合| 蜜臀av在线播放一区二区三区| 国产精品天天摸av网| 欧美一级片免费看| 91免费精品国自产拍在线不卡| 久久99久久99| 亚洲最大成人综合| 国产免费成人在线视频| 欧美午夜精品一区二区蜜桃| 国产精品123| 日韩av中文在线观看| 亚洲毛片av在线| 国产日韩欧美制服另类| 欧美一级理论片| 色菇凉天天综合网| 粉嫩蜜臀av国产精品网站| 麻豆精品视频在线观看视频| 一区av在线播放| 国产精品久久久久婷婷二区次| 精品嫩草影院久久| 欧美肥妇bbw| 欧美日本国产视频| 欧美亚洲国产bt| 色婷婷综合在线| 97久久超碰国产精品电影| 成人性色生活片免费看爆迷你毛片| 久久精品国产亚洲一区二区三区| 天堂一区二区在线| 亚洲一区国产视频| 亚洲精品中文字幕在线观看| 国产精品国产三级国产普通话99| 久久综合五月天婷婷伊人| 日韩欧美国产综合在线一区二区三区| 在线观看视频一区| 色丁香久综合在线久综合在线观看| 91亚洲精品久久久蜜桃网站| 99久久婷婷国产综合精品电影 | 欧美人与z0zoxxxx视频| 在线观看一区不卡| 在线观看av不卡| 欧美视频中文字幕| 欧美日韩亚州综合| 欧美一区二区三区在线| 91精品国产色综合久久ai换脸 | 亚洲精品国产a久久久久久| 中文字幕日韩精品一区 | 欧美精品一区二区三区在线播放 | 久久久久久久网| 久久久影视传媒| 中文字幕中文字幕在线一区| 一区二区三区成人在线视频| 五月天婷婷综合| 麻豆精品视频在线观看免费| 国产精品99久久久久久久vr| 不卡的电影网站| 日本韩国一区二区三区视频| 欧美日韩精品三区| 日韩一级成人av| 国产精品系列在线| 亚洲一区二区三区小说| 久久99国产精品免费| 成人免费视频视频| 日本精品一区二区三区四区的功能| 欧美人妇做爰xxxⅹ性高电影| 2023国产精品| 亚洲精品国产无套在线观| 日日摸夜夜添夜夜添国产精品 | 丰满放荡岳乱妇91ww| 色综合天天综合网国产成人综合天| 欧美日韩大陆在线| 久久久国产一区二区三区四区小说 | 欧美激情一区二区| 亚洲欧美日韩久久| 国产一区二区在线看| 欧美又粗又大又爽| 国产日韩成人精品| 奇米精品一区二区三区在线观看 | 久久99精品一区二区三区| 99精品欧美一区二区蜜桃免费| 欧美一区二区三区免费观看视频| 国产精品免费视频观看| 男人的j进女人的j一区| 91丨porny丨最新| 精品噜噜噜噜久久久久久久久试看|