Eu tenho uma imagem docker que executa o Couchbase Enterprise 3.0.2
Está em um repositório privado atualmente. Então vamos apenas dizer que o nome dele é:
matt/couchbase
Para permitir que os dados persistam caso o matt/couchbase seja removido, criei um contêiner somente de dados baseado no matt/couchbase chamado matt/couchbase-data
O Dockerfile se parece com
FROM matt/couchbase
CMD ["true"]
VOLUME ["/opt/couchbase/var/lib/couchbase/data"]
De acordo com as docas do couchbase, o caminho do volume acima deve ser onde o couchbase armazena seus dados.
Portanto, executo matt/couchbase-data e, em seguida, executo matt/couchbase com um link --volumes-from.
Isso funciona bem. docker inspecionar programas couchbase:
"Volumes": {
"/opt/couchbase/var/lib/couchbase/data": "/var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c"
},
"VolumesRW": {
"/opt/couchbase/var/lib/couchbase/data": true
}
e docker inspecionar couchbase-data contém:
"Volumes": {
"/opt/couchbase/var/lib/couchbase/data": "/var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c"
},
"VolumesRW": {
"/opt/couchbase/var/lib/couchbase/data": true
}
Portanto, parece que os dois contêineres se conectaram perfeitamente.
No entanto, o problema é este. Quando paro o contêiner chamado "couchbase" e o removo com o docker rm e, em seguida, inicio o couchbase novamente, os dados desaparecem, apesar do docker-inspect indicar que o volume ainda está ativo com o mesmo caminho real de antes. ou seja, /var/lib/docker/vfs/dir/f129a034a2b0474392fe98bdc37429f172be26c93a058540f3a1043d324c0b1c
Isso pode ser relevante. O servidor couchbase está sendo iniciado com o seguinte script init que obtive de outro projeto docker couchbase (desculpe, perdi o link temporariamente).
Achei que talvez o cluster-init abaixo (que é o que eu executo por padrão para couchbase) possa estar redefinindo os dados. Mas, de acordo com os documentos, ele apenas define o nome de usuário, a senha e a porta do cluster.
Alguma ideia?
#!/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
Você deve considerar a preservação de todo o diretório /opt/couchbase/var em um volume, em vez de apenas o subdiretório /opt/couchbase/var/lib/couchbase/data .
A razão é que existe um "estado de cluster" armazenado em /opt/couchbase/var . Se for perdido, ele pensará que é um novo cluster em uma nova instância de contêiner.
Escrevi uma postagem no blog que mostra um exemplo completo de como ativar o servidor couchbase no docker. O Dockerfile e todos os scripts usados estão no github .