综合二区_欧美成人综合_欧美成人二区_a黄视频_亚洲视频在线播放_一区二区三区视频免费看

µ±Ç°Î»ÖãºÊ×Ò³ > ÍøÕ¾¾ÉÀ¸Ä¿ > ѧϰ԰µØ > Éè¼ÆÈí¼þ½Ì³Ì > gen_server tasting Ö®³¬¼òµ¥Ãû³Æ·þÎñ£¨Ðø£©

gen_server tasting Ö®³¬¼òµ¥Ãû³Æ·þÎñ£¨Ðø£©
2010-01-13 23:16:22  ×÷Õß:  À´Ô´:
    ǰ¼¸ÌìдÁËÆª¡¶gen_server tasting Ö®³¬¼òµ¥Ãû³Æ·þÎñ ¡·¶«Î÷£¬Ç×ÉíÌåÑéÁË erlang otp µÄÇ¿º·ÍþÁ¦¡£²»¹ýÕýËùν“³¬¼òµ¥”£¬ÄǸö°æ±¾»¹ÊǺܳõ¼¶µÄ£¬ËùÒÔÕâÁ½Ìì±ß¼ÌÐøÑо¿±ß¶¯ÊÖ£¬¿ª·¢µü´ú°æ±¾µÄÃû³Æ·þÎñ¡£

 

ÔÚÕâ¸ö°æ±¾ÖУ¬ÐèÒªÌṩÈçϹ¦ÄÜ£º

 

  1. ʹÓà otp µÄ supervisor ¼à¿ØÊ÷£¬±£Ö¤·þÎñ¿É¿¿ÐÔ¡£
  2. Ìí¼ÓÈÕÖ¾¹¦ÄÜ£¬Í¨¹ý¶¨ÖÆ sasl alarm_handler À´¼Ç¼¾¯¸æÊ¼þ¡£
  3. ½«Ãû³Æ·þÎñ´ò°üΪ application£¬ÔÝÇҽРvsns °É£¬very stabilization name server ºÇºÇ¡£
  4. ¿ª·Å socket ·þÎñ £¨Ê¹Óðë×èÈûµÄ»ìºÏģʽ£©£¬Ê¹Óà vsns://verb /param ×Ô¶¨ÒåЭÒé¶ÔÍâÌṩ·ÃÎÊÖ§³Ö¡£

