如何用docker-compose确认现有的数字海洋水滴?

时间:2015-11-04 01:41:02

标签: docker docker-compose docker-machine

我有一个在Digital Ocean上运行的Droplet(虚拟机),它是从另一台笔记本电脑创建的。机器被称为"生产"。我确实有用于创建该机器的令牌。我在这里真的很困惑,如何"承认"那个小滴在另一台电脑上。我不想重新创建它,就像在一个容器中我拥有一些数据的数据库。用docker-machine / compose控制DO液滴似乎很舒服。唯一的问题,有时我需要在这里切换笔记本电脑。此外,有时数字海洋水滴只是从docker-machine ls消失,但它在DO上运行。

Vagrant实际上拥有数字海洋插件的这种功能,它可以承认已经在那里运行的VM。我非常确定这也必须是docker-machine。

1 个答案:

答案 0 :(得分:1)

据我所知,docker-machine“保存状态”的唯一方法是通过它创建的配置文件。每个使用docker-machine旋转的主机都会在~/.docker/machine/machines/下创建一个保存其配置的文件夹。有关DigitalOcean Droplet的信息存储在config.json文件中。我们来看一个特定的例子:

$ cat ~/.docker/machine/machines/docker-001/config.json | jq .
{
  "DriverName": "digitalocean",
  "Driver": {
    "AccessToken": "9dasd89ssf6542notarealtoken455b44sdgf4685",
    "DropletID": 4906043,
    "DropletName": "",
    "Image": "ubuntu-14-04-x64",
    "MachineName": "docker-001",
    "IPAddress": "45.32.128.70",
    "Region": "nyc3",
    "SSHKeyID": 7697371,
    "Size": "512mb",
    "CaCertPath": "/home/asb/.docker/machine/certs/ca.pem",
    "PrivateKeyPath": "/home/asb/.docker/machine/certs/ca-key.pem",
    "DriverKeyPath": "",
    "SwarmMaster": false,
    "SwarmHost": "tcp://0.0.0.0:3376",
    "SwarmDiscovery": ""
  },
  "CaCertPath": "/home/asb/.docker/machine/certs/ca.pem",
  "ServerCertPath": "",
  "ServerKeyPath": "",
  "PrivateKeyPath": "/home/asb/.docker/machine/certs/ca-key.pem",
  "ClientCertPath": "",
  "SwarmMaster": false,
  "SwarmHost": "tcp://0.0.0.0:3376",
  "SwarmDiscovery": ""
}

因此,在计算机之间同步~/.docker/machine/目录应该可以解决问题。