云诺说 - 小程序开发 - 软件定制
当前位置: Erlang > Erlang热更新会kill掉阻塞进程吗?

Erlang热更新会kill掉阻塞进程吗?

2017-06-02 02:21 分类:Erlang 作者:云诺 阅读(2140)

版权声明:本文为博主原创文章,如果转载请给出原文链接:http://doofuu.com/article/4156132.html

问题:erlang热更新会kill掉还在调用'old' 代码的进程吗?

前几天在跟人讨论erlang模块热更新时对方认为不会kill掉还在调用‘old’代码的进程,原因是这会破坏掉erlang的稳定性,这样热更也就完全没有了意义!今天有时间我来写这篇博客验证下。

大家都知道erlang VM为每个模块最多保存2份代码,当前版本'current'和旧版本'old',当模块第一次被加载时,代码就是'current'版本。如果有新的代码被加载,'current'版本代码就变成了'old'版本,新的代码就成了'current'版本。erlang用两个版本共存的方法来保证任何时候总有一个版本可用,对外服务就不会停止。

测试代码如下:

-module(test).
-compile(export_all).

start() ->
    Pid = spawn(fun() -> do_loop() end),
    register(?MODULE, Pid).
    
do_loop() ->
    receive
        Msg ->
            io:format("~p~n", [Msg])
    end,
    do_loop().

hot_update(Mod) ->
	code:purge(Mod),
	code:load_file(Mod).

测试结果如下:

20161202113227800.png

从结果可以看出erlang热更时会kill掉一直使用‘old’代码的进程,原因是如果进程一直在自己loop里面,就会一直跑着‘old‘版本的代码, 那么如何解决这个问题呢? 请接着看下面

代码修改如下:

-module(test).
-compile(export_all).

start() ->
    Pid = spawn(fun() -> do_loop() end),
    register(?MODULE, Pid).
    
do_loop() ->
    receive
        code_switch ->
            ?MODULE:do_loop();
        Msg ->
            io:format("~p~n", [Msg]),
            do_loop()
    end.
    
hot_update(Mod) ->
    code:purge(Mod),
    code:load_file(Mod).

测试结果如下:

20161202114536570.png

在每次更新完之后给进程发送一条code_switch消息, 这样就没问题了,但是为什么呢? 这就涉及到erlang函数内部调用和外部调用的问题了,详细请参考下面几篇文章:

http://blog.csdn.net/mycwq/article/details/43372687

http://blog.csdn.net/mycwq/article/details/41175237

http://erlang.org/doc/reference_manual/code_loading.html#id86381

http://learnyousomeerlang.com/designing-a-concurrent-application#hot-code-loving

相关推荐

「创作不易,你的支持是本站持续更新最大的动力!」

赞(0) 打赏

谢谢你请我喝奶茶*^_^*

支付宝
微信
1

谢谢你请我喝奶茶*^_^*

支付宝
微信

共有 0 条评论 - Erlang热更新会kill掉阻塞进程吗?

博客简介

云诺说是一个致力于分享互联网编程技术交流、小程序开发、小程序源码分享、软件服务定制和生活记录的技术服务型学习博客网站。

微信 :LGY178888

职业 :小程序开发、软件定制

现居 :广东省-广州市-天河区

最近更新

友情链接

欢迎与本博客交换友情链接,本博客对交换链接的网站没有要求。如果您是本博客的友情链接网站,在遇到网站运行问题时,可以随时联系,我们将免费提供技术类支持! 申请交换友链

站点统计

  • 文章总数:170 篇
  • 草稿数目:0 篇
  • 分类数目:14 个
  • 独立页面:180 个
  • 评论总数:0 条
  • 访问总量: 884760次
  • 最近更新:2025年01月21日