Как подключиться к Postgres из кодовых пространств Github

#node.js #postgresql #docker-compose #node-postgres #codespaces

#node.js #postgresql #docker-compose #узел-postgres #кодовые пространства

Вопрос:

Я экспериментирую с кодовыми пространствами GitHub, пытаясь развернуть приложение с помощью Node и Postgres.

Я выбрал следующий вариант: опция кодового пространства

что привело к следующему devcontainer.json :

 // Update the VARIANT arg in docker-compose.yml to pick a Node.js version: 10, 12, 14 
{
    "name": "Node.js amp; PostgreSQL",
    "dockerComposeFile": "docker-compose.yml",
    "service": "app",
    "workspaceFolder": "/workspace",

    // Set *default* container specific settings.json values on container create.
    "settings": { 
        "terminal.integrated.shell.linux": "/bin/bash",
        "sqltools.connections": [{
            "name": "Container database",
            "driver": "PostgreSQL",
            "previewLimit": 50,
            "server": "localhost",
            "port": 5432,
            "database": "postgres",
            "username": "postgres",
            "password": "postgres"
        }]
    },

    // Add the IDs of extensions you want installed when the container is created.
    "extensions": [
        "dbaeumer.vscode-eslint",
        "mtxr.sqltools",
        "mtxr.sqltools-driver-pg"
    ]

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

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

    // Uncomment to connect as a non-root user. See https://aka.ms/vscode-remote/containers/non-root.
    // "remoteUser": "node"
}

  

и docker-compose.yml :

 version: '3'

services:
  app:
    build: 
      context: .
      dockerfile: Dockerfile
      args:
        # [Choice] Node.js version: 14, 12, 10
        VARIANT: 14
        # On Linux, you may need to update USER_UID and USER_GID below if not your local UID is not 1000.
        USER_UID: 1000
        USER_GID: 1000

    volumes:
      - ..:/workspace:cached
      
    # Overrides default command so things don't shut down after the process ends.
    command: sleep infinity

    # Runs app on the same network as the database container, allows "forwardPorts" in devcontainer.json function.
    network_mode: service:db

    # Uncomment the next line to use a non-root user for all processes.
    # user: node

    # Use "forwardPorts" in **devcontainer.json** to forward an app port locally. 
    # (Adding the "ports" property to this file will not forward from a Codespace.)

  db:
    image: postgres:latest
    restart: unless-stopped
    volumes:
      - postgres-data:/var/lib/postgresql/data
    environment:
      POSTGRES_PASSWORD: postgres
      POSTGRES_USER: postgres
      POSTGRES_DB: postgres

    # Add "forwardPorts": ["5432"] to **devcontainer.json** to forward MongoDB locally.
    # (Adding the "ports" property to this file will not forward from a Codespace.)

volumes:
  postgres-data:
  

Мой package.json заключается в следующем:

 {
  "dependencies": {
    "pg": "^8.4.2"
  },
  "scripts": {
    "start": "node index.js"
  }
}
  

и мой index.js такой:

 const { Pool } = require("pg")

const db = new Pool()

db.query(`CREATE TABLE IF NOT EXISTS testing(id SERIAL PRIMARY KEY);`)
  

Запуск yarn start выдает следующую ошибку:

 codespace ➜ ~/workspace/codespace-demo (main ✗) $ yarn start
yarn run v1.17.3
warning package.json: No license field
$ node index.js
(node:1037) UnhandledPromiseRejectionWarning: Error: connect ECONNREFUSED 127.0.0.1:5432
    at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1141:16)
(node:1037) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). To terminate the node process on unhandled promise rejection, use the CLI flag `--unhandled-rejections=strict` (see https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode). (rejection id: 1)
(node:1037) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
Done in 0.11s.
  

Это наводит меня на мысль, что экземпляр Postgres не запущен и не запущен внутри кодового пространства.

Я попытался раскомментировать эту строку о пересылке портов:

 "forwardPorts": [3000, 5432]
  

но не повезло.

Вероятно, мне не хватает некоторого представления о том, как части Docker подходят для игры здесь, но было бы здорово, если бы кто-нибудь мог указать мне правильное направление!

Комментарии:

1. Может быть, потому, что служба БД еще не запущена. Вы это проверили?

2. Я полагаю, что в этом причина, но не уверен, как запустить его из кодового пространства. Вы знаете, есть ли стандартный способ его запуска?

Ответ №1:

Я смог заставить это работать с двумя точками.

  1. Недостаточно просто добавить a .devcontainer с файлами внутри. Вам нужно зафиксировать изменения, нажать на них, удалить кодовое пространство, а затем создать новое, чтобы отразить изменения.

  2. Внутри .devcontainer/docker-compose.yml я должен был добавить строку network_mode: host в db сервис. Согласно этой теме, это требование скоро будет удалено, но пока оно требуется: https://github.community/t/cant-connect-to-postgres/142655/2?u=andyweiss1982