我无法为Docker Swarm安装NFS卷,并且缺少关于–mount语法(
https://docs.docker.com/engine/reference/commandline/service_create/)的正式官方文档也无济于事.
我已经尝试了这个命令行来创建一个简单的nginx服务,其中/ kkk目录安装到NFS卷:
docker service create –mount type = volume,src = vol_name,volume-driver = local,dst = / kkk,volume-opt = type = nfs,volume-opt = device = 192.168.1.1:/ your / nfs / path – -name test nginx
接受命令行并且服务由Swarm调度,但容器永远不会达到“运行”状态,并且swarm尝试每隔几秒启动一个新实例.我将守护进程设置为调试,但没有关于卷的错误显示…
使用NFS卷创建服务的正确语法是什么?
非常感谢
最佳答案 我在这里发现了一篇文章,展示了如何安装nfs共享(这对我有用):
http://collabnix.com/docker-1-12-swarm-mode-persistent-storage-using-nfs/
sudo docker service create \
--mount type=volume,volume-opt=o=addr=192.168.x.x,volume-opt=device=:/data/nfs,volume-opt=type=nfs,source=vol_collab,target=/mount \
--replicas 3 --name testnfs \
alpine /bin/sh -c "while true; do echo 'OK'; sleep 2; done"
更新:
如果您想将它与docker-compose一起使用,您可以执行以下操作:
version: '3'
services:
alpine:
image: alpine
volumes:
- vol_collab:/mount
deploy:
mode: replicated
replicas: 2
command: /bin/sh -c "while true; do echo 'OK'; sleep 2; done"
volumes:
vol_collab:
driver: local
driver_opts:
type: nfs
o: addr=192.168.xx.xx
device: ":/data/nfs"
然后运行它
docker stack deploy -c docker-compose.yml test