erlang中的inet_gethost

本文详细解析了Erlang中inet_gethost服务的调度流程,强调其在分布式网络中的重要角色,以及如何通过独立进程优化性能。介绍了默认的4个inet_gethost进程如何为节点服务,并讨论了其启动过程和节点间的资源独占性。

erlang分布式网络节点中会经常用到域名解析服务,这一块是由外部程序inet_gethost来实现的,主要为了将这一耗时不确定的操作独立于主逻辑之外,以免影响主进程中process的调度。与inet_gethost同等待遇的还有memsup,cpu_sup和disksup,都是作为主进程的子进程独立执行。

inet_gethost的调度路径是这样的:

1.gen_tcp:connect

2.inet:gethostbyaddr

3.inet:gethostbyaddr_tm_native()

4.inet_gethost_native:gethostbyaddr()

5.inet_gethost_native:getit()

6.inet_gethost_native:ensure_started()

7.inet_gethost_native:start_raw()

8.inet_gethost_native:run_once()

9.inet_gethost_native:do_open_port()

10.inet_gethost_native:open_port({spawn, "inet_gethost 4 "}

11./usr/local/lib/erlang/erts-8.3/bin/inet_gethost

整个服务的启动,是由第一次gethostbyname()调用触发完成的,默认情况下会有4个inet_gethost进程为单一个节点服务,并且这4个inet_gethost进程被这一个节点独占,其他节点会有自己的独占inet_gethost服务。

root@jinjia:/etc/rabbitmq# systemctl status rabbitmq-server.service ● rabbitmq-server.service - RabbitMQ broker Loaded: loaded (/usr/lib/systemd/system/rabbitmq-server.service; enabled; preset> Active: active (running) since Tue 2025-08-26 13:44:00 CST; 17min ago Invocation: 804a04a79d0346d2855dc6d73ec1bb86 Main PID: 10626 (beam.smp) Tasks: 24 (limit: 33484) Memory: 80.6M (peak: 95.8M) CPU: 5.074s CGroup: /system.slice/rabbitmq-server.service ├─10626 /usr/lib/erlang/erts-15.2.7.1/bin/beam.smp -W w -MBas ageffcbf -> ├─10636 erl_child_setup 32768 ├─10655 /usr/lib/erlang/erts-15.2.7.1/bin/inet_gethost 4 ├─10656 /usr/lib/erlang/erts-15.2.7.1/bin/inet_gethost 4 └─10659 /bin/sh -s rabbit_disk_monitor 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Doc guides: https://www.rabbitmq.co> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Support: https://www.rabbitmq.co> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Tutorials: https://www.rabbitmq.co> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Monitoring: https://www.rabbitmq.co> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Upgrading: https://www.rabbitmq.co> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Logs: /var/log/rabbitmq/rabbit@jinji> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: <stdout> 8月 26 13:43:58 jinjia rabbitmq-server[10626]: Config file(s): (none) 8月 26 13:44:00 jinjia rabbitmq-server[10626]: Starting broker... completed with 0 > 8月 26 13:44:00 jinjia systemd[1]: Started rabbitmq-server.service - RabbitMQ broker. lines 1-25/25 (END) 帮我看一下这个的配置文件在哪儿
最新发布
08-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值