×îÖÕÑéÖ¤ÐԵŦÄܲâÊÔÓÃÀýÈçÏ£¬Ö÷ÒªµÄ²âÊÔ´úÂëλÓÚ test/0 ·½·¨ÖУ¬ÆäÉϵö·½·¨¶¼ÓÃÓÚ socket ͨÐÅ£º

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(vsns_tcp_client).   
  2.   
  3. -author(lzy).   
  4. -email(lzy.dev@gmail.com).   
  5. -date("2009.02.06").   
  6. -vsn(0.11).   
  7.   
  8. -compile(export_all).   
  9.   
  10. conn() ->   
  11.     {ok, Socket} = gen_tcp:connect("localhost"8304,   
  12.         [binary, {packet, 2}, {reuseaddr, true}, {active, once}]),   
  13.     Socket.   
  14.   
  15. eval(Socket, Args, AssertVal) ->   
  16.     ok = gen_tcp:send(Socket, Args),   
  17.     receive   
  18.         {tcp, _, AssertVal} ->   
  19.             io:format("Ok. ~p = ~p.~n", [Args, AssertVal]);   
  20.         {tcp_closed, _} ->   
  21.             case Args of   
  22.                 <<"vsns://kernel_oops">> ->   
  23.                     io:format("Ok. kernel_oops = tcp_closed.~n");   
  24.                 _Other ->   
  25.                     io:format("Connection abort by server.~n")   
  26.             end;   
  27.         Other  ->   
  28.             io:format("Assert faild. ~p != ~p.~n", [Other, AssertVal])   
  29.     end,   
  30.     inet:setopts(Socket, [{active, once}]).   
  31.   
  32. close(Socket) ->   
  33.     gen_tcp:close(Socket).   
  34.   
  35. test() ->   
  36.     S = conn(),   
  37.   
  38.     eval(S, <<"vsns://remove_all">>, <<"ack">>),   
  39.   
  40.     eval(S, <<"vsns://save/abc/123">>, <<"">>),   
  41.     eval(S, <<"vsns://save/abc/456">>, <<"123">>),   
  42.     eval(S, <<"vsns://save/abc/789">>, <<"456">>),   
  43.   
  44.     eval(S, <<"vsns://load_all">>, <<"ack">>),   
  45.   
  46.     eval(S, <<"vsns://remove/abc">>, <<"789">>),   
  47.     eval(S, <<"vsns://remove/not_value">>, <<"">>),   
  48.   
  49.     eval(S, <<"foo">>, <<"unknow">>),   
  50.   
  51.     eval(S, <<"vsns://kernel_oops">>, <<"">>),   
  52.   
  53.     ok = close(S),   
  54.   
  55.     pass.   
  56.   
  57. %% File end.  

 

          ʵ¼ÊʵÏÖ supervisor ¼à¿ØÊ÷¡¢ÈÕÖ¾ºÍ¾¯¸æÊ¼þ¹¦ÄܵĹý³Ì£¬Ò²ÊÇѧϰ ¡¶Erlang ³ÌÐòÉè¼Æ¡·µÄ¹ý³Ì¡£

 

          Ê×ÏÈ£¬ÎªÃû³Æ·þÎñÌí¼Ó¼à¿Ø½ø³Ì¡£erlang otp ¼à¿ØÊ÷ºÜ¼òµ¥£¬Ö»ÐèҪʵÏÖÒ»¸ö supervisor behaviour module Ìṩ¸ø otp supervisor Ä£¿é¾Í¿ÉÒÔ£¬Ç°Ãæ°æ±¾µÄÃû³Æ·þÎñÊÇͨ¹ý erlang shell Æô¶¯µÄ£¬ÔÚÒÔºó½«ÓÉÕâ¸ö¼à¿Ø½ø³ÌÀ´Æô¶¯Ëý£¬Ö÷ÒªµÄÆô¶¯´úÂëÔÚ init/1 ·½·¨ÖУ¬¼à¿ØÄ£¿é´úÂëÈçÏ£º

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(name_server_sup).   
  2.   
  3. -author(lzy).   
  4. -email(lzy.dev@gmail.com).   
  5. -date("2009.02.04").   
  6. -vsn(0.1).   
  7.   
  8. -behaviour(supervisor).   
  9.   
  10. %% gen_supervisor behaviour callback functions.   
  11. -export([init/1]).   
  12.   
  13. %% Interface functions.   
  14. -export([start/0, start_in_shell/0, start_link/1]).   
  15.   
  16. start() ->   
  17.     spawn(fun() -> supervisor:start_link({local, ?MODULE}, ?MODULE, _Arg = []) end).   
  18.   
  19. start_in_shell() ->   
  20.     {ok, Pid} = supervisor:start_link({local, ?MODULE}, ?MODULE, _Arg = []),   
  21.     unlink(Pid).   
  22.   
  23. start_link(Args) ->   
  24.     supervisor:start_link({local, ?MODULE}, ?MODULE, Args).   
  25.   
  26. init([]) ->   
  27.     gen_event:swap_handler(alarm_handler, {alarm_handler, swap}, {vsns_alarm_handler, foo}),   
  28.   
  29.     {ok, {   
  30.             {one_for_one, 310},   
  31.             [{   
  32.                 vsns_name_server,   
  33.                 {name_server, start_link, []},   
  34.                 permanent,   
  35.                 1,   
  36.                 worker,   
  37.                 [name_server]   
  38.             }]         
  39.     }}.   
  40.   
  41. %% File end.  

 

          ÓÐÁËÕâ¸ö name_server_sup ¾Í²»Å name_server ±ÀÀ£ÁË£¬supervisor ½ø³Ì»á¸ºÔðÖØÐÂÆô¶¯£¬¶ÔÓÚÃèÊö¼à¿Ø²ßÂÔµÄÊý¾Ý½á¹¹¿É²Î¿¼ erlang doc¡£ÆäÖÐµÄ vsns_alarm_handler ÊǶ¨ÖƵľ¯¸æÊ¼þ´¦ÀíÄ£¿é£¬¸ºÔ𽫷þÎñÖеı¨¾¯¼Ç¼µ½ erlang sasl ÈÕÖ¾ÖУ¬ºóÆÚ¿ÉÒÔʹÓà rb ¹¤¾ßÀ´²é¿´´¦Àí¡£½ÓÏÂÀ´¾ÍÊǾ¯¸æÈÕÖ¾´¦ÀíÄ£¿é´úÂ룺

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(vsns_alarm_handler).   
  2.   
  3. -author(lzy).   
  4. -email(lzy.dev@gmail.com).   
  5. -date("2009.02.04").   
  6. -vsn(0.11).   
  7.   
  8. -behaviour(gen_event).   
  9.   
  10. %% gen_event behaviour callback functions.   
  11. -export([init/1, handle_event/2, handle_call/2, handle_info/2, terminate/2, code_change/3]).   
  12.   
  13. init(Args) ->   
  14.     io:format("vsns_alarm_handler init : ~p.~n", [Args]),   
  15.     {ok, Args}.   
  16.   
  17. handle_event({set_alarm, {remove_all, From}}, _State) ->   
  18.     error_logger:error_msg("vsns depot clear by ~p started.~n.", [From]),   
  19.     {ok, _State};   
  20.   
  21. handle_event({clear_alarm, {remove_all, From}}, _State) ->   
  22.     error_logger:error_msg("vsns depot clear by ~p done.~n.", [From]),   
  23.     {ok, _State};   
  24.   
  25. handle_event(Event, State) ->   
  26.     error_logger:error_msg("unmatched event: ~p.~n", [Event, State]),   
  27.     {ok, State}.   
  28.   
  29. handle_call(_Req, State) ->   
  30.     {ok, State, State}.   
  31.        
  32. handle_info(_Info, State) ->   
  33.     {ok, State}.   
  34.   
  35. terminate(_Reason, _State) ->   
  36.     ok.   
  37.   
  38. code_change(_OldVsn, State, _Extra) ->   
  39.     {ok, State}.   
  40.   
  41. %% File end.  
 

          ¹é¸ùµ½µ×£¬¾ÍÊÇͨ¹ý error_logger:error_msg µ÷ÓÃÀ´¼Ç¼ÈÕÖ¾¡£µ±È»»¹Éæ¼°µ½ erlang sasl µÄÅäÖãº

 

