Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/docker/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
为什么可以';使用Docker/VScode进行远程调试吗?_Docker_Go_Visual Studio Code - Fatal编程技术网

为什么可以';使用Docker/VScode进行远程调试吗?

为什么可以';使用Docker/VScode进行远程调试吗?,docker,go,visual-studio-code,Docker,Go,Visual Studio Code,我正在尝试使用Docker/VScode远程调试Go应用程序。我的文件看起来像: 梅因,加油 Dockerfile docker-compose.yml launch.json 我可以看到我的应用程序的docker日志,我知道它正在收听2345。但无论出于什么原因,我似乎无法调试该应用程序。我看到的另一个问题是,我看不到任何试图运行launch.json的日志 编辑:我正在Mac OSX上使用Docker Desktop运行此程序。Docker Desktop for Mac在虚

我正在尝试使用Docker/VScode远程调试Go应用程序。我的文件看起来像:

  • 梅因,加油
  • Dockerfile
  • docker-compose.yml
  • launch.json
我可以看到我的应用程序的docker日志,我知道它正在收听
2345
。但无论出于什么原因,我似乎无法调试该应用程序。我看到的另一个问题是,我看不到任何试图运行
launch.json
的日志


编辑:我正在Mac OSX上使用Docker Desktop运行此程序。

Docker Desktop for Mac在虚拟机中运行Docker


不要试图达到127.0.0.1:2345,而应该使用虚拟机IP。

日志应该显示在输出窗口中,您所说的“无法调试”是什么意思“?是否设置了断点?是否确实执行了设置断点的代码?dockerfile与此有何关系?我已检查了所知的所有输出,但没有看到任何相关的输出。作为参考,我正在尝试完成类似的操作。是否在Windows主机上运行此操作?是否也在使用Docker?”lbox?我也尝试过,但仍然没有成功。我认为,这不重要,如果端口被暴露,并且vscode能够看到它,应该没问题吧?
package main

    import (
        "log"
        "net"
        "net/http"
        "strings"
    )
    
    func main() {
        http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
            message := r.URL.Path
            message = strings.TrimPrefix(message, "/")
            message = "Hello, " + message + "!"
    
            w.Write([]byte(message))
        })
    
        log.Print("starting web server")
        listener, err := net.Listen("tcp", ":8080")
        if err != nil {
            log.Fatal(err)
        }
    
        log.Printf("Start listening: %v", listener.Addr().String())
    
        if err := http.Serve(listener, nil); err != nil {
            log.Fatal(err)
        }
    }
    FROM golang:1.12
    
    ENV GOPATH /go
    ENV PATH $GOPATH/bin:/usr/local/go/bin:$PATH
    
    RUN go get github.com/go-delve/delve/cmd/dlv
    
    # set the working directory to /go/src
    WORKDIR $GOPATH/src
    
    # Copy everything from the current directory to the working directory inside the container
    # (as set by WORKDIR)
    COPY . .
    
    # 8080 is for the web application
    EXPOSE 8080 2345
    version: "3.0"
    
    services:
      web:
        container_name: go-delve-docker-vscode-example
        build: "./"
        ports:
          - "8080:8080"
          - "2345:2345"
        security_opt:
          - "seccomp:unconfined"
        tty: true
        stdin_open: true
        # command: go run main.go
        command: dlv debug --headless --listen=:2345 --api-version=2 --log main.go
    {
        "version": "0.2.0",
        "configurations": [
              {
                    "name": "Delve into Docker",
                    "type": "go",
                    "request": "launch",
                    "mode": "remote",
                    "remotePath": "/go/src/",
                    "port": 2345,
                    "host": "127.0.0.1",
                    "program": "${workspaceRoot}",
                    "showLog": true
              }
        ]
    }