如何在机器上启动单元的IP地址并在另一个单元中使用它?

时间:2015-03-13 13:45:55

标签: docker coreos etcd

我是CoreOS和Docker的新手,我遇到了舰队问题。

我有一个标准单元启动POSTGRES容器,我想知道启动此单元的机器的IP地址。 我实际上有一组3台机器,而POSTGRES单元并不总是在同一台机器上启动(这意味着IP不是静态的)。

当我开始另一个需要POSTGRES的单位(见下文)时,我需要它。

我现在正在使用名为BindsTo的单位参数:

[Unit]
Description=Test
After=docker.service
After=postgres@1.service

Requires=docker.service
Requires=postgres@1.service

BindsTo=postgres@1.service

[Service]
TimeoutStartSec=0
ExecStartPre=-/usr/bin/docker kill test%i
ExecStartPre=-/usr/bin/docker rm test%i
ExecStart=/usr/bin/docker run -rm --name test%i -e HOST="HereThePostgresIP" sryther/test
ExecStop=/usr/bin/docker stop test%i

N.B。 :此单元不需要在与POSTGRES单元相同的机器上启动。

我尝试使用%H变量,但它返回主机名而不是机器的IP地址。

法兰绒也在我的群集中使用。

谢谢!


我找到了解决方法:

[Unit]
Description=Test
After=docker.service

Requires=docker.service

[Service]
TimeoutStartSec=0
ExecStartPre=-/usr/bin/docker kill test%i
ExecStartPre=-/usr/bin/docker rm test%i

ExecStart=/usr/bin/docker run -rm --name test%i --link postgres1:postgres sryther/test
ExecStop=/usr/bin/docker stop test%i

IP地址在容器环境中设置为 POSTGRES_PORT_5432_TCP_ADDR

2 个答案:

答案 0 :(得分:4)

我在我的舰队环境中使用registrator进行发现。当我启动我的舰队时,我修改了cloud-config文件,还包括registrator(以及etcd,flannel,fleet等)。 Regender驻留在docker上并识别新容器何时启动/终止/停止。 Registrator管理已发现容器的数据库,它有多种形式(如consul,skydns)。我配置我的skydns模式运行。所以,这里有一个例子,我用一个单元文件启动我的postgres服务器,我不知道它将要落在哪里:

[Unit]
Description=Postgres
After=docker.service
Requires=flanneld.service docker.service etcd.service

[Service]
Restart=always
ExecStartPre=-/usr/bin/env docker kill postgresql
ExecStartPre=-/usr/bin/env docker rm postgresql
ExecStartPre=/usr/bin/env docker pull sameersbn/postgresql:9.4
ExecStart=/usr/bin/docker run --name postgresql sameersbn/postgresql:9.4
ExecStop=-/usr/bin/docker stop postgresql

当postgres开始时,我使用postgres条目更新了etcd:

/skydns/net/tacodata/postgresql/aup1:postgresql:5432

如果我拿到那个,我会&#39 ;;;看到ip和端口:

$ etcdctl get /skydns/net/tacodata/postgresql/aup1:postgresql:5432
{"host":"10.1.43.5","port":5432}

可以修改您的应用程序来执行此操作。或者,您可以运行容器skydns,它会自动为您更新dns,因此您拥有SRV记录和A记录。在我的安装中,我使用了一个名为tacodata.net的测试域,因此,在postgresql出现后,我有dns记录!

root@f7e403be967a:/# host -t srv postgresql.tacodata.net 10.1.45.1
Using domain server:
Name: 10.1.45.1
Address: 10.1.45.1#53
Aliases: 

postgresql.tacodata.net has SRV record 10 100 5432
aup1:postgresql:5432.postgresql.tacodata.net.

当我启动我的依赖应用程序时,我让它们需要postgresql.service,我只是使用postgresql.tacodata.net将ip地址引用到应用程序。

-g

答案 1 :(得分:3)

据格雷格说,我使用了SkyDNS和Registrator:

  

我在我的舰队环境中使用registrator进行发现。当我启动我的舰队时,我修改了cloud-config文件,还包括registrator(以及etcd,flannel,fleet等)。 Regender驻留在docker上并识别新容器何时启动/终止/停止。 Registrator管理已发现容器的数据库,它有多种形式(如consul,skydns)。我将我配置为以skydns模式运行。

下面你可以找到我的工作cloud-config,请记住我使用CoreOS 607并且我的测试是在VMware上执行的。我的目标是设置3台机器来制作一个小型集群,每台机器上运行一个etcd,如this

我设法找到了这个解决方案,感谢Greg关于这个主题以及this cloud-config file used with Vagrant

我希望它能帮助:)。


#cloud-config

coreos:
  etcd:
    discovery: https://discovery.etcd.io/4c8c3f9a67048e76e9075c97d9d63c0c
    addr: 192.168.1.13:4001
    peer-addr: 192.168.1.13:7001
  fleet:
    public-ip: 192.168.1.13
  units:
    - name: etcd.service
      command: start
    - name: flanneld.service
      drop-ins:
        - name: 50-network-config.conf
          content: |
            [Service]
            ExecStartPre=/usr/bin/etcdctl set /coreos.com/network/config '{ "Network": "172.16.0.0/16" }'
      command: start
    - name: fleet.service
      command: start
    - name: skydns.service
      enable: false
      content: |
        [Unit]
        Description=Skydns
        After=docker.service
        After=fleet.service
        [Service]
        ExecStartPre=/usr/bin/docker pull skynetservices/skydns
        ExecStart=/usr/bin/env bash -c '/usr/bin/docker run -p 53:53 --name skydns -e ETCD_MACHINES="http://$(ifconfig docker0 | awk \'/\<inet\>/ { print $2}\'):4001" skynetservices/skydns -nameservers="8.8.8.8:53" --addr="0.0.0.0:53"'
        ExecStop=/usr/bin/docker stop skydns
        Restart=always

        [X-Fleet]
        Global=true

        [Install]
        WantedBy=multi-user.target
    - name: registrator.service
      enable: false
      content: |
        [Unit]
        Description=Registrator
        After=docker.service
        After=fleet.service

        [Service]
        ExecStartPre=/usr/bin/docker pull gliderlabs/registrator
        ExecStart=/usr/bin/env bash -c '/usr/bin/docker run --net=host -p 8080:8080 -p 8443:8443 -v /var/run/docker.sock:/tmp/docker.sock --name registrator gliderlabs/registrator skydns2://$(ifconfig docker0 | awk \'/\<inet\>/ { print $2}\'):4001/skydns.local'
        ExecStop=/usr/bin/docker stop registrator
        Restart=always

        [X-Fleet]
        Global=true
    - name: primordial.service
      command: start
      content: |
        [Unit]
        Description=Load and start fleet services
        After=fleet.service
        Requires=fleet.service
        After=etcd.service
        Requires=etcd.service
        After=flanneld.service
        Requires=flanneld.service

        [Service]
        Type=oneshot
        RemainAfterExit=yes
        ExecStartPre=/usr/bin/systemctl stop docker.service
        ExecStartPre=/usr/bin/ifconfig docker0 down
        ExecStartPre=/usr/bin/brctl delbr docker0
        ExecStartPre=/usr/bin/systemctl start docker.service
        ExecStart=/usr/bin/fleetctl start /etc/systemd/system/skydns.service
        ExecStart=/usr/bin/fleetctl start /etc/systemd/system/registrator.service
ssh_authorized_keys:
  - ssh-rsa AAAA....