婷婷综合国产,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| 亚洲精选在线视频| 中文字幕第一区综合| 国产欧美一区二区三区在线老狼| 久久精品免费在线观看| 国产亚洲午夜高清国产拍精品| 91精品国产入口| 欧美一区二区久久久| 欧美一级搡bbbb搡bbbb| 精品免费国产一区二区三区四区| 久久综合九色综合久久久精品综合 | 欧美经典一区二区| 国产精品天干天干在观线| 亚洲人成网站影音先锋播放| 洋洋av久久久久久久一区| 日韩和欧美一区二区| 久久99久久久久久久久久久| 国产精品一区二区在线观看网站| 成人久久18免费网站麻豆 | 欧美极品另类videosde| 日本一区二区动态图| 亚洲综合激情网| 久久国产人妖系列| 99久久久精品| 日韩亚洲国产中文字幕欧美| 日本一区二区不卡视频| 亚洲国产日日夜夜| 国产精品99久久久久久有的能看| 色噜噜狠狠色综合欧洲selulu| 欧美一区日韩一区| 综合欧美亚洲日本| 久久99热这里只有精品| 91麻豆国产香蕉久久精品| 日韩欧美专区在线| 一区二区三国产精华液| 寂寞少妇一区二区三区| 欧美伊人精品成人久久综合97| 欧美一级日韩免费不卡| 亚洲女厕所小便bbb| 国产一区二区91| 欧美日韩国产三级| 亚洲欧美一区二区三区久本道91 | 久久久久久久综合狠狠综合| 一区二区日韩av| 成人自拍视频在线观看| 欧美电视剧免费观看| 亚洲美女精品一区| 成人国产精品免费观看| 欧美大片在线观看一区二区| 亚洲福利电影网| 91偷拍与自偷拍精品| 久久综合丝袜日本网| 日韩精品电影一区亚洲| 日本道精品一区二区三区| 国产精品美女久久久久久久久久久| 老司机免费视频一区二区三区| 欧美图片一区二区三区| 亚洲欧美日韩久久| 99这里都是精品| 国产精品久久久久久久久久免费看| 精品制服美女丁香| 日韩美女在线视频| 男女男精品视频网| 91精品国产91久久综合桃花| 亚洲一区日韩精品中文字幕| 91成人网在线| 一区二区三区精品视频在线| 91香蕉视频污在线| 亚洲色图在线视频| 色综合久久99| 一区二区三区免费| 欧美日韩另类国产亚洲欧美一级| 一区二区三区四区不卡在线| 在线免费观看视频一区| 亚洲综合视频网| 欧美日本在线播放| 男女视频一区二区| 精品成人佐山爱一区二区| 国产美女精品人人做人人爽 | 99精品偷自拍| 亚洲精品国产品国语在线app| 一本一本大道香蕉久在线精品 | 国产精品66部| 国产精品家庭影院| 欧美天堂一区二区三区| 亚洲国产欧美另类丝袜| 欧美日韩视频专区在线播放| 视频在线观看国产精品| 26uuu成人网一区二区三区| 国产麻豆精品95视频| 国产精品女人毛片| 欧美四级电影网| 久久精品国产精品青草| 国产精品久久久久久久久图文区| 在线观看国产精品网站| 久久精品国产久精国产| 国产精品日产欧美久久久久| 欧美性色综合网| 国产美女主播视频一区| 亚洲丝袜自拍清纯另类| 日韩亚洲国产中文字幕欧美| 国产成人精品在线看| 亚洲老妇xxxxxx| 精品久久久久久最新网址| 99国产精品久| 国产麻豆视频一区| 亚洲成人自拍网| 亚洲国产岛国毛片在线| 日本道精品一区二区三区| 韩国理伦片一区二区三区在线播放| 国产精品国产自产拍高清av | 国产精品视频一区二区三区不卡| 欧美午夜精品一区二区蜜桃| 国产精品亚洲专一区二区三区 | 久久男人中文字幕资源站| 91丨porny丨中文| 国产一区欧美二区| 天堂影院一区二区| 国产精品国产三级国产普通话三级 | 国产欧美日韩另类视频免费观看| 欧美三级一区二区| av中文字幕亚洲| 国产在线不卡一区| 三级不卡在线观看| 亚洲精品中文字幕在线观看| 亚洲天堂免费在线观看视频| 日韩欧美色电影| 91亚洲午夜精品久久久久久| 国产精品国产三级国产普通话三级| 91.xcao| 色综合天天在线| 成人中文字幕电影| 久久精品国产精品亚洲综合| 亚洲国产成人av网| 欧美日韩国产免费| 99精品黄色片免费大全| 国产电影精品久久禁18| 国产精品综合在线视频| 日av在线不卡| 日本亚洲天堂网| 日韩在线一区二区三区| 天堂在线亚洲视频| 视频一区欧美日韩| 亚洲国产精品欧美一二99| 亚洲日本免费电影| 亚洲精品一卡二卡| 亚洲综合丝袜美腿| 亚洲成人动漫av| 亚洲精品日韩一| 亚洲在线成人精品| 日韩专区在线视频| 国内精品在线播放| 粉嫩久久99精品久久久久久夜| 国产福利91精品一区二区三区| 国产精品自拍av| 成人午夜免费av| 在线免费观看不卡av| 欧美久久一二三四区| 欧美大白屁股肥臀xxxxxx| 日韩欧美在线影院| 中文字幕av资源一区| 亚洲卡通欧美制服中文| 亚洲6080在线| 国精产品一区一区三区mba视频| 国产成人在线看| 色综合欧美在线| 日韩三级电影网址| 国产欧美视频在线观看| 一区二区三区加勒比av| 日本成人在线视频网站| 国产高清视频一区| 欧美性大战久久久久久久蜜臀| 在线成人小视频| 久久精品亚洲精品国产欧美| 一区二区三区中文在线观看| 日韩精品免费专区| 国产精品自在在线| 欧美日韩国产三级| 欧美激情综合网| 天天免费综合色| 成人开心网精品视频| 3atv一区二区三区| 国产精品免费av| 精品一区二区三区蜜桃| 97久久精品人人做人人爽50路| 欧美日韩国产一二三| 国产精品国产三级国产aⅴ无密码| 日韩激情一二三区| 91一区二区在线| 久久噜噜亚洲综合| 日韩福利视频导航| 色婷婷av一区| 国产精品色一区二区三区| 麻豆免费精品视频| 欧美日韩小视频| 亚洲精选免费视频| 99精品欧美一区二区三区综合在线| 欧美大胆一级视频| 日韩精品视频网|