亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区

當(dāng)前位置:首頁(yè) > 網(wǎng)站舊欄目 > 學(xué)習(xí)園地 > 設(shè)計(jì)軟件教程 > Erlang:一個(gè)通用的網(wǎng)絡(luò)服務(wù)器

Erlang:一個(gè)通用的網(wǎng)絡(luò)服務(wù)器
2010-01-13 23:12:05  作者:  來(lái)源:
前面幾篇文章里談到了Erlang的gen_tcp網(wǎng)絡(luò)編程和Erlang/OPT的gen_server模塊,現(xiàn)在讓我們將它們兩者綁定在一起

大多數(shù)人認(rèn)為“服務(wù)器”意味著網(wǎng)絡(luò)服務(wù)器,但Erlang使用這個(gè)術(shù)語(yǔ)時(shí)表達(dá)的是更抽象的意義
gen_serer在Erlang里是基于它的消息傳遞協(xié)議來(lái)操作的服務(wù)器,我們可以在此基礎(chǔ)上嫁接一個(gè)TCP服務(wù)器,但這需要一些工作

網(wǎng)絡(luò)服務(wù)器的結(jié)構(gòu)
大部分網(wǎng)絡(luò)服務(wù)器有相似的架構(gòu)
首先它們創(chuàng)建一個(gè)監(jiān)聽(tīng)socket來(lái)監(jiān)聽(tīng)接收的連接
然后它們進(jìn)入一個(gè)接收狀態(tài),在這里一直循環(huán)接收新的連接,直到結(jié)束(結(jié)束表示連接已經(jīng)到達(dá)并開(kāi)始真正的client/server工作)

先看看前面網(wǎng)絡(luò)編程里的echo server的例子:
Java代碼 復(fù)制代碼
  1. -module(echo).   
  2. -author('Jesse E.I. Farmer <jesse@20bits.com>').   
  3. -export([listen/1]).   
  4.   
  5. -define(TCP_OPTIONS, [binary, {packet, 0}, {active, false}, {reuseaddr, true}]).   
  6.   
  7. % Call echo:listen(Port) to start the service.   
  8. listen(Port) ->   
  9.     {ok, LSocket} = gen_tcp:listen(Port, ?TCP_OPTIONS),   
  10.     accept(LSocket).   
  11.   
  12. % Wait for incoming connections and spawn the echo loop when we get one.   
  13. accept(LSocket) ->   
  14.     {ok, Socket} = gen_tcp:accept(LSocket),   
  15.     spawn(fun() -> loop(Socket) end),   
  16.     accept(LSocket).   
  17.   
  18. % Echo back whatever data we receive on Socket.   
  19. loop(Socket) ->   
  20.     case gen_tcp:recv(Socket, 0) of   
  21.         {ok, Data} ->   
  22.             gen_tcp:send(Socket, Data),   
  23.             loop(Socket);   
  24.         {error, closed} ->   
  25.             ok   
  26.     end.  

你可以看到,listen會(huì)創(chuàng)建一個(gè)監(jiān)聽(tīng)socket并馬上調(diào)用accept
accept會(huì)等待進(jìn)來(lái)的連接,創(chuàng)建一個(gè)新的worker(loop)來(lái)處理真正的工作,然后等待下一個(gè)連接

在這部分代碼里,父進(jìn)程擁有l(wèi)isten socket和accept loop兩者
后面我們會(huì)看到,如果我們集成accept/listen loop和gen_server的話這樣做并不好

抽象網(wǎng)絡(luò)服務(wù)器
網(wǎng)絡(luò)服務(wù)器有兩部分:連接處理和業(yè)務(wù)邏輯
上面講到,連接處理對(duì)每個(gè)網(wǎng)絡(luò)服務(wù)器都是幾乎一樣的
理想狀態(tài)下我們可以這樣做:
Java代碼 復(fù)制代碼
  1. -module(my_server).   
  2. start(Port) ->   
  3.   connection_handler:start(my_server, Port, businees_logic).   
  4.   
  5. business_logic(Socket) ->   
  6.   % Read data from the network socket and do our thang!  

讓我們繼續(xù)完成它

