具有SQL命令的CockroachDB Docker Compose脚本

jon*_*gen 6 bash docker-compose cockroachdb

我想完成两件事:

1)使用docker compose启动一个CockroachDB集群(有效)

2)在群集上执行SQL命令(我想创建一个数据库)

我的Docker文件如下所示:

version: '3'

services: 
roach-ui: 
 image: cockroachdb/cockroach
 command: start --insecure
 expose:
  - "8080"
  - "26257"
 ports:
  - "26257:26257"
  - "8080:8080"
 networks:
  - roachnet
db-1: 
 image: cockroachdb/cockroach
 command: start --insecure --join=roach-ui
 networks:
  - roachnet
 volumes: 
  - ./data/db-1:/cockroach/cockroach-data

networks:
 roachnet:
Run Code Online (Sandbox Code Playgroud)

当我运行docker-compose up时,一切都按预期工作。使用google时,我发现解决方案是运行bash脚本,我创建了以下setup.sh:

sql --insecure --execute="CREATE TABLE testDB"
Run Code Online (Sandbox Code Playgroud)

我试图通过命令bash -c“ setup.sh”运行脚本,但是Docker表示无法运行命令“ bash”。有什么建议么 ?谢谢 :)

编辑:

我正在运行docker-compose up,我得到的错误是:

roach-ui_1  | Failed running "bash"
heimdall_roach-ui_1 exited with code 1
Run Code Online (Sandbox Code Playgroud)

Tar*_*ani 7

因此,您需要一个额外的初始化服务来初始化数据库。该服务将运行bash脚本以执行将初始化数据库的命令

setup_db.sh

#!/bin/bash
echo Wait for servers to be up
sleep 10

HOSTPARAMS="--host db-1 --insecure"
SQL="/cockroach/cockroach.sh sql $HOSTPARAMS"

$SQL -e "CREATE DATABASE tarun;"
$SQL -d tarun -e "CREATE TABLE articles(name VARCHAR);"
Run Code Online (Sandbox Code Playgroud)

然后添加此文件以在 docker-compose.yml

docker-compose.yaml

version: '3'

services:
  roach-ui:
    image: cockroachdb/cockroach
    command: start --insecure
    expose:
     - "8080"
     - "26257"
    ports:
     - "26257:26257"
     - "8080:8080"
    networks:
     - roachnet
  db-1:
    image: cockroachdb/cockroach
    command: start --insecure --join=roach-ui
    networks:
     - roachnet
    volumes:
     - ./data/db-1:/cockroach/cockroach-data
  db-init:
   image: cockroachdb/cockroach
   networks:
    - roachnet
   volumes:
     - ./setup_db.sh:/setup_db.sh
   entrypoint: "/bin/bash"
   command: /setup_db.sh
networks:
  roachnet:
Run Code Online (Sandbox Code Playgroud)