使用 Couchbase 的 Docker 数据卷

使用 Couchbase 的 Docker 数据卷

我有一个运行 Couchbase enterprise 3.0.2 的 docker 镜像

它目前位于私有存储库中。因此,我们将其名称定为:

matt/couchbase

为了在 matt/couchbase 被删除后仍能保留数据,我创建了一个基于 matt/couchbase 的数据容器,名为 matt/couchbase-data

Dockerfile 看起来像

FROM matt/couchbase
CMD ["true"]
VOLUME ["/opt/couchbase/var/lib/couchbase/data"]

根据 Couchbase 基座,上面的卷路径是 Couchbase 存储其数据的地方。

因此我运行 matt/couchbase-data,然后使用 --volumes-from 链接运行 matt/couchbase。

一切正常。docker inspect couchbase 显示:

"Volumes": {
        "/opt/couchbase/var/lib/couchbase/data": "/var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c"
    },
    "VolumesRW": {
        "/opt/couchbase/var/lib/couchbase/data": true
    }

docker inspect couchbase-data 包含:

"Volumes": {
        "/opt/couchbase/var/lib/couchbase/data": "/var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c"
    },
    "VolumesRW": {
        "/opt/couchbase/var/lib/couchbase/data": true
    }

因此看起来这两个容器连接得很好。

但是,问题是这样的。当我停止名为“couchbase”的容器,并使用 docker rm 将其删除,然后再次启动 couchbase 时,数据消失了,尽管 docker-inspect 指示该卷仍然存在,并且实际路径与之前相同。即 /var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c

这可能相关。couchbase 服务器正在使用以下 init 脚本启动,该脚本是我从另一个 docker couchbase 项目获得的(抱歉,暂时丢失了链接)。

我认为下面的 cluster-init(这是我为 Couchbase 默认运行的程序)可能正在重置数据。但根据文档,它只是设置集群用户名、密码和端口。

有任何想法吗?

#!/bin/bash
set +e



echo 'removing document size limit'
sed -i 's/return getStringBytes(json) > self.docBytesLimit;/return false/g' /opt/couchbase/lib/ns_server/erlang/lib/ns_server/priv/public/js/documents.js

echo 'starting couchbase'
/etc/init.d/couchbase-server restart

wait_for_start() {
    "$@"
    while [ $? -ne 0 ]
    do
        echo 'waiting for couchbase to start'
        sleep 1
        "$@"
    done
}


if [ -z "$CLUSTER_INIT_USER" ] || [ -z "$CLUSTER_INIT_PASSWORD" ]; then
       echo >&2 'error: Couchbase not initialized because CLUSTER_INIT_USER or CLUSTER_INIT_PASSWORD was not set'
       echo >&2 '       Did you forget to add -e CLUSTER_INIT_USER=... -e CLUSTER_INIT_PASSWORD=... ?'
       exit 1
fi

if [ -z "$COUCHBASE_PORT_8091_TCP" ]; then

    if [ -z "$CLUSTER_RAM_SIZE" ]; then
        CLUSTER_RAM_SIZE=1024
    fi

    echo 'initializing cluster...'
    wait_for_start /opt/couchbase/bin/couchbase-cli cluster-init -c 127.0.0.1:8091 --cluster-init-username="$CLUSTER_INIT_USER" --cluster-init-password="$CLUSTER_INIT_PASSWORD" --cluster-init-ramsize="$CLUSTER_RAM_SIZE" -u "$CLUSTER_INIT_USER" -p "$CLUSTER_INIT_PASSWORD"

    if [ -n "$SAMPLE_BUCKETS" ]; then
    curl http://"$CLUSTER_INIT_USER":"$CLUSTER_INIT_PASSWORD"@127.0.0.1:8091/sampleBuckets/install --data "[$SAMPLE_BUCKETS]"
    fi
else
    ip=`hostname --ip-address`
    wait_for_start /opt/couchbase/bin/couchbase-cli server-add -c $COUCHBASE_PORT_8091_TCP_ADDR:$COUCHBASE_PORT_8091_TCP_PORT --user="$CLUSTER_INIT_USER" --password="$CLUSTER_INIT_PASSWORD" --server-add=$ip:8091
fi

trap "/etc/init.d/couchbase-server stop" exit INT TERM

pid_file=/opt/couchbase/var/lib/couchbase/couchbase-server.pid
# can't use 'wait $(<"$pid_file")' as process not child of shell
while [ -e /proc/$(<"$pid_file") ]; do sleep 1; done

答案1

你应该考虑保留整个/opt/couchbase/var卷中的目录,而不仅仅是/opt/couchbase/var/lib/couchbase/数据子目录。

原因是“集群状态”存储在/opt/couchbase/var。如果丢失,它会认为这是一个新容器实例上的全新集群。

我写了一个博客文章它介绍了在 Docker 下启动 CouchBase 服务器的完整示例。Dockerfile 和所有使用的脚本如下:在 github 上

相关内容