7. 7
Горячая замена кода
7
code_change(_OldVsn, State, _Extra) ->
%% No change planned. The function is there for the behaviour,
%% but will not be used. Only a version on the next
{ok, State}.
code_change({down, _Vsn}, {Chs, N}, _Extra) ->
{ok, Chs};
code_change(_Vsn, Chs, _Extra) ->
{ok, {Chs, 0}}.
8. 8
Супервизор
8
• Наблюдающий и наблюдаемый
• Спецификация «ребенка»:
• Супервизоры супервизоров или кто
следит за следящими
{ChildId, StartFunc, Restart, Shutdown, Type, Modules}.
9. 99
child_spec() = {Id,StartFunc,Restart,Shutdown,Type,Modules}
Id = term()
StartFunc = {M,F,A}
M = F = atom()
A = [term()]
Restart = permanent | transient | temporary
Shutdown = brutal_kill | int()>0 | infinity
Type = worker | supervisor
Modules = [Module] | dynamic
Module = atom()
Какой должен быть ребенок
14. 1414
• Быстро поднятое не считается
упавшим
• Уронить до конца и поднять с самого
начала
15. 15
Храните состояние вовне
15
• Очереди сообщений
• Быстрые key/value хранилища
• Всегда можно что-то потерять пока
оно не записано в постоянное
хранилище