zoukankan      html  css  js  c++  java
  • [Elixir002]节点启动后自动连接其它节点

    问题: 如何指定一个节点在启动后自动连接到别的节点上?

    这个我们要使用到sys.config,这是erlang的配置文件,这个文件一般都是$ROOT/releases/Vsn下

    1. 首先我们要先启动一个master节点,Node.list可以看到当前节点并没有连接到任何节点

    iex --cookie secret --name master@127.0.0.1
    Erlang/OTP 18 [erts-7.2.1] [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false] [dtrace]
    
    Interactive Elixir (1.2.2) - press Ctrl+C to exit (type h() ENTER for help)
    iex(master@127.0.0.1)1>Node.list
    []

    2. 我们再启动一个slave节点,让它启动时直接连接到master上

    新建sys.config

    #sys.config
    [{kernel,
      [
        {sync_nodes_optional, ['master@127.0.0.1']},
        {sync_nodes_timeout, 150000}
      ]}
    ].

    这个配置可以表明,启动后会主动连接到'master@127.0.0.1' ,如果没有连接成功会每150秒再重连。

    iex --cookie secret --name slave@127.0.0.1 --erl "-config sys.config"
    Erlang/OTP 18 [erts-7.2.1] [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false] [dtrace]
    
    Interactive Elixir (1.2.2) - press Ctrl+C to exit (type h() ENTER for help)
    iex(slave@127.0.0.1)1> Node.list
    [:"master@127.0.0.1"]

    这时在2个节点上用Node.list都可以看到对方啦。 注意: 一定要保持2个节点的cookie是一样的

    再验证一下:

    iex(slave@127.0.0.1)2>:rpc.call(:"master@127.0.0.1", :io, :format, [:user, "~ts pid: ~p~n", ["我是在master节点上运行的", self()]])
    :ok
    iex(slave@127.0.0.1)2>self
    #PID<0.69.0>

    这个format只是会在原运行节点上输出,因为使用了:user, 所以我们在master上看到结果

    iex(master@127.0.0.1)2> 我是在master节点上运行的 pid: <9547.69.0>

    可以看到master上输入的pid是slaver上的进程pid, 其中9547是标记它来自slaver@127.0.0.1节点, 即: <0.69.0> == <9547.0.0>

    3. sys.config实现了发布新的release后会根据新的sys.config再加载配置

     When traversing the contents of sys.config and a filename is encountered, its contents are read and merged with the result so far. When an application configuration tuple{Application, Env} is found, it is merged with the result so far. Merging means that new parameters are added and existing parameter values overwritten.

    官方的例子给得太简单啦,演示个完整的例子看看:)

    假如我们想在上面的slaver节点上的kernel再加一个配置database的地址, 那么我们新建一个region.config 

    #File: /etc/region.config
    [{kernel, [ {database_for_example_purposes,
    "db://prod-host-omg:8089"} ]}].

    那么我们要做的就是把region.config加到sys.config

    File: sys.config
    [{kernel, [
              {sync_nodes_optional, ['master@127.0.0.1']},
              {sync_nodes_timeout, 150000}
              ]},
         "/etc/region.config"].

    我们再验证一下是否改变

    iex --cookie secret --name slave@127.0.0.1 --erl "-config ./sys.config"
    Erlang/OTP 18 [erts-7.2.1] [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false] [dtrace]
    
    Interactive Elixir (1.2.2) - press Ctrl+C to exit (type h() ENTER for help)
    iex(slave@127.0.0.1)1> Application.get_all_env(:kernel)
    [database_for_example_purposes: 'db://prod-host-omg:8089',
     sync_nodes_timeout: 150000, included_applications: [],
     sync_nodes_optional: [:"master@127.0.0.1"], error_logger: :tty]

    有兴趣可以看看extrm release如何生成sys.config的

    参照资料

    1. Distributed-otp-applications

    2. Design_principles about distributed_applications

    3. sys.config


    A day in the life of an Erlang developer

  • 相关阅读:
    spring cloud eureka 配置
    nginx 无法访问root权限的文件内容
    Linux 如何将一个文件夹的所有内容授权给某一个用户
    eclipse 注释字体不一致的问题
    java web 跨域
    tomcat的catalina.out日志文件过大
    linux 安装禅道
    修改rabbitmq Web UI 监控页面的端口
    nginx访问静态文件配置
    centos 安装单机版 redis4.0.10
  • 原文地址:https://www.cnblogs.com/zhongwencool/p/elixir_auto_connect_node.html
Copyright © 2011-2022 走看看