Config´úÂë ¸´ÖÆ´úÂë
  1. %% file name: sasl_log.config   
  2. %% auther: lzy   
  3. %% email: lzy.dev@gmail.com   
  4. %% date: 2009.02.04  
  5. %% version: 0.1  
  6.   
  7. [{sasl, [   
  8.     {sasl_error_logger, false},    
  9.     {errlog_type, error},   
  10.     {error_logger_mf_dir, "./logs"},   
  11.     %% 10M per log file.   
  12.     {error_logger_mf_maxbytes, 1048760},   
  13.     {error_logger_mf_maxfiles, 5}   
  14. ]}].   
  15.   
  16. %% File end.  
 

          ¸ÃÅäÖÃÎļþ¿ÉÒÔͨ¹ý erlang shell µÄ Æô¶¯Æô¶¯²ÎÊýÖ¸¶¨¡£-boot start_sasl -config .\sasl_log¡£ÔÙ½ÓÏÂÀ´¾ÍÊÇ´ò°ü vsns application£¬ÕâÐèÒªÒ»¸ö application ÃèÊöÎļþºÍÒ»¸ö application behavior Ä£¿é£¬ºÜ¼òµ¥¾ßÌåÅäÖòÎÊýÓïÒâ¿É²Î¿¼ erlang doc¡£

 

