我有两个包含已发布的Elixir应用程序的Docker镜像。
我在本地机器上运行这两个Docker。
我正在尝试连接这两个节点。
如何在命名节点上运行发布的应用程序?
或者 - 是否有其他方法可以做到这一点?
docker-compose
的情况下创建 Erlang 节点的方法。
docker network create example
$ docker run --rm -it --name bar -h bar --net example erlang:19.3 /bin/bash
root@bar:/# erl -sname bar -setcookie example
Erlang/OTP 19 [erts-8.3.5.1] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V8.3.5.1 (abort with ^G)
(bar@bar)1>
docker run --rm -it --name foo -h foo --net example erlang:19.3 /bin/bash
root@foo:/# erl -sname foo -setcookie example
Erlang/OTP 19 [erts-8.3.5.1] [source] [64-bit] [smp:4:4] [ds:4:4:10] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V8.3.5.1 (abort with ^G)
(foo@foo)1>
(foo@foo)1> net_adm:ping(bar@bar).
pong
(bar@bar)1> net_adm:ping(foo@foo).
pong
bash
shelldocker exec -it foo /bin/bash
在这里,foo
是docker容器的名称。
./rel/your_app/bin/your_app console
我假设你知道容器内发布路径的位置。
docker-compose.yml:
version: "3"
services:
elixir1:
image: image-name
#(other configs here, like ports, volumes)
elixir2:
image: image-name
#(other configs here, like ports, volumes)
elixir1
和elixir2
之间进行指向。docker run
命令替换为:docker-compose up
Node.connect
。 - fay
docker network
并为运行的 Docker 容器提供了主机 (-h
),那么两个 Erlang 节点应该能够相互连接。 - juan.facorro