Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/jsp/3.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
VS代码远程容器-连接到主机上的数据库或单独docker compose文件中的数据库_Docker_Vscode Remote - Fatal编程技术网

VS代码远程容器-连接到主机上的数据库或单独docker compose文件中的数据库

VS代码远程容器-连接到主机上的数据库或单独docker compose文件中的数据库,docker,vscode-remote,Docker,Vscode Remote,我已经开始使用VS代码远程容器,特别是通过选项为您生成的GO容器。它提供了一个devcontainer.json文件和一个Dockerfile,工作正常 我的问题是试图从此远程容器中连接到数据库 我曾尝试使用docker compose构建一个单独的postgres数据库,并尝试连接到安装在我的基本计算机上的数据库 但是,每次我尝试通过db,err:=sqlx.connect(“postgres”,dsn)连接,或者使用sodasoda-migrate-up连接,如果只是挂断一段时间,然后说它无

我已经开始使用VS代码远程容器,特别是通过选项为您生成的GO容器。它提供了一个
devcontainer.json
文件和一个
Dockerfile
,工作正常

我的问题是试图从此远程容器中连接到数据库

我曾尝试使用docker compose构建一个单独的postgres数据库,并尝试连接到安装在我的基本计算机上的数据库

但是,每次我尝试通过
db,err:=sqlx.connect(“postgres”,dsn)
连接,或者使用soda
soda-migrate-up
连接,如果只是挂断一段时间,然后说它无法连接

有人找到了连接到DB的解决方案吗

这是我的go dockerfile:

#-------------------------------------------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See https://go.microsoft.com/fwlink/?linkid=2090316 for license information.
#-------------------------------------------------------------------------------------------------------------

FROM golang:1

# This Dockerfile adds a non-root user with sudo access. Use the "remoteUser"
# property in devcontainer.json to use it. On Linux, the container user's GID/UIDs
# will be updated to match your local UID/GID (when using the dockerFile property).
# See https://aka.ms/vscode-remote/containers/non-root-user for details.
ARG USERNAME=vscode
ARG USER_UID=1000
ARG USER_GID=$USER_UID

