先在服务器上安装go-delve
go-delve的github地址:https://github.com/go-delve
- 在服务器上安装好go语言的环境,然后在服务器上安装go-delve
go install github.com/go-delve/delve/cmd/dlv@latest
- 以服务器api做示例,示例代码如下,将代码文件上传到服务器
package main
import (
"flag"
"github.com/gin-gonic/gin"
)
func main() {
var port string
flag.StringVar(&port, "port", "8080", "启动端口")
flag.Parse()
r := gin.Default()
r.GET("/dev", func(c *gin.Context) {
v := 1
// c.JSON:返回JSON格式的数据
c.JSON(200, gin.H{
"message": v,
})
})
// 启动HTTP服务,默认在0.0.0.0:8080启动服务
r.Run(":" + port)
}
- 在Goland增加远程调试配置,2345为服务器端口,云服务器应该需要在安全组开放对应端口
- 进入到服务器代码目录,执行以下命令,与Goland提供的命令一样,但由于程序有启动参数,需要在后面增加--,表示后面的内容为启动参数
dlv debug --headless --listen=:2345 --api-version=2 --accept-multiclient -- --port=8081
- 在Goland打上断点并启动调试(快捷键:Shift + F9(ubuntu)),启动调试后,服务器会开启相应web服务
- 用postman调用api,看下是否能够断点成功
如果要生成可执行文件进行调试,需要调整上述第4步,使用如下命令编译生成可执行文件,目的是为了去掉编译器优化
go build -gcflags "all=-N -l" -o demo
然后执行
dlv --listen=:2345 --headless=true --api-version=2 --accept-multiclient exec ./demo -- --port=8081
标签:--,gin,go,delve,port,调试
From: https://www.cnblogs.com/burndust/p/16654395.html