App´úÂë ¸´ÖÆ´úÂë
  1. %% file name: vsns.app   
  2. %% auther: lzy   
  3. %% email: lzy.dev@gmail.com   
  4. %% date: 2009.02.05  
  5. %% version: 0.1  
  6.   
  7. {   
  8.     application, vsns,   
  9.     [   
  10.         {description, "very stabilization name service."},   
  11.         {vsn, "1.0a"},   
  12.         {modules, [vsns_app, vsns_supervisor, name_server, vsns_alarm_handler]},   
  13.         {registered, [vsns_supervisor, name_server]},   
  14.         {applications, [kernel, stdlib]},   
  15.         {mod, {vsns_app, []}},   
  16.         {start_phases, []}   
  17.     ]   
  18. }.   
  19.   
  20. %% File end.  
 
Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(vsns_app).   
  2.   
  3. -author(lzy).   
  4. -email(lzy.dev@gmail.com).   
  5. -date("2009.02.05").   
  6. -vsn(0.1).   
  7.   
  8. -behavior(application).   
  9.   
  10. -export([start/2, stop/1]).   
  11.   
  12. start(_Type, Args) ->   
  13.     name_server_sup:start_link(Args).   
  14.   
  15. stop(_State) ->   
  16.     void.   
  17.   
  18. %% File end.  

 

          ¾­¹ýÕâÑùµÄ°ü×°£¬¾Í¿ÉÒÔͨ¹ý application:start(vsns) µ÷ÓÃÀ´Æô¶¯ vsns ·þÎñ¡£Í¨¹ý appmon ¹¤¾ß¿ÉÒÔ¿´µ½ÈçϽø³ÌÊ÷£º

 

vsns ½ø³ÌÊ÷

 

µ½ÕâÀÎÒÃǾͿÉÒÔͨ¹ý erlang À´Ê¹Óà vsns ÁË¡£

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. C:\Program Files\erl5.6.4\usr\lzy_app\vsns>..\..\..\bin\erl.exe -sname vsns +P 1  
  2. 02400 -smp enable +S 1 -boot start_sasl -config sasl_log   
  3. Eshell V5.6.4  (abort with ^G)   
  4. (vsns@srclzy)1> application:start(vsns).   
  5. vsns_alarm_handler init : {foo,{alarm_handler,[]}}.   
  6. name_server starting.   
  7. ok   
  8. (vsns@srclzy)2> name_server:save(abc, 123).   
  9. undefined   
  10. (vsns@srclzy)3> name_server:load_all().   
  11. [{abc,123}]  
 

          ×îºó»¹ÐèÒªÒ»¸ö socket tcp ·þÎñÆ÷£¬À´½« vsns ±©Â¶³öÀ´£¬ÔÊÐíÆäËü client À´Ê¹Ó÷þÎñ¡£otp ÖÐûÓÐÀàËÆµÄ socket server behavior£¬µ«¿ÉÒÔͨ¹ý gen_server À´ÊµÏÖ£¬µ±È»ÉõÖÁ¿ÉÒÔʵÏÖÒ»¸ö·Ç otp Ïà¹ØµÄ socket ·þÎñÆ÷¡£ÕâÀï Serge Aleynikov ʵÏÖÁËÒ»¸öºÜºÃ tcp ·þÎñÆ÷£¬»ùÓÚÓÐÏÞ״̬»úģʽÀ´´¦ÀíÇëÇó£¬ÔÚ´Ë×öÁ˺ܺõIJûÊö£ºBuilding a Non-blocking TCP server using OTP principles £¬²»¹ý¿ÖÅÂÐèÒª´úÀíÀ´´ò¿ªÁ¬½Ó¡£ÔÚËû¸ø³öµÄ´úÂëÖУ¬ÎÒÌí¼ÓÁ˼¸ÐдúÂ룬½« socket server ÌṩµÄ·þÎñÊÇ×öΪ¿ÉÅäÖõÄ£¬Í¨¹ý application »·¾³À´ÅäÖà socket server ʹÓÃµÄ gen_fsm behaviour module£¬´óԼλÓÚ tcp_server_app Ä£¿éµÄ 15 ºÍ 27 ÐС£

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(tcp_server_app).   
  2.   
  3. ... ...   
  4.   
  5. -define(DEF_SERVICE, tcp_echo_fsm).   
  6.   
  7. ... ...   
  8.   
  9. start(_Type,  _Args) ->   
  10.     ListenPort = get_app_env(listen_port, ?DEF_PORT),    
  11.     ServiceMod = get_app_env(service_mod, ?DEF_SERVICE),    
  12.     supervisor:start_link({local, ?MODULE}, ?MODULE, [ListenPort, ServiceMod]).   
  13.   
  14. ... ...  
 

          ÔÚ saleyn_tcp_server ÖÐÌṩµÄÊÇ echo ·þÎñ¡£ÎªÁ˽« saleyn_tcp_server ·þÎñÖ¸¶¨³É vsns£¬³ýÁËÉÏÃæµÄÐÞ¸ÄÍ⣬ʣϾÍÖ»ÐèҪʵÏÖÒ»¸öµ÷Óà vsns µÄ gen_fsm behaviour module ÁË£¬´úÂëºÜ¼òµ¥£¬ÊÇ»ùÓÚ tcp_echo_fsm Ð޸ĵÃÀ´µÄ£¬ºÇºÇ¡£

 