# Configure apt, install packages and tools
RUN apt-get update \
    && export DEBIAN_FRONTEND=noninteractive \
    && apt-get -y install --no-install-recommends apt-utils dialog 2>&1 \
    #
    # Verify git, process tools, lsb-release (common in install instructions for CLIs) installed
    && apt-get -y install git openssh-client less iproute2 procps lsb-release \
    #
    # Build Go tools w/module support
    && mkdir -p /tmp/gotools \
    && cd /tmp/gotools \
    && GOPATH=/tmp/gotools GO111MODULE=on go get -v golang.org/x/tools/gopls@latest 2>&1 \
    && GOPATH=/tmp/gotools GO111MODULE=on go get -v \
        honnef.co/go/tools/...@latest \
        golang.org/x/tools/cmd/gorename@latest \
        golang.org/x/tools/cmd/goimports@latest \
        golang.org/x/tools/cmd/guru@latest \
        golang.org/x/lint/golint@latest \
        github.com/mdempsky/gocode@latest \
        github.com/cweill/gotests/...@latest \
        github.com/haya14busa/goplay/cmd/goplay@latest \
        github.com/sqs/goreturns@latest \
        github.com/josharian/impl@latest \
        github.com/davidrjenni/reftools/cmd/fillstruct@latest \
        github.com/uudashr/gopkgs/v2/cmd/gopkgs@latest  \
        github.com/ramya-rao-a/go-outline@latest  \
        github.com/acroca/go-symbols@latest  \
        github.com/godoctor/godoctor@latest  \
        github.com/rogpeppe/godef@latest  \
        github.com/zmb3/gogetdoc@latest \
        github.com/fatih/gomodifytags@latest  \
        github.com/mgechev/revive@latest  \
        github.com/go-delve/delve/cmd/dlv@latest 2>&1 \
    #
    # Build Go tools w/o module support
    && GOPATH=/tmp/gotools go get -v github.com/alecthomas/gometalinter 2>&1 \
    #
    # Build gocode-gomod
    && GOPATH=/tmp/gotools go get -x -d github.com/stamblerre/gocode 2>&1 \
    && GOPATH=/tmp/gotools go build -o gocode-gomod github.com/stamblerre/gocode \
    #
    # Install Go tools
    && mv /tmp/gotools/bin/* /usr/local/bin/ \
    && mv gocode-gomod /usr/local/bin/ \
    #
    # Install golangci-lint
    && curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b /usr/local/bin 2>&1 \
    #
    # Create a non-root user to use if preferred - see https://aka.ms/vscode-remote/containers/non-root-user.
    && groupadd --gid $USER_GID $USERNAME \
    && useradd -s /bin/bash --uid $USER_UID --gid $USER_GID -m $USERNAME \
    # [Optional] Add sudo support
    && apt-get install -y sudo \
    && echo $USERNAME ALL=\(root\) NOPASSWD:ALL > /etc/sudoers.d/$USERNAME \
    && chmod 0440 /etc/sudoers.d/$USERNAME \
    #
    # Clean up
    && apt-get autoremove -y \
    && apt-get clean -y \
    && rm -rf /var/lib/apt/lists/* /tmp/gotools

# Update this to "on" or "off" as appropriate
ENV GO111MODULE=auto

这是devcontainer.json文件:

// For format details, see https://aka.ms/vscode-remote/devcontainer.json or this file's README at:
// https://github.com/microsoft/vscode-dev-containers/tree/v0.122.1/containers/go
{
    "name": "Go",
    "dockerFile": "Dockerfile",

    "runArgs": [ "--cap-add=SYS_PTRACE", "--security-opt", "seccomp=unconfined" ],

    // Set *default* container specific settings.json values on container create.
    "settings": { 
        "terminal.integrated.shell.linux": "/bin/bash",
        "go.gopath": "/go"
    },

    // Add the IDs of extensions you want installed when the container is created.
    "extensions": [
        "golang.Go"
    ],

    // Use 'forwardPorts' to make a list of ports inside the container available locally.
    "forwardPorts": [3000],

    // Use 'postCreateCommand' to run commands after the container is created.
    // "postCreateCommand": "go version",

    // Uncomment to connect as a non-root user. See https://aka.ms/vscode-remote/containers/non-root.
    // "remoteUser": "vscode"
}
这是我用于DB的docker compose文件

version: "3.1"

services:
  db:
    image: postgres:10.10
    environment:
      POSTGRES_PASSWORD: pass
      POSTGRES_USER: user
      POSTGRES_DB: my_db
    container_name: test_db
    ports:
      - 1234:5432
    restart: "no"
    volumes:
      - ../postgres-data:/var/lib/postgresql/data
Soda使用一个.yml文件连接到数据库,如下所示:

development:
  dialect: postgres
  database: my_db
  user: user
  password: pass
  host: 174.24.0.1
  port: 1234
提前感谢

如果有人还在看,回答得很好:

如果数据库在主机上运行,则可以使用以下方法:

development:
  dialect: postgres
  database: my_db
  user: user
  password: pass
  host: host.docker.internal
  port: 1234

您使用的数据库连接字符串是什么,请更新您的dockerfile和docker-compose@DupinderSingh我已经更新了帖子,加入了我正在使用的dockerfile和docker compose。Soda使用一个.yml文件进行连接,它在上面的帖子中,你只是想从docker容器内部连接到数据库吗?是的。从容器内部。我在本地机器上有一个数据库,也在一个单独的容器中有一个数据库。我知道如何连接,但它只是挂起然后超时。如果他们都在一个地方,那就行了。但我怀疑,因为go代码在一个容器中,它无法访问我的机器或其他容器上的数据