實(shí)現(xiàn)一個(gè)通用網(wǎng)絡(luò)服務(wù)器
使用gen_server來(lái)實(shí)現(xiàn)一個(gè)網(wǎng)絡(luò)服務(wù)器的問(wèn)題是,gen_tcp:accept調(diào)用是堵塞的
如果我們?cè)诜⻊?wù)器的初始化例程里調(diào)用它,那么整個(gè)gen_server機(jī)制都會(huì)堵塞,直到客戶(hù)端建立連接

有兩種方式來(lái)繞過(guò)這個(gè)問(wèn)題
一種方式為使用低級(jí)連接機(jī)制來(lái)支持非堵塞(或異步)accept
有許多方法來(lái)支持這樣做,最值得注意的是gen_tcp:controlling_process,它幫你管理當(dāng)客戶(hù)端建立連接時(shí)誰(shuí)接受了什么消息

我認(rèn)為另一種比較簡(jiǎn)單而更優(yōu)雅的方式是,一個(gè)單獨(dú)的進(jìn)程來(lái)監(jiān)聽(tīng)socket
該進(jìn)程做兩件事:監(jiān)聽(tīng)“接收連接”消息以及分配新的接收器
當(dāng)它接收一條新的“接收連接”的消息時(shí),就知道該分配新的接收器了

接收器可以任意調(diào)用堵塞的gen_tcp:accept,因?yàn)樗试S在自己的進(jìn)程里
當(dāng)它接受一個(gè)連接后,它發(fā)出一條異步消息傳回給父進(jìn)程,并且立即調(diào)用業(yè)務(wù)邏輯方法