Erlang´úÂë ¸´ÖÆ´úÂë
  1. -module(vsns_tcp_fsm).   
  2.   
  3. -author(lzy).   
  4. -email(lzy.dev@gmail.com).   
  5. -date("2009.02.06").   
  6. -vsn(0.1).   
  7. -remark("vsns_tcp_fsm used by saleyn_tcp_server appliction to support vsns socket server.").   
  8. -remark("It referenced from saleyn_tcp_server/tcp_echo_fsm module.").   
  9.   
  10. -behaviour(gen_fsm).   
  11.   
  12. -export([start_link/0, set_socket/2]).   
  13.   
  14. %% gen_fsm callbacks   
  15. -export([init/1, handle_event/3,   
  16.          handle_sync_event/4, handle_info/3, terminate/3, code_change/4]).   
  17.   
  18. %% FSM States   
  19. -export([   
  20.     'WAIT_FOR_SOCKET'/2,   
  21.     'WAIT_FOR_DATA'/2  
  22. ]).   
  23.   
  24. -record(state, {   
  25.                 socket,    % client socket   
  26.                 addr       % client address   
  27.                }).   
  28.   
  29. -define(TIMEOUT, 120000).   
  30.   
  31. %%%------------------------------------------------------------------------   
  32. %%% API   
  33. %%%------------------------------------------------------------------------   
  34.   
  35. %%-------------------------------------------------------------------------   
  36. %% @spec (Socket) -> {ok,Pid} | ignore | {error,Error}   
  37. %% @doc To be called by the supervisor in order to start the server.   
  38. %%      If init/1 fails with Reason, the function returns {error,Reason}.   
  39. %%      If init/1 returns {stop,Reason} or ignore, the process is   
  40. %%      terminated and the function returns {error,Reason} or ignore,   
  41. %%      respectively.   
  42. %% @end   
  43. %%-------------------------------------------------------------------------   
  44. start_link() ->   
  45.     gen_fsm:start_link(?MODULE, [], []).   
  46.   
  47. set_socket(Pid, Socket) when is_pid(Pid), is_port(Socket) ->   
  48.     gen_fsm:send_event(Pid, {socket_ready, Socket}).   
  49.   
  50. %%%------------------------------------------------------------------------   
  51. %%% Callback functions from gen_server   
  52. %%%------------------------------------------------------------------------   
  53.   
  54. %%-------------------------------------------------------------------------   
  55. %% Func: init/1  
  56. %% Returns: {ok, StateName, StateData}          |   
  57. %%          {ok, StateName, StateData, Timeout} |   
  58. %%          ignore                              |   
  59. %%          {stop, StopReason}   
  60. %% @private   
  61. %%-------------------------------------------------------------------------   
  62. init([]) ->   
  63.     process_flag(trap_exit, true),   
  64.     {ok, 'WAIT_FOR_SOCKET', #state{}}.   
  65.   
  66. %%-------------------------------------------------------------------------   
  67. %% Func: StateName/2  
  68. %% Returns: {next_state, NextStateName, NextStateData}          |   
  69. %%          {next_state, NextStateName, NextStateData, Timeout} |   
  70. %%          {stop, Reason, NewStateData}   
  71. %% @private   
  72. %%-------------------------------------------------------------------------   
  73. 'WAIT_FOR_SOCKET'({socket_ready, Socket}, State) when is_port(Socket) ->   
  74.     % Now we own the socket   
  75.     inet:setopts(Socket, [binary, {packet, 2}, {reuseaddr, true}, {active, once}]),   
  76.     {ok, {IP, _Port}} = inet:peername(Socket),   
  77.     {next_state, 'WAIT_FOR_DATA', State#state{socket=Socket, addr=IP}, ?TIMEOUT};   
  78.   
  79. 'WAIT_FOR_SOCKET'(Other, State) ->   
  80.     error_logger:error_msg("State: 'WAIT_FOR_SOCKET'. Unexpected message: ~p\n", [Other]),   
  81.     %% Allow to receive async messages   
  82.     {next_state, 'WAIT_FOR_SOCKET', State}.   
  83.   
  84. %% Notification event coming from client   
  85. 'WAIT_FOR_DATA'({data, Data}, #state{socket=S} = State) ->   
  86.     ok = handle_data(S, string:tokens(binary_to_list(Data), "/")),   
  87.     inet:setopts(S, [{active, once}]),   
  88.     {next_state, 'WAIT_FOR_DATA', State, ?TIMEOUT};   
  89.   
  90. 'WAIT_FOR_DATA'(timeout, State) ->   
  91.     error_logger:error_msg("~p Client connection timeout - closing.\n", [self()]),   
  92.     {stop, normal, State};   
  93.   
  94. 'WAIT_FOR_DATA'(Data, State) ->   
  95.     io:format("~p Ignoring data: ~p\n", [self(), Data]),   
  96.     {next_state, 'WAIT_FOR_DATA', State, ?TIMEOUT}.   
  97.   
  98. %%-------------------------------------------------------------------------   
  99. %% Func: handle_event/3  
  100. %% Returns: {next_state, NextStateName, NextStateData}          |   
  101. %%          {next_state, NextStateName, NextStateData, Timeout} |   
  102. %%          {stop, Reason, NewStateData}   
  103. %% @private   
  104. %%-------------------------------------------------------------------------   
  105. handle_event(Event, StateName, StateData) ->   
  106.     {stop, {StateName, undefined_event, Event}, StateData}.   
  107.   
  108. %%-------------------------------------------------------------------------   
  109. %% Func: handle_sync_event/4  
  110. %% Returns: {next_state, NextStateName, NextStateData}            |   
  111. %%          {next_state, NextStateName, NextStateData, Timeout}   |   
  112. %%          {reply, Reply, NextStateName, NextStateData}          |   
  113. %%          {reply, Reply, NextStateName, NextStateData, Timeout} |   
  114. %%          {stop, Reason, NewStateData}                          |   
  115. %%          {stop, Reason, Reply, NewStateData}   
  116. %% @private   
  117. %%-------------------------------------------------------------------------   
  118. handle_sync_event(Event, _From, StateName, StateData) ->   
  119.     {stop, {StateName, undefined_event, Event}, StateData}.   
  120.   
  121. %%-------------------------------------------------------------------------   
  122. %% Func: handle_info/3  
  123. %% Returns: {next_state, NextStateName, NextStateData}          |   
  124. %%          {next_state, NextStateName, NextStateData, Timeout} |   
  125. %%          {stop, Reason, NewStateData}   
  126. %% @private   
  127. %%-------------------------------------------------------------------------   
  128. handle_info({tcp, Socket, Bin}, StateName, #state{socket=Socket} = StateData) ->   
  129.     % Flow control: enable forwarding of next TCP message   
  130.     inet:setopts(Socket, [{active, once}]),   
  131.     ?MODULE:StateName({data, Bin}, StateData);   
  132.   
  133. handle_info({tcp_closed, Socket}, _StateName,   
  134.             #state{socket=Socket, addr=Addr} = StateData) ->   
  135.     error_logger:info_msg("~p Client ~p disconnected.\n", [self(), Addr]),   
  136.     {stop, normal, StateData};   
  137.   
  138. handle_info(_Info, StateName, StateData) ->   
  139.     {noreply, StateName, StateData}.   
  140.   
  141. %%-------------------------------------------------------------------------   
  142. %% Func: terminate/3  
  143. %% Purpose: Shutdown the fsm   
  144. %% Returns: any   
  145. %% @private   
  146. %%-------------------------------------------------------------------------   
  147. terminate(_Reason, _StateName, #state{socket=Socket}) ->   
  148.     (catch gen_tcp:close(Socket)),   
  149.     ok.   
  150.   
  151. %%-------------------------------------------------------------------------   
  152. %% Func: code_change/4  
  153. %% Purpose: Convert process state when code is changed   
  154. %% Returns: {ok, NewState, NewStateData}   
  155. %% @private   
  156. %%-------------------------------------------------------------------------   
  157. code_change(_OldVsn, StateName, StateData, _Extra) ->   
  158.     {ok, StateName, StateData}.   
  159.   
  160. handle_data(S, ["vsns:""save", Key, Value]) ->   
  161.     gen_tcp:send(S, list_to_binary(swap_undefined(name_server:save(Key, Value))));   
  162.   
  163. handle_data(S, ["vsns:""load", Key]) ->   
  164.     gen_tcp:send(S, list_to_binary(swap_undefined(name_server:load(Key))));   
  165.   
  166. handle_data(S, ["vsns:""load_all"]) ->   
  167.     name_server:load_all(),   
  168.     gen_tcp:send(S, <<"ack">>); % list_to_binary(name_server:load_all())   
  169.   
  170. handle_data(S, ["vsns:""remove", Key]) ->   
  171.     gen_tcp:send(S, list_to_binary(swap_undefined(name_server:remove(Key))));   
  172.   
  173. handle_data(S, ["vsns:""remove_all"]) ->   
  174.     name_server:remove_all(),   
  175.     gen_tcp:send(S, <<"ack">>); % list_to_binary(name_server:remove_all())   
  176.   
  177. handle_data(S, ["vsns:""kernel_oops"]) ->   
  178.     gen_tcp:send(S, list_to_binary(name_server:kernel_oops()));   
  179.   
  180. handle_data(S, _Data) ->   
  181.     gen_tcp:send(S, <<"unknow">>).   
  182.   
  183. swap_undefined(undefined) ->   
  184.     "";   
  185.   
  186. swap_undefined(Other) ->   
  187.     Other.   
  188.   
  189. %   File end.  
Ö÷Õ¾Ö©Öë³ØÄ£°å£º 999在线观看精品免费不卡网站 | a免费在线 | 97超碰导航| 中国一级毛片在线播放 | 干少妇18p| 国产成人精品亚洲日本在线桃色 | 热久久久久 | 91高清在线视频 | 天天添夜夜操 | 国产一区二区三区免费观看在线 | 国产二区精品视频 | 91亚洲国产亚洲国产亚洲 | 91国内在线观看 | 懂色av一区二区三区四区 | 一级片在线观看网站 | 国产一区二区三区播放 | 国产精品一区91 | 一级片免费在线 | 亚洲成人999 | 亚洲一区二区三区在线观看免费 | 成年免费黄色网 | 免费亚洲网站 | 国产视频一区二区三区在线播放 | 亚洲欧美偷拍一区 | 国产日韩欧美一区二区在线播放 | 免费精品视频一区二区三区 | 91视频污版 | 91视频-全网资源最全平台 | 国产91精品高清一区二区三区 | 97插插| 日韩精品小视频 | 91偷自产一区二区三区精品 | 91亚洲国产在人线播放午夜 | 91精品久久久久久综合 | 国产日韩欧美一区二区在线播放 | 在线国产一区二区 | 国产精品一区91 | 91高清完整版 | 91精品在线免费 | 第一色网站 | 狠狠色丁香婷婷综合橹88 |