erlang集群是依靠epmd维护的,epmd是erlang集群节点间port映射的守护进程。负责维护集群内的节点连接。提供节点名称到IP地址及port的解析服务。

epmd 自己定义port号

epmdport配置

默认情况下,epmd绑定在4369port。可是。port固定的话。easy遭受攻击。可能导致新节点的认证失败而无法启动,或无法增加集群。

或者要在一台机器上部署不同的erlang集群,希望不会互相干扰。

epmd -daemon -port 5000
假设想用调试模式启动 epmd,使用 epmd -d -port 5000

另外。epmd通常伴随着erlang节点启动时自己主动启动。无须手动处理,所以,这里也能够通过改动erl启动參数以达到自己主动调整epmdport。

erl -name hello@127.0.0.1 -epmd "epmd -port 5000 -daemon" 

节点启动配置

当epmdport改变时,erlang节点须要显式指定epmdport信息。

windwos下启动方式
1、环境变量设置ERL_EPMD_PORT
C:\>set ERL_EPMD_PORT=5000
C:\>erl -name hello@127.0.0.1 
注意了, 以上命令port号(这里是5000)前后不能留有空格。

2、设置erlang启动參数
erl -name hello@127.0.0.1 -epmd_port 5000
linux下启动方式
1、环境变量设置ERL_EPMD_PORT
ERL_EPMD_PORT=5000 erl -name hello@127.0.0.1
2、设置erlang启动參数
erl -name hello@127.0.0.1 -epmd_port 5000

这两种方式是等价的,erlang启动时会做下面处理:
  1. // erlexec.c
  2. static void add_epmd_port(void)
  3. {
  4. char* port = get_env("ERL_EPMD_PORT");
  5. if (port != NULL) {
  6. add_args("-epmd_port", port, NULL);
  7. }
  8. }

当中,epmd_port在erl_epmd模块被用到,完毕epmd连接。

  1. %% erl_epmd.erl
  2. get_epmd_port() ->
  3. case init:get_argument(epmd_port) of
  4. {ok, [[PortStr|_]|_]} when is_list(PortStr) ->
  5. list_to_integer(PortStr);
  6. error ->
  7. ?erlang_daemon_port
  8. end.
  9.  
  10. %%
  11. %% Epmd socket
  12. %%
  13. open() -> open({127,0,0,1}). % The localhost IP address.
  14.  
  15. open({A,B,C,D}=EpmdAddr) when ?ip(A,B,C,D) ->
  16. gen_tcp:connect(EpmdAddr, get_epmd_port(), [inet]);
  17.  
  18. %% 注冊节点名称和port
  19. do_register_node(NodeName, TcpPort) ->
  20. case open() of
  21. {ok, Socket} ->
  22. Name = to_string(NodeName),
  23. Extra = "",
  24. Elen = length(Extra),
  25. Len = 1+2+1+1+2+2+2+length(Name)+2+Elen,
  26. gen_tcp:send(Socket, [?int16(Len), ?EPMD_ALIVE2_REQ,
  27. ?int16(TcpPort),
  28. $M,
  29. 0,
  30. ?
  31.  
  32. int16(epmd_dist_high()),
  33. ?int16(epmd_dist_low()),
  34. ?int16(length(Name)),
  35. Name,
  36. ?
  37.  
  38. int16(Elen),
  39. Extra]),
  40. wait_for_reg_reply(Socket, []);
  41. Error ->
  42. Error
  43. end.

epmd相关问题

限制指定IP的节点增加集群

epmd -port 5000 -address 127.0.0.1 -daemon
这样。假设节点名字不是 xxx@127.0.0.1,将无法启动。或增加集群。

怎样杀掉epmd进程

epmd独立于erlang节点。在全部节点关闭后还会继续存在,有时候可能须要杀掉epmd进程。
epmd  -kill

设定节点连接监听port

节点启动时,会启动一个tcp socket,用于监听并处理其它节点的连接请求。可是,这个port号是随机的,有时候我们须要定义防火墙规则,就要对port范围做一些限定。
通过改动erlang启动參数就可以设定,方法例如以下:
erl -name hello@127.0.0.1 -kernel inet_dist_listen_min 9100 -kernel inet_dist_listen_max 9200
看下这两个參数是怎么被使用的?
  1. %% inet_tcp_dist.erl
  2.  
  3. listen(Name) ->
  4. %% 启动本地节点监听socket
  5. case do_listen([{active, false}, {packet,2}, {reuseaddr, true}]) of
  6. {ok, Socket} ->
  7. TcpAddress = get_tcp_address(Socket),
  8. {_,Port} = TcpAddress#net_address.address,
  9. %% 注冊节点名称和port
  10. case erl_epmd:register_node(Name, Port) of
  11. {ok, Creation} ->
  12. {ok, {Socket, TcpAddress, Creation}};
  13. Error ->
  14. Error
  15. end;
  16. Error ->
  17. Error
  18. end.
  19.  
  20. do_listen(Options0) ->
  21. %% 获取port范围
  22. {First,Last} = case application:get_env(kernel,inet_dist_listen_min) of
  23. {ok,N} when is_integer(N) ->
  24. case application:get_env(kernel,
  25. inet_dist_listen_max) of
  26. {ok,M} when is_integer(M) ->
  27. {N,M};
  28. _ ->
  29. {N,N}
  30. end;
  31. _ ->
  32. {0,0}
  33. end,
  34. %% 获取绑定IP地址
  35. Options = case application:get_env(kernel, inet_dist_use_interface) of
  36. {ok, Ip} ->
  37. [{ip, Ip} | Options0];
  38. _ ->
  39. Options0
  40. end,
  41. do_listen(First, Last, [{backlog,128}|Options]).
  42.  
  43. do_listen(First,Last,_) when First > Last ->
  44. {error,eaddrinuse};
  45. do_listen(First,Last,Options) ->
  46. %% 尝试监听socket
  47. case inet_tcp:listen(First, Options) of
  48. {error, eaddrinuse} ->
  49. do_listen(First+1,Last,Options);
  50. Other ->
  51. Other
  52. end.