這里是代碼,我加了一些注釋?zhuān)M勺x性還可以:
Java代碼 復(fù)制代碼
  1. -module(socket_server).   
  2. -author('Jesse E.I. Farmer <jesse@20bits.com>').   
  3. -behavior(gen_server).   
  4.   
  5. -export([init/1, code_change/3, handle_call/3, handle_cast/2, handle_info/2, terminate/2]).   
  6. -export([accept_loop/1]).   
  7. -export([start/3]).   
  8.   
  9. -define(TCP_OPTIONS, [binary, {packet, 0}, {active, false}, {reuseaddr, true}]).   
  10.   
  11. -record(server_state, {   
  12.         port,   
  13.         loop,   
  14.         ip=any,   
  15.         lsocket=null}).   
  16.   
  17. start(Name, Port, Loop) ->   
  18.     State = #server_state{port = Port, loop = Loop},   
  19.     gen_server:start_link({local, Name}, ?MODULE, State, []).   
  20.   
  21. init(State = #server_state{port=Port}) ->   
  22.     case gen_tcp:listen(Port, ?TCP_OPTIONS) of   
  23.         {ok, LSocket} ->   
  24.             NewState = State#server_state{lsocket = LSocket},   
  25.             {ok, accept(NewState)};   
  26.         {error, Reason} ->   
  27.             {stop, Reason}   
  28.     end.   
  29.   
  30. handle_cast({accepted, _Pid}, State=#server_state{}) ->   
  31.     {noreply, accept(State)}.   
  32.   
  33. accept_loop({Server, LSocket, {M, F}}) ->   
  34.     {ok, Socket} = gen_tcp:accept(LSocket),   
  35.     % Let the server spawn a new process and replace this loop   
  36.     % with the echo loop, to avoid blocking   
  37.     gen_server:cast(Server, {accepted, self()}),   
  38.     M:F(Socket).   
  39.       
  40. % To be more robust we should be using spawn_link and trapping exits   
  41. accept(State = #server_state{lsocket=LSocket, loop = Loop}) ->   
  42.     proc_lib:spawn(?MODULE, accept_loop, [{self(), LSocket, Loop}]),   
  43.     State.   
  44.   
  45. % These are just here to suppress warnings.   
  46. handle_call(_Msg, _Caller, State) -> {noreply, State}.   
  47. handle_info(_Msg, Library) -> {noreply, Library}.   
  48. terminate(_Reason, _Library) -> ok.   
  49. code_change(_OldVersion, Library, _Extra) -> {ok, Library}.  

我們使用gen_server:cast來(lái)傳遞異步消息給監(jiān)聽(tīng)進(jìn)程,當(dāng)監(jiān)聽(tīng)進(jìn)程接受accepted消息后,它分配一個(gè)新的接收器

目前,這個(gè)服務(wù)器不是很健壯,因?yàn)槿绻麩o(wú)論什么原因活動(dòng)的接收器失敗以后,服務(wù)器會(huì)停止接收新的連接
為了讓它變得更像OTP,我們因該捕獲異常退出并且在連接失敗時(shí)分配新的接收器

一個(gè)通用的echo服務(wù)器
echo服務(wù)器是最簡(jiǎn)單的服務(wù)器,讓我們使用我們新的抽象socket服務(wù)器來(lái)寫(xiě)它:
Java代碼 復(fù)制代碼
  1. -module(echo_server).   
  2. -author('Jesse E.I. Farmer <jesse@20bits.com>').   
  3.   
  4. -export([start/0, loop/1]).   
  5.   
  6. % echo_server specific code   
  7. start() ->   
  8.     socket_server:start(?MODULE, 7000, {?MODULE, loop}).   
  9. loop(Socket) ->   
  10.     case gen_tcp:recv(Socket, 0) of   
  11.         {ok, Data} ->   
  12.             gen_tcp:send(Socket, Data),   
  13.             loop(Socket);   
  14.         {error, closed} ->   
  15.             ok   
  16.     end.  

你可以看到,服務(wù)器只含有自己的業(yè)務(wù)邏輯
連接處理被封裝到socket_server里面
而這里的loop方法也和最初的echo服務(wù)器一樣

希望你可以從中學(xué)到點(diǎn)什么,我覺(jué)得我開(kāi)始理解Erlang了

歡迎回復(fù),特別關(guān)于是如何改進(jìn)我的代碼,cheers!
安徽新華電腦學(xué)校專(zhuān)業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢(xún)
亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区
视频一区不卡| 日日碰狠狠躁久久躁婷婷| 熟女少妇精品一区二区| αv一区二区三区| 色综合久久久久久中文网| 欧美日韩一区在线播放| 久久久久久久91| 日韩av高清在线看片| 91精品国产综合久久久久久久久| 国产精品国产精品国产专区不卡 | www.日韩免费| 日韩亚洲欧美视频| 久久久久久久久亚洲| 日本精品免费在线观看| 国产高清一区二区三区| 性一交一乱一伧国产女士spa| 99国产在线| 亚洲精品国产精品久久| 91精品久久久久久久久中文字幕 | 亚洲精品高清视频| 69av在线播放| 日韩中文字幕在线不卡| 久久精品成人一区二区三区蜜臀| 日本不卡在线观看视频| 久久久久久网站| 欧美在线不卡区| 国产精品欧美激情在线观看| 国语精品免费视频| 久久在精品线影院精品国产| 国产欧美日韩综合精品| 一区二区三区国产福利| 国产精品av网站| 日本精品一区二区三区四区| 久久久久久久999精品视频| 欧美久久综合性欧美| 国产精品久久久久久超碰| 国产日韩精品一区观看| 亚洲一区二区三区在线免费观看 | 国产精品国产亚洲精品看不卡| 国产在线精品一区免费香蕉| 欧美日韩不卡合集视频| 操人视频欧美| 日本欧美视频在线观看| 久久久精品一区二区| 国产日韩一区二区| 亚洲a中文字幕| 久久国产日韩欧美| 蜜桃传媒一区二区| 亚洲欧洲精品在线观看| 日韩一区二区福利| 国产一区免费| 日韩一区不卡| 国产精品日韩一区二区三区| 国产免费一区二区三区| 日本在线观看不卡| 国产精品成人久久电影| 97久久精品人搡人人玩| 日韩毛片在线免费看| 国产精品久久久91| 99精品免费在线观看| 欧洲亚洲免费视频| 精品毛片久久久久久| 99久久综合狠狠综合久久止 | www.久久色.com| 国产精品一区二区三区毛片淫片| 三年中国中文在线观看免费播放 | 国产激情999| 免费精品视频一区| 三年中国中文在线观看免费播放| 日韩中文娱乐网| 成人精品一二区| 欧美中日韩一区二区三区| 伊人久久婷婷色综合98网| 日韩中文字幕国产| 91精品久久久久久久久久入口| 欧美 日韩 国产在线| 亚洲国产一区二区精品视频| 国产精品美女久久久久久免费| 91观看网站| 国产日韩在线免费| 欧美主播一区二区三区美女 久久精品人| 九九久久久久久久久激情| www日韩欧美| 91高清视频免费| 精品少妇一区二区三区在线| 日产精品久久久一区二区福利| 色综合91久久精品中文字幕 | 欧在线一二三四区| 亚洲.欧美.日本.国产综合在线 | 国产伦精品一区二区三区视频黑人 | 亚洲va码欧洲m码| 久久亚洲欧美日韩精品专区| 国产av熟女一区二区三区| 成人精品小视频| 国产一区免费| 激情小视频网站| 青青在线免费观看视频| 日韩中文字幕av在线| 亚洲精品欧美极品| 一区二区三区四区国产| 国产精品国产三级欧美二区| 北条麻妃在线一区二区| 久久久精品在线视频| 99国精产品一二二线| 麻豆91av| 激情五月开心婷婷| 欧美在线视频一区二区| 日本人成精品视频在线| 午夜免费日韩视频| 亚洲中文字幕无码av永久| 欧美黄网免费在线观看| 久久成人精品一区二区三区| 国产精品视频精品视频| 久久精品99久久久香蕉| 久久国产乱子伦免费精品| 久久久亚洲福利精品午夜| 7777免费精品视频| 久久久婷婷一区二区三区不卡| 91精品在线一区| av免费观看网| 91久久久久久久久| 91精品在线国产| 国产精品aaaa| 久久视频这里有精品| 久久综合福利| 久久久久久久久综合| 日韩中文理论片| 久久精品最新地址| 国产精品免费看久久久无码| 国产精品久久久久久久午夜 | 亚洲最大成人在线| 亚洲一区二区精品在线观看| 亚洲欧美日韩精品久久久| 亚洲va久久久噜噜噜| 三区精品视频| 欧美亚洲成人免费| 国模私拍一区二区三区| 国产日产欧美a一级在线| 高清视频一区二区三区| 91精品久久久久久蜜桃| 久久国产精品免费一区| 国产精品久久久久久久久影视| 久久综合久久美利坚合众国| 欧美精品久久久久久久免费观看| 中文字幕一区二区三区有限公司| 中文字幕日韩精品无码内射| 亚洲一区精彩视频| 日韩午夜视频在线观看| 国内免费精品永久在线视频| 国产精品一区=区| 国产成人中文字幕| 久久精品色欧美aⅴ一区二区| 九九热在线精品视频| 午夜精品久久久久久久99热浪潮 | 91精品国产乱码久久久久久蜜臀| 久久精品国产美女| 国产精品久久久久久搜索| 亚洲午夜精品国产| 日韩精品国内| 黄色片网址在线观看| 国产精品一区二区免费| 国产盗摄xxxx视频xxx69| 国产精品入口尤物| 中文字幕免费高| 日韩欧美精品久久| 国产欧美一区二区视频| 久久久综合亚洲91久久98| 国产精品久久中文| 亚洲精品国产精品国自产观看| 欧美日韩天天操| 国产精品一区二区三区免费 | 日韩 欧美 自拍| 欧美a在线视频| 91精品久久久久久久久久久| 国产成人精品一区二区| 欧美激情极品视频| 青青草原av在线播放| 国产精品一区二区三区成人| 北条麻妃久久精品| 亚洲一区二区三区毛片| 欧美极品日韩| 91av在线精品| 欧美成人一区在线| 日本a级片电影一区二区| 国语自产精品视频在线看一大j8| 99免费在线观看视频| 国产精品美女xx| 日韩av免费在线播放| 国产精品一区二区三区免费视频| 久久久久久国产免费| 一区二区三区欧美在线| 欧美性受xxx| 7777免费精品视频| 精品国产一区二区三区四区精华| 欧美一区二区三区免费视| 国产日韩欧美日韩| 国产成人精品综合| 日本一区二区三区免费看| www日韩av| 国产精品狼人色视频一区|