golang源码调试

使用bitnami/golang搭建go环境

从源码安装go

我们要对源码重新编译后调试,使用go编译器二进制文件,我们调试的go版本是1.24。根据官方文档所述

Go 1.N 版本将需要一个 Go 1.M 编译器, 其中 M 为 N-2,向下舍入为偶数。示例:Go 1.24 和 1.25 需要 Go 1.22。

我们的编译器的版本只要大于等于最低版本要求就可以进行编译,我下载的bootstrap工具链的版本为 go1.23.0.linux-amd64.tar.gz

bitnami/golang 的源码文件在 /opt/bitnami/go 文件夹中,我们要对其进行多次的调试和修改,我们将目录挂载到本地,如果挂载后没有显示对应的文件, 需要取消挂载,将文件夹内容复制出来后重新进行挂载

yaml 复制代码
services:
  golang:
    image: bitnami/golang:1.24
    container_name: golang
    hostname: golang
    tty: true
    command: ["sleep", "infinity"]
    environment:
      GOROOT_BOOTSTRAP: /root/go    # 设置二进制包环境变量信息 
    volumes:
      - "../cmd:/go/src/cmd"        # 后续调试时使用的文件目录挂载 
      - "./data/go:/opt/bitnami/go" # 容器自己go源码位置
      - "./data/bootstrap:/root/go" # 下载后的1.23版本的工具链

修改源码后进行编译

我们对fmt.Println进行修改, 文件位置位于 src/fmt/print.go, 修改如下:

go 复制代码
// Println formats using the default formats for its operands and writes to standard output.
// Spaces are always added between operands and a newline is appended.
// It returns the number of bytes written and any write error encountered.
func Println(a ...any) (n int, err error) {
    println("添加调试输出debug")

    return Fprintln(os.Stdout, a...)
}

修改后,我们重新编译源码后运行查看一下结果

shell 复制代码
$ cd /opt/bitnami/go/src

$ ./make.bash
Building Go cmd/dist using /root/go. (go1.23.0 linux/amd64)
Building Go toolchain1 using /root/go.
Building Go bootstrap cmd/go (go_bootstrap) using Go toolchain1.
Building Go toolchain2 using go_bootstrap and Go toolchain1.
Building Go toolchain3 using go_bootstrap and Go toolchain2.
Building packages and commands for linux/amd64.
---
Installed Go for linux/amd64 in /opt/bitnami/go
Installed commands in /opt/bitnami/go/bin

$ cat /go/src/cmd/array/array.go
package main

import "fmt"

func main() {
        fmt.Println("hello world")
}

# 运行查看输出信息
$ go run /go/src/cmd/array/array.go
添加调试输出debug
hello world

将go语言的源代码编译成汇编语言,通过汇编语言分析程序具体执行过程。

shell 复制代码
$ cd /go/src/cmd/array

$ go build -gcflags -S array.go

# 获取汇编指令的优化过程及 Go 语言更详细的编译过程
$ GOSSAFUNC=main go build array.go
# runtime
dumped SSA for main,1 to /go/src/cmd/array/ssa.html
# command-line-arguments
dumped SSA for main,1 to ./ssa.html

在当前文件夹下点击ssa.html后可以查看汇编代码优化的每一个步骤,可以在页面上进行交互查看每个步骤,方便分析编译优化的过程。

参考文档:draven.co/golang/docs...

相关推荐
研究司马懿15 小时前
【云原生】Gateway API高级功能
云原生·go·gateway·k8s·gateway api
梦想很大很大1 天前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
lekami_兰1 天前
MySQL 长事务:藏在业务里的性能 “隐形杀手”
数据库·mysql·go·长事务
却尘2 天前
一篇小白也能看懂的 Go 字符串拼接 & Builder & cap 全家桶
后端·go
ん贤2 天前
一次批量删除引发的死锁,最终我选择不加锁
数据库·安全·go·死锁
mtngt112 天前
AI DDD重构实践
go
Grassto4 天前
12 go.sum 是如何保证依赖安全的?校验机制源码解析
安全·golang·go·哈希算法·go module
Grassto5 天前
11 Go Module 缓存机制详解
开发语言·缓存·golang·go·go module
程序设计实验室6 天前
2025年的最后一天,分享我使用go语言开发的电子书转换工具网站
go
我的golang之路果然有问题6 天前
使用 Hugo + GitHub Pages + PaperMod 主题 + Obsidian 搭建开发博客
golang·go·github·博客·个人开发·个人博客·hugo