2015/9/29 标题“erlang epmd 自己定义port号”改成“erlang集群IP及port管理”

2015/6/25 补充节点连接监听port设定方法
參考:http://blog.csdn.net/mycwq/article/details/46630743

erlang集群IP及port管理的更多相关文章

  1. redis 与java的连接 和集群环境下Session管理

    redis 的安装与设置开机自启(https://www.cnblogs.com/zhulina-917/p/11746993.html)  第一步: a) 搭建环境 引入 jedis jar包 co ...

  2. redis内存分配管理与集群环境下Session管理

    ##################内存管理############### 1.Redis的内存管理 .与memcache不同,没有实现自己的内存池 .在2..4以前,默认使用标准的内存分配函数(li ...

  3. Erlang 集群互连测试

    Erlang 集群互连测试Erlang节点相同cookie全互联成为一个集群(cluster).如果2个集群不同cookie, 然后其中有节点连接到对方集群的节点,这2个集群会合并成一个集群吗?连接到 ...

  4. cdh 5.13 hadoop 集群IP变更详细步骤

    1.因一些不可抗因素,集群IP变更. 修改CM的数据库IP地址 /etc/cloudera-scm-server/db.p... 2.修改每个主机的hosts列表 3.修改SCM数据库的hosts表中 ...

  5. CEPH-5:ceph集群基本概念与管理

    ceph集群基本概念与管理 ceph集群基本概念 ceph集群整体结构图 名称 作用 osd 全称Object Storage Device,主要功能是存储数据.复制数据.平衡数据.恢复数据等.每个O ...

  6. ES系列十六、集群配置和维护管理

    一.修改配置文件 1.节点配置 1.vim elasticsearch.yml # ======================== Elasticsearch Configuration ===== ...

  7. Spark Storage(一) 集群下的区块管理

    Storage模块 在Spark中提及最多的是RDD,而RDD所交互的数据是通过Storage来实现和管理 Storage模块整体架构 1. 存储层 在Spark里,单节点的Storage的管理是通过 ...

  8. Redis Cluster 集群的实现和管理

    系统环境 CentOS 7 集群规划 在一台物理机(实际部署应当分散到多个物理机上),创建6个Redis节点,其中3个主节点.3个从节点. 节点表: IP 端口 主从 路径 192.168.1.21 ...

  9. kubernetes有状态集群服务部署与管理

    有状态集群服务的两个需求:一个是存储需求,另一个是集群需求.对存储需求,Kubernetes的解决方案是:Volume.Persistent Volume .对PV,除了手动创建PV池外,还可以通过S ...

随机推荐

  1. HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))

    Pet Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissio ...

  2. iOS视图控制器之间delegate传值教程

    之前在StackOverFlow上看到一篇讲传值(segue传值和delegate传值)的文章,感觉讲的非常清晰,就将delegate部分翻译了一下.有兴趣能够看看. 原文: http://stack ...

  3. 《转》 Openstack Grizzly 指定 compute node 创建 instance

    声明:此文档仅仅做学习交流使用,请勿用作其它商业用途 作者:朝阳_tony 邮箱:linzhaolover@gmail.com 2013年6月4日9:37:44 星期二 转载请注明出处:http:// ...

  4. 《sql---教学反馈系统-阶段项目1》

    --修改列 --把 "Address" 栏位改名为 "Addr".这可以用以下的指令达成: --ALTER table customer change Addr ...

  5. LCS最大公共子序列问题

    在生物应用中,经常需要比较两个(或多个)不同生物体的DNA, 例如:某种生物的DNA可能为S1=ACCGGTCGAGTGCGCGGAAGCCGGCCGAA, 另一种生物的DNA可能为S2=GTCGTT ...

  6. GMM的EM算法

    在聚类算法K-Means, K-Medoids, GMM, Spectral clustering,Ncut一文中我们给出了GMM算法的基本模型与似然函数,在EM算法原理中对EM算法的实现与收敛性证明 ...

  7. hdu1565+hdu1569(最大点权独立集)

    传送门:hdu1565 方格取数(1) 传送门:hdu1569 方格取数(2) 定理:1. 最小点权覆盖集=最小割=最大流2. 最大点权独立集=总权-最小点权覆盖集 步骤: 1. 先染色,取一个点染白 ...

  8. Android wear 初体验

    近期一直在研究android wear SDK,整体感受来说就是和现有的android 其它的开发SDK还是有非常多新的东西.比如手机终端与手表端的通信机制,手表端的UI规范.可是从开发本身来讲,还是 ...

  9. sql优化-提防错误关联

    在写sql时,在多表关联时,有时候容易把关联关系写错.一般情况下,该问题比较容易发现,但如果sql较长时,光靠眼力就比较难发现了.今天写了一个脚本,碰到该问题了. 第一版本的脚本如下: select ...

  10. poj3764(dfs+Trie树+贪心)

    题目链接:http://poj.org/problem?id=3764 分析:好题!武森09年的论文中有道题CowXor,求的是线性结构上的,连续序列的异或最大值,用的办法是先预处理出前n项的异或值, ...