05资源初始化.html 92 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858
  1. <!DOCTYPE HTML>
  2. <html lang="" >
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
  6. <title>05 资源初始化 · 高性能服务器开发 技术专栏</title>
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  8. <meta name="description" content="">
  9. <meta name="generator" content="GitBook 3.2.3">
  10. <meta name="author" content="easy_coder">
  11. <link rel="stylesheet" href="../../gitbook/style.css">
  12. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.css">
  13. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-search-pro/search.css">
  14. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-splitter/splitter.css">
  15. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-back-to-top-button/plugin.css">
  16. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-prism/prism.css">
  17. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
  18. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-code/plugin.css">
  19. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
  20. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-fontsettings/website.css">
  21. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-theme-fexa/fexa.css">
  22. <meta name="HandheldFriendly" content="true"/>
  23. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  24. <meta name="apple-mobile-web-app-capable" content="yes">
  25. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  26. <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../../gitbook/images/apple-touch-icon-precomposed-152.png">
  27. <link rel="shortcut icon" href="../../gitbook/images/favicon.ico" type="image/x-icon">
  28. <link rel="next" href="06get过程.html" />
  29. <link rel="prev" href="04内存初始化.html" />
  30. </head>
  31. <body>
  32. <div class="book">
  33. <div class="header-inner">
  34. <!-- LOGO -->
  35. <div class="logo"></div>
  36. <span class="title"></span>
  37. <!-- Search -->
  38. <div id="book-search-input" role="search">
  39. <input type="text" placeholder="Type to search" />
  40. </div>
  41. <!-- Nav -->
  42. <ul class="header-nav">
  43. </ul>
  44. </div>
  45. <div class="book-summary">
  46. <div class="book-summary-title">文档目录</div>
  47. <nav role="navigation">
  48. <ul class="summary">
  49. <li class="header">Part I</li>
  50. <li class="chapter " data-level="1.1" data-path="../../">
  51. <a href="../../">
  52. Introduction
  53. </a>
  54. </li>
  55. <li class="chapter " data-level="1.2" data-path="../C++必知必会的知识点/">
  56. <a href="../C++必知必会的知识点/">
  57. C++必知必会的知识点
  58. </a>
  59. <ul class="articles">
  60. <li class="chapter " data-level="1.2.1" data-path="../C++必知必会的知识点/如何成为一名合格的CC++开发者?.html">
  61. <a href="../C++必知必会的知识点/如何成为一名合格的CC++开发者?.html">
  62. 如何成为一名合格的C/C++开发者?
  63. </a>
  64. </li>
  65. <li class="chapter " data-level="1.2.2" data-path="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
  66. <a href="../C++必知必会的知识点/不定参数函数实现var_arg系列的宏.html">
  67. 不定参数函数实现var_arg系列的宏
  68. </a>
  69. </li>
  70. <li class="chapter " data-level="1.2.3" data-path="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
  71. <a href="../C++必知必会的知识点/你一定要搞明白的C函数调用方式与栈原理.html">
  72. 你一定要搞明白的C函数调用方式与栈原理
  73. </a>
  74. </li>
  75. <li class="chapter " data-level="1.2.4" data-path="../C++必知必会的知识点/深入理解CC++中的指针.html">
  76. <a href="../C++必知必会的知识点/深入理解CC++中的指针.html">
  77. 深入理解C/C++中的指针
  78. </a>
  79. </li>
  80. <li class="chapter " data-level="1.2.5" data-path="../C++必知必会的知识点/详解C++11中的智能指针.html">
  81. <a href="../C++必知必会的知识点/详解C++11中的智能指针.html">
  82. 详解C++11中的智能指针
  83. </a>
  84. </li>
  85. <li class="chapter " data-level="1.2.6" data-path="../C++必知必会的知识点/C++17结构化绑定.html">
  86. <a href="../C++必知必会的知识点/C++17结构化绑定.html">
  87. C++17结构化绑定
  88. </a>
  89. </li>
  90. <li class="chapter " data-level="1.2.7" data-path="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
  91. <a href="../C++必知必会的知识点/C++必须掌握的pimpl惯用法.html">
  92. C++必须掌握的pimpl惯用法
  93. </a>
  94. </li>
  95. <li class="chapter " data-level="1.2.8" data-path="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
  96. <a href="../C++必知必会的知识点/用VisualStudio调试Linux程序.html">
  97. 用Visual Studio调试Linux程序
  98. </a>
  99. </li>
  100. <li class="chapter " data-level="1.2.9" data-path="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
  101. <a href="../C++必知必会的知识点/如何使用VisualStudio管理和阅读开源项目代码.html">
  102. 如何使用Visual Studio管理和阅读开源项目代码
  103. </a>
  104. </li>
  105. <li class="chapter " data-level="1.2.10" data-path="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
  106. <a href="../C++必知必会的知识点/利用cmake工具生成VisualStudio工程文件.html">
  107. 利用cmake工具生成Visual Studio工程文件
  108. </a>
  109. </li>
  110. </ul>
  111. </li>
  112. <li class="chapter " data-level="1.3" data-path="../多线程/">
  113. <a href="../多线程/">
  114. 多线程
  115. </a>
  116. <ul class="articles">
  117. <li class="chapter " data-level="1.3.1" data-path="../多线程/后台C++开发你一定要知道的条件变量.html">
  118. <a href="../多线程/后台C++开发你一定要知道的条件变量.html">
  119. 后台C++开发你一定要知道的条件变量
  120. </a>
  121. </li>
  122. <li class="chapter " data-level="1.3.2" data-path="../多线程/整型变量赋值是原子操作吗?.html">
  123. <a href="../多线程/整型变量赋值是原子操作吗?.html">
  124. 整型变量赋值是原子操作吗?
  125. </a>
  126. </li>
  127. </ul>
  128. </li>
  129. <li class="divider"></li>
  130. <li class="chapter " data-level="2.1" data-path="../网络编程/">
  131. <a href="../网络编程/">
  132. 网络编程
  133. </a>
  134. <ul class="articles">
  135. <li class="chapter " data-level="2.1.1" data-path="../网络编程/bind函数重难点解析.html">
  136. <a href="../网络编程/bind函数重难点解析.html">
  137. bind 函数重难点解析
  138. </a>
  139. </li>
  140. <li class="chapter " data-level="2.1.2" data-path="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
  141. <a href="../网络编程/connect函数在阻塞和非阻塞模式下的行为.html">
  142. connect 函数在阻塞和非阻塞模式下的行为
  143. </a>
  144. </li>
  145. <li class="chapter " data-level="2.1.3" data-path="../网络编程/select函数重难点解析.html">
  146. <a href="../网络编程/select函数重难点解析.html">
  147. select 函数重难点解析
  148. </a>
  149. </li>
  150. <li class="chapter " data-level="2.1.4" data-path="../网络编程/Linuxepoll模型(含LT模式和ET模式详解).html">
  151. <a href="../网络编程/Linuxepoll模型(含LT模式和ET模式详解).html">
  152. Linux epoll 模型(含LT 模式和 ET 模式详解)
  153. </a>
  154. </li>
  155. <li class="chapter " data-level="2.1.5" data-path="../网络编程/socket的阻塞模式和非阻塞模式.html">
  156. <a href="../网络编程/socket的阻塞模式和非阻塞模式.html">
  157. socket 的阻塞模式和非阻塞模式
  158. </a>
  159. </li>
  160. <li class="chapter " data-level="2.1.6" data-path="../网络编程/非阻塞模式下send和recv函数的返回值.html">
  161. <a href="../网络编程/非阻塞模式下send和recv函数的返回值.html">
  162. 非阻塞模式下 send 和 recv 函数的返回值
  163. </a>
  164. </li>
  165. <li class="chapter " data-level="2.1.7" data-path="../网络编程/服务器开发通信协议设计介绍.html">
  166. <a href="../网络编程/服务器开发通信协议设计介绍.html">
  167. 服务器开发通信协议设计介绍
  168. </a>
  169. </li>
  170. <li class="chapter " data-level="2.1.8" data-path="../网络编程/TCP协议如何解决粘包、半包问题.html">
  171. <a href="../网络编程/TCP协议如何解决粘包、半包问题.html">
  172. TCP 协议如何解决粘包、半包问题
  173. </a>
  174. </li>
  175. <li class="chapter " data-level="2.1.9" data-path="../网络编程/网络通信中收发数据的正确姿势.html">
  176. <a href="../网络编程/网络通信中收发数据的正确姿势.html">
  177. 网络通信中收发数据的正确姿势
  178. </a>
  179. </li>
  180. <li class="chapter " data-level="2.1.10" data-path="../网络编程/服务器端发数据时,如果对端一直不收,怎么办?.html">
  181. <a href="../网络编程/服务器端发数据时,如果对端一直不收,怎么办?.html">
  182. 服务器端发数据时,如果对端一直不收,怎么办?
  183. </a>
  184. </li>
  185. </ul>
  186. </li>
  187. <li class="divider"></li>
  188. <li class="chapter " data-level="3.1" data-path="../程序员必知必会的网络命令/">
  189. <a href="../程序员必知必会的网络命令/">
  190. 程序员必知必会的网络命令
  191. </a>
  192. <ul class="articles">
  193. <li class="chapter " data-level="3.1.1" data-path="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
  194. <a href="../程序员必知必会的网络命令/利用telnet命令发电子邮件.html">
  195. 利用telnet命令发电子邮件
  196. </a>
  197. </li>
  198. <li class="chapter " data-level="3.1.2" data-path="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
  199. <a href="../程序员必知必会的网络命令/做Java或者C++开发都应该知道的lsof命令.html">
  200. 做Java或者C++开发都应该知道的lsof命令
  201. </a>
  202. </li>
  203. <li class="chapter " data-level="3.1.3" data-path="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
  204. <a href="../程序员必知必会的网络命令/Linux网络故障排查的瑞士军刀.html">
  205. Linux网络故障排查的瑞士军刀nc命令
  206. </a>
  207. </li>
  208. <li class="chapter " data-level="3.1.4" data-path="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
  209. <a href="../程序员必知必会的网络命令/Linuxtcpdump使用介绍.html">
  210. Linux tcpdump使用详解
  211. </a>
  212. </li>
  213. <li class="chapter " data-level="3.1.5" data-path="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
  214. <a href="../程序员必知必会的网络命令/从抓包的角度分析connect函数的连接过程.html">
  215. 从抓包的角度分析connect函数的连接过程
  216. </a>
  217. </li>
  218. <li class="chapter " data-level="3.1.6" data-path="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
  219. <a href="../程序员必知必会的网络命令/服务器开发中网络数据分析与故障排查经验漫谈.html">
  220. 服务器开发中网络数据分析与故障排查经验漫谈
  221. </a>
  222. </li>
  223. </ul>
  224. </li>
  225. <li class="header">Part II</li>
  226. <li class="chapter " data-level="4.1" data-path="../高性能服务器框架设计/">
  227. <a href="../高性能服务器框架设计/">
  228. 高性能服务器框架设计
  229. </a>
  230. <ul class="articles">
  231. <li class="chapter " data-level="4.1.1" data-path="../高性能服务器框架设计/主线程与工作线程的分工.html">
  232. <a href="../高性能服务器框架设计/主线程与工作线程的分工.html">
  233. 主线程与工作线程的分工
  234. </a>
  235. </li>
  236. <li class="chapter " data-level="4.1.2" data-path="../高性能服务器框架设计/Reactor模式.html">
  237. <a href="../高性能服务器框架设计/Reactor模式.html">
  238. Reactor模式
  239. </a>
  240. </li>
  241. <li class="chapter " data-level="4.1.3" data-path="../高性能服务器框架设计/实例:一个服务器程序的架构介绍.html">
  242. <a href="../高性能服务器框架设计/实例:一个服务器程序的架构介绍.html">
  243. 实例:一个服务器程序的架构介绍
  244. </a>
  245. </li>
  246. <li class="chapter " data-level="4.1.4" data-path="../高性能服务器框架设计/错误码系统的设计.html">
  247. <a href="../高性能服务器框架设计/错误码系统的设计.html">
  248. 错误码系统的设计
  249. </a>
  250. </li>
  251. <li class="chapter " data-level="4.1.5" data-path="../高性能服务器框架设计/日志系统的设计.html">
  252. <a href="../高性能服务器框架设计/日志系统的设计.html">
  253. 日志系统的设计
  254. </a>
  255. </li>
  256. <li class="chapter " data-level="4.1.6" data-path="../高性能服务器框架设计/如何设计断线自动重连机制.html">
  257. <a href="../高性能服务器框架设计/如何设计断线自动重连机制.html">
  258. 如何设计断线自动重连机制
  259. </a>
  260. </li>
  261. <li class="chapter " data-level="4.1.7" data-path="../高性能服务器框架设计/心跳包机制设计详解.html">
  262. <a href="../高性能服务器框架设计/心跳包机制设计详解.html">
  263. 心跳包机制设计详解
  264. </a>
  265. </li>
  266. <li class="chapter " data-level="4.1.8" data-path="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
  267. <a href="../高性能服务器框架设计/业务数据处理一定要单独开线程吗.html">
  268. 业务数据处理一定要单独开线程吗
  269. </a>
  270. </li>
  271. <li class="chapter " data-level="4.1.9" data-path="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
  272. <a href="../高性能服务器框架设计/C++高性能服务器网络框架设计细节.html">
  273. C++ 高性能服务器网络框架设计细节
  274. </a>
  275. </li>
  276. </ul>
  277. </li>
  278. <li class="divider"></li>
  279. <li class="chapter " data-level="5.1" data-path="../服务器开发案例实战/">
  280. <a href="../服务器开发案例实战/">
  281. 服务器开发案例实战
  282. </a>
  283. <ul class="articles">
  284. <li class="chapter " data-level="5.1.1" data-path="../服务器开发案例实战/从零实现一个http服务器.html">
  285. <a href="../服务器开发案例实战/从零实现一个http服务器.html">
  286. 从零实现一个http服务器
  287. </a>
  288. </li>
  289. <li class="chapter " data-level="5.1.2" data-path="../服务器开发案例实战/从零实现一款12306刷票软件.html">
  290. <a href="../服务器开发案例实战/从零实现一款12306刷票软件.html">
  291. 从零实现一款12306刷票软件
  292. </a>
  293. </li>
  294. <li class="chapter " data-level="5.1.3" data-path="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
  295. <a href="../服务器开发案例实战/从零实现一个邮件收发客户端.html">
  296. 从零实现一个邮件收发客户端
  297. </a>
  298. </li>
  299. <li class="chapter " data-level="5.1.4" data-path="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
  300. <a href="../服务器开发案例实战/从零开发一个WebSocket服务器.html">
  301. 从零开发一个WebSocket服务器
  302. </a>
  303. </li>
  304. <li class="chapter " data-level="5.1.5" data-path="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
  305. <a href="../服务器开发案例实战/1从一款多人联机实时对战游戏开始.html">
  306. 从零学习开源项目系列(一) 从一款多人联机实时对战游戏开始
  307. </a>
  308. </li>
  309. <li class="chapter " data-level="5.1.6" data-path="../服务器开发案例实战/2最后一战概况.html">
  310. <a href="../服务器开发案例实战/2最后一战概况.html">
  311. 从零学习开源项目系列(二) 最后一战概况
  312. </a>
  313. </li>
  314. <li class="chapter " data-level="5.1.7" data-path="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
  315. <a href="../服务器开发案例实战/3CSBattleMgr服务源码研究.html">
  316. 从零学习开源项目系列(三) CSBattleMgr服务源码研究
  317. </a>
  318. </li>
  319. <li class="chapter " data-level="5.1.8" data-path="../服务器开发案例实战/4LogServer源码探究.html">
  320. <a href="../服务器开发案例实战/4LogServer源码探究.html">
  321. 从零学习开源项目系列(四)LogServer源码探究
  322. </a>
  323. </li>
  324. </ul>
  325. </li>
  326. <li class="header">Part III</li>
  327. <li class="chapter " data-level="6.1" data-path="../TeamTalk源码解析/">
  328. <a href="../TeamTalk源码解析/">
  329. TeamTalk IM源码分析
  330. </a>
  331. <ul class="articles">
  332. <li class="chapter " data-level="6.1.1" data-path="../TeamTalk源码解析/01TeamTalk介绍.html">
  333. <a href="../TeamTalk源码解析/01TeamTalk介绍.html">
  334. 01 TeamTalk介绍
  335. </a>
  336. </li>
  337. <li class="chapter " data-level="6.1.2" data-path="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
  338. <a href="../TeamTalk源码解析/02服务器端的程序的编译与部署.html">
  339. 02 服务器端的程序的编译与部署
  340. </a>
  341. </li>
  342. <li class="chapter " data-level="6.1.3" data-path="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
  343. <a href="../TeamTalk源码解析/03服务器端的程序架构介绍.html">
  344. 03 服务器端的程序架构介绍
  345. </a>
  346. </li>
  347. <li class="chapter " data-level="6.1.4" data-path="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
  348. <a href="../TeamTalk源码解析/04服务器端db_proxy_server源码分析.html">
  349. 04 服务器端db_proxy_server源码分析
  350. </a>
  351. </li>
  352. <li class="chapter " data-level="6.1.5" data-path="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
  353. <a href="../TeamTalk源码解析/05服务器端msg_server源码分析.html">
  354. 05 服务器端msg_server源码分析
  355. </a>
  356. </li>
  357. <li class="chapter " data-level="6.1.6" data-path="../TeamTalk源码解析/06服务器端login_server源码分析.html">
  358. <a href="../TeamTalk源码解析/06服务器端login_server源码分析.html">
  359. 06 服务器端login_server源码分析
  360. </a>
  361. </li>
  362. <li class="chapter " data-level="6.1.7" data-path="../TeamTalk源码解析/07服务器端msfs源码分析.html">
  363. <a href="../TeamTalk源码解析/07服务器端msfs源码分析.html">
  364. 07 服务器端msfs源码分析
  365. </a>
  366. </li>
  367. <li class="chapter " data-level="6.1.8" data-path="../TeamTalk源码解析/08服务器端file_server源码分析.html">
  368. <a href="../TeamTalk源码解析/08服务器端file_server源码分析.html">
  369. 08 服务器端file_server源码分析
  370. </a>
  371. </li>
  372. <li class="chapter " data-level="6.1.9" data-path="../TeamTalk源码解析/09服务器端route_server源码分析.html">
  373. <a href="../TeamTalk源码解析/09服务器端route_server源码分析.html">
  374. 09 服务器端route_server源码分析
  375. </a>
  376. </li>
  377. <li class="chapter " data-level="6.1.10" data-path="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
  378. <a href="../TeamTalk源码解析/10开放一个TeamTalk测试服务器地址和几个测试账号.html">
  379. 10 开放一个TeamTalk测试服务器地址和几个测试账号
  380. </a>
  381. </li>
  382. <li class="chapter " data-level="6.1.11" data-path="../TeamTalk源码解析/11pc客户端源码分析.html">
  383. <a href="../TeamTalk源码解析/11pc客户端源码分析.html">
  384. 11 pc客户端源码分析
  385. </a>
  386. </li>
  387. </ul>
  388. </li>
  389. <li class="divider"></li>
  390. <li class="chapter " data-level="7.1" data-path="../libevent源码深度剖析/">
  391. <a href="../libevent源码深度剖析/">
  392. libevent源码深度剖析
  393. </a>
  394. <ul class="articles">
  395. <li class="chapter " data-level="7.1.1" data-path="../libevent源码深度剖析/libevent源码深度剖析01.html">
  396. <a href="../libevent源码深度剖析/libevent源码深度剖析01.html">
  397. libevent源码深度剖析01
  398. </a>
  399. </li>
  400. <li class="chapter " data-level="7.1.2" data-path="../libevent源码深度剖析/libevent源码深度剖析02.html">
  401. <a href="../libevent源码深度剖析/libevent源码深度剖析02.html">
  402. libevent源码深度剖析02
  403. </a>
  404. </li>
  405. <li class="chapter " data-level="7.1.3" data-path="../libevent源码深度剖析/libevent源码深度剖析03.html">
  406. <a href="../libevent源码深度剖析/libevent源码深度剖析03.html">
  407. libevent源码深度剖析03
  408. </a>
  409. </li>
  410. <li class="chapter " data-level="7.1.4" data-path="../libevent源码深度剖析/libevent源码深度剖析04.html">
  411. <a href="../libevent源码深度剖析/libevent源码深度剖析04.html">
  412. libevent源码深度剖析04
  413. </a>
  414. </li>
  415. <li class="chapter " data-level="7.1.5" data-path="../libevent源码深度剖析/libevent源码深度剖析05.html">
  416. <a href="../libevent源码深度剖析/libevent源码深度剖析05.html">
  417. libevent源码深度剖析05
  418. </a>
  419. </li>
  420. <li class="chapter " data-level="7.1.6" data-path="../libevent源码深度剖析/libevent源码深度剖析06.html">
  421. <a href="../libevent源码深度剖析/libevent源码深度剖析06.html">
  422. libevent源码深度剖析06
  423. </a>
  424. </li>
  425. <li class="chapter " data-level="7.1.7" data-path="../libevent源码深度剖析/libevent源码深度剖析07.html">
  426. <a href="../libevent源码深度剖析/libevent源码深度剖析07.html">
  427. libevent源码深度剖析07
  428. </a>
  429. </li>
  430. <li class="chapter " data-level="7.1.8" data-path="../libevent源码深度剖析/libevent源码深度剖析08.html">
  431. <a href="../libevent源码深度剖析/libevent源码深度剖析08.html">
  432. libevent源码深度剖析08
  433. </a>
  434. </li>
  435. <li class="chapter " data-level="7.1.9" data-path="../libevent源码深度剖析/libevent源码深度剖析09.html">
  436. <a href="../libevent源码深度剖析/libevent源码深度剖析09.html">
  437. libevent源码深度剖析09
  438. </a>
  439. </li>
  440. <li class="chapter " data-level="7.1.10" data-path="../libevent源码深度剖析/libevent源码深度剖析10.html">
  441. <a href="../libevent源码深度剖析/libevent源码深度剖析10.html">
  442. libevent源码深度剖析10
  443. </a>
  444. </li>
  445. <li class="chapter " data-level="7.1.11" data-path="../libevent源码深度剖析/libevent源码深度剖析11.html">
  446. <a href="../libevent源码深度剖析/libevent源码深度剖析11.html">
  447. libevent源码深度剖析11
  448. </a>
  449. </li>
  450. <li class="chapter " data-level="7.1.12" data-path="../libevent源码深度剖析/libevent源码深度剖析12.html">
  451. <a href="../libevent源码深度剖析/libevent源码深度剖析12.html">
  452. libevent源码深度剖析12
  453. </a>
  454. </li>
  455. <li class="chapter " data-level="7.1.13" data-path="../libevent源码深度剖析/libevent源码深度剖析13.html">
  456. <a href="../libevent源码深度剖析/libevent源码深度剖析13.html">
  457. libevent源码深度剖析13
  458. </a>
  459. </li>
  460. </ul>
  461. </li>
  462. <li class="chapter " data-level="7.2" data-path="../leveldb源码分析/">
  463. <a href="../leveldb源码分析/">
  464. leveldb源码分析
  465. </a>
  466. <ul class="articles">
  467. <li class="chapter " data-level="7.2.1" data-path="../leveldb源码分析/leveldb源码分析1.html">
  468. <a href="../leveldb源码分析/leveldb源码分析1.html">
  469. leveldb源码分析1
  470. </a>
  471. </li>
  472. <li class="chapter " data-level="7.2.2" data-path="../leveldb源码分析/leveldb源码分析2.html">
  473. <a href="../leveldb源码分析/leveldb源码分析2.html">
  474. leveldb源码分析2
  475. </a>
  476. </li>
  477. <li class="chapter " data-level="7.2.3" data-path="../leveldb源码分析/leveldb源码分析3.html">
  478. <a href="../leveldb源码分析/leveldb源码分析3.html">
  479. leveldb源码分析3
  480. </a>
  481. </li>
  482. <li class="chapter " data-level="7.2.4" data-path="../leveldb源码分析/leveldb源码分析4.html">
  483. <a href="../leveldb源码分析/leveldb源码分析4.html">
  484. leveldb源码分析4
  485. </a>
  486. </li>
  487. <li class="chapter " data-level="7.2.5" data-path="../leveldb源码分析/leveldb源码分析5.html">
  488. <a href="../leveldb源码分析/leveldb源码分析5.html">
  489. leveldb源码分析5
  490. </a>
  491. </li>
  492. <li class="chapter " data-level="7.2.6" data-path="../leveldb源码分析/leveldb源码分析6.html">
  493. <a href="../leveldb源码分析/leveldb源码分析6.html">
  494. leveldb源码分析6
  495. </a>
  496. </li>
  497. <li class="chapter " data-level="7.2.7" data-path="../leveldb源码分析/leveldb源码分析7.html">
  498. <a href="../leveldb源码分析/leveldb源码分析7.html">
  499. leveldb源码分析7
  500. </a>
  501. </li>
  502. <li class="chapter " data-level="7.2.8" data-path="../leveldb源码分析/leveldb源码分析8.html">
  503. <a href="../leveldb源码分析/leveldb源码分析8.html">
  504. leveldb源码分析8
  505. </a>
  506. </li>
  507. <li class="chapter " data-level="7.2.9" data-path="../leveldb源码分析/leveldb源码分析9.html">
  508. <a href="../leveldb源码分析/leveldb源码分析9.html">
  509. leveldb源码分析9
  510. </a>
  511. </li>
  512. <li class="chapter " data-level="7.2.10" data-path="../leveldb源码分析/leveldb源码分析10.html">
  513. <a href="../leveldb源码分析/leveldb源码分析10.html">
  514. leveldb源码分析10
  515. </a>
  516. </li>
  517. <li class="chapter " data-level="7.2.11" data-path="../leveldb源码分析/leveldb源码分析11.html">
  518. <a href="../leveldb源码分析/leveldb源码分析11.html">
  519. leveldb源码分析11
  520. </a>
  521. </li>
  522. <li class="chapter " data-level="7.2.12" data-path="../leveldb源码分析/leveldb源码分析12.html">
  523. <a href="../leveldb源码分析/leveldb源码分析12.html">
  524. leveldb源码分析12
  525. </a>
  526. </li>
  527. <li class="chapter " data-level="7.2.13" data-path="../leveldb源码分析/leveldb源码分析13.html">
  528. <a href="../leveldb源码分析/leveldb源码分析13.html">
  529. leveldb源码分析13
  530. </a>
  531. </li>
  532. <li class="chapter " data-level="7.2.14" data-path="../leveldb源码分析/leveldb源码分析14.html">
  533. <a href="../leveldb源码分析/leveldb源码分析14.html">
  534. leveldb源码分析14
  535. </a>
  536. </li>
  537. <li class="chapter " data-level="7.2.15" data-path="../leveldb源码分析/leveldb源码分析15.html">
  538. <a href="../leveldb源码分析/leveldb源码分析15.html">
  539. leveldb源码分析15
  540. </a>
  541. </li>
  542. <li class="chapter " data-level="7.2.16" data-path="../leveldb源码分析/leveldb源码分析16.html">
  543. <a href="../leveldb源码分析/leveldb源码分析16.html">
  544. leveldb源码分析16
  545. </a>
  546. </li>
  547. <li class="chapter " data-level="7.2.17" data-path="../leveldb源码分析/leveldb源码分析17.html">
  548. <a href="../leveldb源码分析/leveldb源码分析17.html">
  549. leveldb源码分析17
  550. </a>
  551. </li>
  552. <li class="chapter " data-level="7.2.18" data-path="../leveldb源码分析/leveldb源码分析18.html">
  553. <a href="../leveldb源码分析/leveldb源码分析18.html">
  554. leveldb源码分析18
  555. </a>
  556. </li>
  557. <li class="chapter " data-level="7.2.19" data-path="../leveldb源码分析/leveldb源码分析19.html">
  558. <a href="../leveldb源码分析/leveldb源码分析19.html">
  559. leveldb源码分析19
  560. </a>
  561. </li>
  562. <li class="chapter " data-level="7.2.20" data-path="../leveldb源码分析/leveldb源码分析20.html">
  563. <a href="../leveldb源码分析/leveldb源码分析20.html">
  564. leveldb源码分析20
  565. </a>
  566. </li>
  567. <li class="chapter " data-level="7.2.21" data-path="../leveldb源码分析/leveldb源码分析21.html">
  568. <a href="../leveldb源码分析/leveldb源码分析21.html">
  569. leveldb源码分析21
  570. </a>
  571. </li>
  572. <li class="chapter " data-level="7.2.22" data-path="../leveldb源码分析/leveldb源码分析22.html">
  573. <a href="../leveldb源码分析/leveldb源码分析22.html">
  574. leveldb源码分析22
  575. </a>
  576. </li>
  577. </ul>
  578. </li>
  579. <li class="divider"></li>
  580. <li class="chapter " data-level="8.1" data-path="./">
  581. <a href="./">
  582. Memcached源码分析
  583. </a>
  584. <ul class="articles">
  585. <li class="chapter " data-level="8.1.1" data-path="00服务器资源调整.html">
  586. <a href="00服务器资源调整.html">
  587. 00 服务器资源调整
  588. </a>
  589. </li>
  590. <li class="chapter " data-level="8.1.2" data-path="01初始化参数解析.html">
  591. <a href="01初始化参数解析.html">
  592. 01 初始化参数解析
  593. </a>
  594. </li>
  595. <li class="chapter " data-level="8.1.3" data-path="02网络监听的建立.html">
  596. <a href="02网络监听的建立.html">
  597. 02 网络监听的建立
  598. </a>
  599. </li>
  600. <li class="chapter " data-level="8.1.4" data-path="03网络连接建立.html">
  601. <a href="03网络连接建立.html">
  602. 03 网络连接建立
  603. </a>
  604. </li>
  605. <li class="chapter " data-level="8.1.5" data-path="04内存初始化.html">
  606. <a href="04内存初始化.html">
  607. 04 内存初始化
  608. </a>
  609. </li>
  610. <li class="chapter active" data-level="8.1.6" data-path="05资源初始化.html">
  611. <a href="05资源初始化.html">
  612. 05 资源初始化
  613. </a>
  614. </li>
  615. <li class="chapter " data-level="8.1.7" data-path="06get过程.html">
  616. <a href="06get过程.html">
  617. 06 get过程
  618. </a>
  619. </li>
  620. <li class="chapter " data-level="8.1.8" data-path="07cas属性.html">
  621. <a href="07cas属性.html">
  622. 07 cas属性
  623. </a>
  624. </li>
  625. <li class="chapter " data-level="8.1.9" data-path="08内存池.html">
  626. <a href="08内存池.html">
  627. 08 内存池
  628. </a>
  629. </li>
  630. <li class="chapter " data-level="8.1.10" data-path="09连接队列.html">
  631. <a href="09连接队列.html">
  632. 09 连接队列
  633. </a>
  634. </li>
  635. <li class="chapter " data-level="8.1.11" data-path="10Hash表操作.html">
  636. <a href="10Hash表操作.html">
  637. 10 Hash表操作
  638. </a>
  639. </li>
  640. <li class="chapter " data-level="8.1.12" data-path="12set操作.html">
  641. <a href="12set操作.html">
  642. 12 set操作
  643. </a>
  644. </li>
  645. <li class="chapter " data-level="8.1.13" data-path="13do_item_alloc操作.html">
  646. <a href="13do_item_alloc操作.html">
  647. 13 do_item_alloc操作
  648. </a>
  649. </li>
  650. <li class="chapter " data-level="8.1.14" data-path="14item结构.html">
  651. <a href="14item结构.html">
  652. 14 item结构
  653. </a>
  654. </li>
  655. <li class="chapter " data-level="8.1.15" data-path="15Hash表扩容.html">
  656. <a href="15Hash表扩容.html">
  657. 15 Hash表扩容
  658. </a>
  659. </li>
  660. <li class="chapter " data-level="8.1.16" data-path="16线程交互.html">
  661. <a href="16线程交互.html">
  662. 16 线程交互
  663. </a>
  664. </li>
  665. <li class="chapter " data-level="8.1.17" data-path="17状态机.html">
  666. <a href="17状态机.html">
  667. 17 状态机
  668. </a>
  669. </li>
  670. </ul>
  671. </li>
  672. <li class="divider"></li>
  673. <li class="chapter " data-level="9.1" data-path="../游戏开发专题/">
  674. <a href="../游戏开发专题/">
  675. 游戏开发专题
  676. </a>
  677. <ul class="articles">
  678. <li class="chapter " data-level="9.1.1" data-path="../游戏开发专题/1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
  679. <a href="../游戏开发专题/1游戏服务器开发的基本体系与服务器端开发的一些建议.html">
  680. 1 游戏服务器开发的基本体系与服务器端开发的一些建议
  681. </a>
  682. </li>
  683. <li class="chapter " data-level="9.1.2" data-path="../游戏开发专题/2网络游戏服务器开发框架设计介绍.html">
  684. <a href="../游戏开发专题/2网络游戏服务器开发框架设计介绍.html">
  685. 2 网络游戏服务器开发框架设计介绍
  686. </a>
  687. </li>
  688. <li class="chapter " data-level="9.1.3" data-path="../游戏开发专题/3游戏后端开发需要掌握的知识.html">
  689. <a href="../游戏开发专题/3游戏后端开发需要掌握的知识.html">
  690. 3 游戏后端开发需要掌握的知识
  691. </a>
  692. </li>
  693. <li class="chapter " data-level="9.1.4" data-path="../游戏开发专题/4关于游戏服务端架构的整理.html">
  694. <a href="../游戏开发专题/4关于游戏服务端架构的整理.html">
  695. 4 关于游戏服务端架构的整理
  696. </a>
  697. </li>
  698. <li class="chapter " data-level="9.1.5" data-path="../游戏开发专题/5各类游戏对应的服务端架构.html">
  699. <a href="../游戏开发专题/5各类游戏对应的服务端架构.html">
  700. 5 各类游戏对应的服务端架构
  701. </a>
  702. </li>
  703. <li class="chapter " data-level="9.1.6" data-path="../游戏开发专题/6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
  704. <a href="../游戏开发专题/6从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则.html">
  705. 6 从腾讯QQgame高性能服务器集群架构看“分而治之”与“自治”等分布式架构设计原则
  706. </a>
  707. </li>
  708. <li class="chapter " data-level="9.1.7" data-path="../游戏开发专题/7QQ游戏百万人同时在线服务器架构实现.html">
  709. <a href="../游戏开发专题/7QQ游戏百万人同时在线服务器架构实现.html">
  710. 7 QQ游戏百万人同时在线服务器架构实现
  711. </a>
  712. </li>
  713. <li class="chapter " data-level="9.1.8" data-path="../游戏开发专题/8大型多人在线游戏服务器架构设计.html">
  714. <a href="../游戏开发专题/8大型多人在线游戏服务器架构设计.html">
  715. 8 大型多人在线游戏服务器架构设计
  716. </a>
  717. </li>
  718. <li class="chapter " data-level="9.1.9" data-path="../游戏开发专题/9百万用户级游戏服务器架构设计.html">
  719. <a href="../游戏开发专题/9百万用户级游戏服务器架构设计.html">
  720. 9 百万用户级游戏服务器架构设计
  721. </a>
  722. </li>
  723. <li class="chapter " data-level="9.1.10" data-path="../游戏开发专题/10十万在线的WebGame的数据库设计思路.html">
  724. <a href="../游戏开发专题/10十万在线的WebGame的数据库设计思路.html">
  725. 10 十万在线的WebGame的数据库设计思路
  726. </a>
  727. </li>
  728. <li class="chapter " data-level="9.1.11" data-path="../游戏开发专题/11一种高性能网络游戏服务器架构设计.html">
  729. <a href="../游戏开发专题/11一种高性能网络游戏服务器架构设计.html">
  730. 11 一种高性能网络游戏服务器架构设计
  731. </a>
  732. </li>
  733. <li class="chapter " data-level="9.1.12" data-path="../游戏开发专题/12经典游戏服务器端架构概述.html">
  734. <a href="../游戏开发专题/12经典游戏服务器端架构概述.html">
  735. 12 经典游戏服务器端架构概述
  736. </a>
  737. </li>
  738. <li class="chapter " data-level="9.1.13" data-path="../游戏开发专题/13游戏跨服架构进化之路.html">
  739. <a href="../游戏开发专题/13游戏跨服架构进化之路.html">
  740. 13 游戏跨服架构进化之路
  741. </a>
  742. </li>
  743. </ul>
  744. </li>
  745. <li class="header">Part IV</li>
  746. <li class="chapter " data-level="10.1" data-path="../程序员面试题精讲/">
  747. <a href="../程序员面试题精讲/">
  748. 程序员面试题精讲
  749. </a>
  750. <ul class="articles">
  751. <li class="chapter " data-level="10.1.1" data-path="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
  752. <a href="../程序员面试题精讲/腾讯后台开发实习生技能要求.html">
  753. 腾讯后台开发实习生技能要求
  754. </a>
  755. </li>
  756. <li class="chapter " data-level="10.1.2" data-path="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
  757. <a href="../程序员面试题精讲/聊聊如何拿大厂的offer.html">
  758. 聊聊如何拿大厂的 offer
  759. </a>
  760. </li>
  761. <li class="chapter " data-level="10.1.3" data-path="../程序员面试题精讲/网络通信题目集锦.html">
  762. <a href="../程序员面试题精讲/网络通信题目集锦.html">
  763. 网络通信题目集锦
  764. </a>
  765. </li>
  766. <li class="chapter " data-level="10.1.4" data-path="../程序员面试题精讲/我面试后端开发经理的经历.html">
  767. <a href="../程序员面试题精讲/我面试后端开发经理的经历.html">
  768. 我面试后端开发经理的经历
  769. </a>
  770. </li>
  771. <li class="chapter " data-level="10.1.5" data-path="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
  772. <a href="../程序员面试题精讲/LinuxCC++后端开发面试问哪些问题.html">
  773. Linux C/C++后端开发面试问哪些问题
  774. </a>
  775. </li>
  776. </ul>
  777. </li>
  778. <li class="chapter " data-level="10.2" data-path="../职业规划/">
  779. <a href="../职业规划/">
  780. 职业规划
  781. </a>
  782. <ul class="articles">
  783. <li class="chapter " data-level="10.2.1" data-path="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
  784. <a href="../职业规划/给工作4年迷茫的程序员们的一点建议.html">
  785. 给工作 4 年迷茫的程序员们的一点建议
  786. </a>
  787. </li>
  788. <li class="chapter " data-level="10.2.2" data-path="../职业规划/聊聊技术人员的常见的职业问题.html">
  789. <a href="../职业规划/聊聊技术人员的常见的职业问题.html">
  790. 聊聊技术人员的常见的职业问题
  791. </a>
  792. </li>
  793. <li class="chapter " data-level="10.2.3" data-path="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
  794. <a href="../职业规划/写给那些傻傻想做服务器开发的朋友.html">
  795. 写给那些傻傻想做服务器开发的朋友
  796. </a>
  797. </li>
  798. </ul>
  799. </li>
  800. <li class="chapter " data-level="10.3" data-path="../自我提升与开源代码/">
  801. <a href="../自我提升与开源代码/">
  802. 自我提升与开源代码
  803. </a>
  804. <ul class="articles">
  805. <li class="chapter " data-level="10.3.1" data-path="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
  806. <a href="../自我提升与开源代码/2020年好好读一读开源代码吧.html">
  807. 2020 年好好读一读开源代码吧
  808. </a>
  809. </li>
  810. </ul>
  811. </li>
  812. <li class="chapter " data-level="10.4" data-path="../后端开发相关的书籍/">
  813. <a href="../后端开发相关的书籍/">
  814. 后端开发相关的书籍
  815. </a>
  816. <ul class="articles">
  817. <li class="chapter " data-level="10.4.1" data-path="../后端开发相关的书籍/后台开发应该读的书.html">
  818. <a href="../后端开发相关的书籍/后台开发应该读的书.html">
  819. 后台开发应该读的书
  820. </a>
  821. </li>
  822. </ul>
  823. </li>
  824. <li class="chapter " data-level="10.5" data-path="../程序员的简历/">
  825. <a href="../程序员的简历/">
  826. 程序员的简历
  827. </a>
  828. <ul class="articles">
  829. <li class="chapter " data-level="10.5.1" data-path="../程序员的简历/程序员如何写简历.html">
  830. <a href="../程序员的简历/程序员如何写简历.html">
  831. 程序员如何写简历
  832. </a>
  833. </li>
  834. </ul>
  835. </li>
  836. <li class="chapter " data-level="10.6" data-path="../程序员的薪资与年终奖那些事儿/">
  837. <a href="../程序员的薪资与年终奖那些事儿/">
  838. 程序员的薪资与年终奖那些事儿
  839. </a>
  840. <ul class="articles">
  841. <li class="chapter " data-level="10.6.1" data-path="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
  842. <a href="../程序员的薪资与年终奖那些事儿/技术面试与HR谈薪资技巧.html">
  843. 技术面试与HR谈薪资技巧
  844. </a>
  845. </li>
  846. <li class="chapter " data-level="10.6.2" data-path="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
  847. <a href="../程序员的薪资与年终奖那些事儿/聊一聊程序员如何增加收入.html">
  848. 聊一聊程序员如何增加收入
  849. </a>
  850. </li>
  851. <li class="chapter " data-level="10.6.3" data-path="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
  852. <a href="../程序员的薪资与年终奖那些事儿/谈一谈年终奖.html">
  853. 谈一谈年终奖
  854. </a>
  855. </li>
  856. </ul>
  857. </li>
  858. <li class="chapter " data-level="10.7" data-path="../程序员的烦心事/">
  859. <a href="../程序员的烦心事/">
  860. 程序员的烦心事
  861. </a>
  862. <ul class="articles">
  863. <li class="chapter " data-level="10.7.1" data-path="../程序员的烦心事/拒绝了一家公司的offer后,他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入,我该不该去?.html">
  864. <a href="../程序员的烦心事/拒绝了一家公司的offer后,他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入,我该不该去?.html">
  865. 拒绝了一家公司的offer后,他们的副总和hr总监同时打电话来询问拒绝原因并极力要求加入,我该不该去?
  866. </a>
  867. </li>
  868. <li class="chapter " data-level="10.7.2" data-path="../程序员的烦心事/我是一名程序员,结婚时女友要求我用两年的工资作为彩礼,我该不该答应?.html">
  869. <a href="../程序员的烦心事/我是一名程序员,结婚时女友要求我用两年的工资作为彩礼,我该不该答应?.html">
  870. 我是一名程序员,结婚时女友要求我用两年的工资作为彩礼,我该不该答应?
  871. </a>
  872. </li>
  873. </ul>
  874. </li>
  875. <li class="chapter " data-level="10.8" data-path="../作者的故事/">
  876. <a href="../作者的故事/">
  877. 作者的故事
  878. </a>
  879. <ul class="articles">
  880. <li class="chapter " data-level="10.8.1" data-path="../作者的故事/我的2019.html">
  881. <a href="../作者的故事/我的2019.html">
  882. 我的 2019
  883. </a>
  884. </li>
  885. <li class="chapter " data-level="10.8.2" data-path="../作者的故事/我是如何年薪五十万的.html">
  886. <a href="../作者的故事/我是如何年薪五十万的.html">
  887. 我是如何年薪五十万的
  888. </a>
  889. </li>
  890. </ul>
  891. </li>
  892. <li class="divider"></li>
  893. <li>
  894. <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
  895. Published with GitBook
  896. </a>
  897. </li>
  898. </ul>
  899. </nav>
  900. </div>
  901. <!-- Content nav -->
  902. <div class="book-anchor">
  903. <div class="book-anchor-title">在这篇文章中:</div>
  904. <div class="book-anchor-body">
  905. </div>
  906. </div>
  907. <div class="book-body">
  908. <div class="body-inner">
  909. <div class="book-header" role="navigation">
  910. <!-- Title -->
  911. <h1>
  912. <i class="fa fa-circle-o-notch fa-spin"></i>
  913. <a href="../.." >05 资源初始化</a>
  914. </h1>
  915. </div>
  916. <div class="page-wrapper" tabindex="-1" role="main">
  917. <div class="page-inner">
  918. <div id="book-search-results">
  919. <div class="search-noresults">
  920. <section class="normal markdown-section">
  921. <div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><li><span class="title-icon "></span><a href="#memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94;-&#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;"><b></b>Memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94; &#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;</a></li></ul></div><h1 id="memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94;-&#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;"><a name="memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94;-&#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;" class="anchor-navigation-ex-anchor" href="#memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94;-&#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;"><i class="fa fa-link" aria-hidden="true"></i></a>Memcached&#x6E90;&#x7801;&#x9605;&#x8BFB;&#x4E94; &#x8D44;&#x6E90;&#x521D;&#x59CB;&#x5316;</h1>
  922. <p><code>Memcached</code>&#x5185;&#x90E8;&#x6709;<strong>hash&#x8868;&#xFF0C;&#x5404;&#x79CD;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#xFF0C;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#xFF0C;&#x7F51;&#x7EDC;&#xFF0C;&#x8FDE;&#x63A5;&#xFF0C;&#x5185;&#x5B58;&#x7ED3;&#x6784;</strong>&#x7B49;&#xFF0C;&#x5728;memcached&#x542F;&#x52A8;&#x65F6;(&#x6267;&#x884C;main&#x51FD;&#x6570;)&#xFF0C;&#x4F1A;&#x5BF9;&#x8FD9;&#x4E9B;&#x8D44;&#x6E90;&#x8FDB;&#x884C;&#x521D;&#x59CB;&#x5316;&#x7684;&#xFF0C;&#x7F51;&#x7EDC;&#x548C;&#x5185;&#x5B58;&#x7684;&#x521D;&#x59CB;&#x5316;&#x64CD;&#x4F5C;&#x653E;&#x5230;&#x540E;&#x7EED;&#x5206;&#x6790;&#xFF0C;&#x8FD9;&#x6B21;&#x5206;&#x6790;hash&#x8868;&#xFF0C;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#xFF0C;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#xFF0C;&#x7F51;&#x7EDC;&#x8FDE;&#x63A5;&#x7684;&#x521D;&#x59CB;&#x5316;&#x8FC7;&#x7A0B;&#x3002;</p>
  923. <p><strong>1 hash&#x8868;&#x7684;&#x521D;&#x59CB;&#x5316;</strong></p>
  924. <pre class="language-"><code>//hash&#x8868;&#x7684;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x4F20;&#x5165;&#x7684;&#x53C2;&#x6570;&#x662F;&#x542F;&#x52A8;&#x65F6;&#x4F20;&#x5165;&#x7684;
  925. assoc_init(settings.hashpower_init);
  926. //hashsize&#x7684;&#x5B9E;&#x73B0;
  927. #define hashsize(n) ((ub4)1&lt;&lt;(n))
  928. //&#x4E3B;hash&#x8868;&#x7ED3;&#x6784;&#x5B9A;&#x4E49;&#xFF0C;&#x5728;hash&#x8868;&#x6269;&#x5BB9;&#x65F6;&#xFF0C;&#x4F1A;&#x6709;&#x6B21;hash&#x8868;&#xFF0C;&#x6240;&#x4EE5;&#x6709;&#x4E3B;&#x6B21;hash&#x8868;&#x533A;&#x5206;&#xFF0C;&#x8BE5;&#x7ED3;&#x6784;&#x662F;&#x6307;&#x9488;&#x7684;&#x6307;&#x9488;&#xFF0C;&#x4E5F;&#x5373;&#x76F8;&#x5F53;&#x4E8E;&#x6570;&#x7EC4;&#x6307;&#x9488;
  929. static item** primary_hashtable = 0;
  930. void assoc_init(const int hashtable_init) {
  931. if (hashtable_init) {
  932. //&#x5982;&#x679C;&#x8BBE;&#x7F6E;&#x4E86;&#x521D;&#x59CB;&#x5316;&#x53C2;&#x6570;&#xFF0C;&#x5219;&#x6309;&#x8BBE;&#x7F6E;&#x7684;&#x53C2;&#x6570;&#x8FDB;&#x884C;&#x521D;&#x59CB;&#x5316;
  933. hashpower = hashtable_init;
  934. }
  935. //hashpower&#x7684;&#x9ED8;&#x8BA4;&#x503C;&#x4E3A;16,&#x5982;&#x679C;&#x672A;&#x8BBE;&#x7F6E;&#x65B0;&#x503C;&#xFF0C;&#x5219;&#x6309;&#x9ED8;&#x8BA4;&#x503C;&#x8FDB;&#x884C;&#x521D;&#x59CB;&#x5316;
  936. primary_hashtable = calloc(hashsize(hashpower), sizeof(void *));
  937. if (! primary_hashtable) {
  938. fprintf(stderr, &quot;Failed to init hashtable.\n&quot;);
  939. exit(EXIT_FAILURE);
  940. }
  941. STATS_LOCK();//&#x5168;&#x5C40;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x52A0;&#x9501;&#xFF0C;&#x4FDD;&#x8BC1;&#x6570;&#x636E;&#x540C;&#x6B65;
  942. stats.hash_power_level = hashpower;
  943. stats.hash_bytes = hashsize(hashpower) * sizeof(void *);
  944. STATS_UNLOCK();
  945. }
  946. </code></pre><p><strong>2 &#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x7684;&#x521D;&#x59CB;&#x5316;</strong></p>
  947. <p><code>Memcached</code>&#x5185;&#x90E8;&#x6709;&#x5F88;&#x591A;&#x5168;&#x5C40;&#x7684;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#xFF0C;&#x7528;&#x4E8E;&#x5B9E;&#x65F6;&#x83B7;&#x53D6;&#x5404;&#x4E2A;&#x8D44;&#x6E90;&#x7684;&#x4F7F;&#x7528;&#x60C5;&#x51B5;&#xFF0C;&#x540E;&#x9762;&#x5C06;&#x4F1A;&#x770B;&#x5230;&#xFF0C;&#x6240;&#x6709;&#x5BF9;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x7684;&#x66F4;&#x65B0;&#x90FD;&#x9700;&#x8981;&#x52A0;&#x9501;&#xFF0C;&#x800C;&#x8FD9;&#x4E9B;&#x4FE1;&#x606F;&#x7684;&#x66F4;&#x65B0;&#x662F;&#x548C;Memcached&#x7684;&#x64CD;&#x4F5C;&#x6B21;&#x6570;&#x540C;&#x6570;&#x91CF;&#x7EA7;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#xFF0C;&#x5728;&#x4E00;&#x5B9A;&#x7A0B;&#x5EA6;&#x6765;&#x8BF4;&#xFF0C;&#x8FD9;&#x4E9B;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x5BF9;<strong>&#x6027;&#x80FD;</strong>&#x6709;&#x5F71;&#x54CD;&#x3002;</p>
  948. <p>stats&#x7ED3;&#x6784;&#x662F;&#x5BF9;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x7684;&#x4E00;&#x4E2A;&#x62BD;&#x8C61;&#xFF0C;&#x5404;&#x4E2A;&#x5B57;&#x6BB5;&#x90FD;&#x6BD4;&#x8F83;&#x597D;&#x7406;&#x89E3;&#xFF0C;&#x4E0D;&#x505A;&#x89E3;&#x91CA;&#x3002;</p>
  949. <pre class="language-"><code>struct stats {
  950. pthread_mutex_t mutex;
  951. unsigned int curr_items;
  952. unsigned int total_items;
  953. uint64_t curr_bytes;
  954. unsigned int curr_conns;
  955. unsigned int total_conns;
  956. uint64_t rejected_conns;
  957. unsigned int reserved_fds;
  958. unsigned int conn_structs;
  959. uint64_t get_cmds;
  960. uint64_t set_cmds;
  961. uint64_t touch_cmds;
  962. uint64_t get_hits;
  963. uint64_t get_misses;
  964. uint64_t touch_hits;
  965. uint64_t touch_misses;
  966. uint64_t evictions;
  967. uint64_t reclaimed;
  968. time_t started; /* when the process was started */
  969. bool accepting_conns; /* whether we are currently accepting */
  970. uint64_t listen_disabled_num;
  971. unsigned int hash_power_level; /* Better hope it&apos;s not over 9000 */
  972. uint64_t hash_bytes; /* size used for hash tables */
  973. bool hash_is_expanding; /* If the hash table is being expanded */
  974. uint64_t expired_unfetched; /* items reclaimed but never touched */
  975. uint64_t evicted_unfetched; /* items evicted but never touched */
  976. bool slab_reassign_running; /* slab reassign in progress */
  977. uint64_t slabs_moved; /* times slabs were moved around */
  978. };
  979. </code></pre><p>&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x7684;&#x521D;&#x59CB;&#x5316;&#x4E5F;&#x5C31;&#x662F;&#x5BF9;stats&#x53D8;&#x91CF;&#x7684;&#x4E00;&#x4E2A;&#x521D;&#x59CB;&#x5316;&#x3002;</p>
  980. <pre class="language-"><code>//&#x5168;&#x5C40;&#x5BF9;&#x8C61;&#x7684;&#x5B9A;&#x4E49;
  981. struct stats stats;
  982. //&#x5168;&#x5C40;&#x53D8;&#x91CF;&#x7684;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x8BE5;&#x5168;&#x5C40;&#x53D8;&#x91CF;&#x5728;memcached&#x542F;&#x52A8;&#x4E4B;&#x540E;&#xFF0C;&#x4E00;&#x76F4;&#x4F7F;&#x7528;
  983. static void stats_init(void)
  984. {
  985. stats.curr_items = stats.total_items = stats.curr_conns =
  986. stats.total_conns = stats.conn_structs = 0;
  987. stats.get_cmds = stats.set_cmds = stats.get_hits = stats.get_misses =
  988. stats.evictions = stats.reclaimed = 0;
  989. stats.touch_cmds = stats.touch_misses = stats.touch_hits =
  990. stats.rejected_conns = 0;
  991. stats.curr_bytes = stats.listen_disabled_num = 0;
  992. stats.hash_power_level = stats.hash_bytes = stats.hash_is_expanding = 0;
  993. stats.expired_unfetched = stats.evicted_unfetched = 0;
  994. stats.slabs_moved = 0;
  995. stats.accepting_conns = true; /* assuming we start in this state. */
  996. stats.slab_reassign_running = false;
  997. /* make the time we started always be 2 seconds before we really
  998. did, so time(0) - time.started is never zero. if so, things
  999. like &apos;settings.oldest_live&apos; which act as booleans as well as
  1000. values are now false in boolean context... */
  1001. process_started = time(0) - 2;
  1002. stats_prefix_init();
  1003. }
  1004. </code></pre><p><strong>3 &#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x521D;&#x59CB;&#x5316;</strong></p>
  1005. <p><code>Memcached</code>&#x91C7;&#x7528;&#x4E86;&#x5178;&#x578B;&#x7684;<code>Master-Worker</code>&#x7684;&#x7EBF;&#x7A0B;&#x6A21;&#x5F0F;&#xFF0C;Master&#x5C31;&#x662F;&#x7531;main&#x7EBF;&#x7A0B;&#x6765;&#x5145;&#x5F53;&#xFF0C;&#x800C;Worker&#x7EBF;&#x7A0B;&#x5219;&#x662F;&#x901A;&#x8FC7;Pthread&#x521B;&#x5EFA;&#x7684;&#x3002;</p>
  1006. <pre class="language-"><code>//&#x4F20;&#x5165;&#x7EBF;&#x7A0B;&#x4E2A;&#x6570;&#x548C;libevent&#x7684;main_base&#x5B9E;&#x4F8B;
  1007. thread_init(settings.num_threads, main_base);
  1008. //&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x521D;&#x59CB;&#x5316;
  1009. void thread_init(int nthreads, struct event_base *main_base) {
  1010. int i;
  1011. int power;
  1012. //&#x521D;&#x59CB;&#x5316;&#x5404;&#x79CD;&#x9501;&#x548C;&#x6761;&#x4EF6;&#x53D8;&#x91CF;
  1013. pthread_mutex_init(&amp;cache_lock, NULL);
  1014. pthread_mutex_init(&amp;stats_lock, NULL);
  1015. pthread_mutex_init(&amp;init_lock, NULL);
  1016. pthread_cond_init(&amp;init_cond, NULL);
  1017. pthread_mutex_init(&amp;cqi_freelist_lock, NULL);
  1018. cqi_freelist = NULL;
  1019. //Memcached&#x5BF9;hash&#x6876;&#x7684;&#x9501;&#x91C7;&#x7528;&#x5206;&#x6BB5;&#x9501;&#xFF0C;&#x6309;&#x7EBF;&#x7A0B;&#x4E2A;&#x6570;&#x6765;&#x5206;&#x6BB5;&#xFF0C;&#x9ED8;&#x8BA4;&#x603B;&#x5171;&#x662F;1&lt;&lt;16&#x4E2A;hash&#x6876;&#xFF0C;&#x800C;&#x9501;&#x7684;&#x6570;&#x76EE;&#x662F;1&lt;&lt;power&#x4E2A;
  1020. /* Want a wide lock table, but don&apos;t waste memory */
  1021. if (nthreads &lt; 3) {
  1022. power = 10;
  1023. } else if (nthreads &lt; 4) {
  1024. power = 11;
  1025. } else if (nthreads &lt; 5) {
  1026. power = 12;
  1027. } else {
  1028. /* 8192 buckets, and central locks don&apos;t scale much past 5 threads */
  1029. power = 13;
  1030. }
  1031. item_lock_count = hashsize(power);
  1032. //&#x7533;&#x8BF7;1&lt;&lt;power&#x4E2A;pthread_mutex_t&#x9501;&#xFF0C;&#x4FDD;&#x5B58;&#x5728;item_locks&#x6570;&#x7EC4;&#x3002;
  1033. item_locks = calloc(item_lock_count, sizeof(pthread_mutex_t));
  1034. if (! item_locks) {
  1035. perror(&quot;Can&apos;t allocate item locks&quot;);
  1036. exit(1);
  1037. }
  1038. //&#x5BF9;&#x8FD9;&#x4E9B;&#x9501;&#x8FDB;&#x884C;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x8FD9;&#x90E8;&#x5206;&#x53EF;&#x53C2;&#x8003;APUE&#x7684;&#x7EBF;&#x7A0B;&#x90E8;&#x5206;
  1039. for (i = 0; i &lt; item_lock_count; i++) {
  1040. pthread_mutex_init(&amp;item_locks[i], NULL);
  1041. }
  1042. /*&#x521B;&#x5EFA;&#x7EBF;&#x7A0B;&#x7684;&#x5C40;&#x90E8;&#x53D8;&#x91CF;&#xFF0C;&#x8BE5;&#x5C40;&#x90E8;&#x53D8;&#x91CF;&#x7684;&#x540D;&#x79F0;&#x4E3A;item_lock_type_key,&#x7528;&#x4E8E;&#x4FDD;&#x5B58;&#x4E3B;hash&#x8868;&#x6240;&#x6301;&#x6709;&#x7684;&#x9501;&#x7684;&#x7C7B;&#x578B;
  1043. &#x4E3B;hash&#x8868;&#x5728;&#x8FDB;&#x884C;&#x6269;&#x5BB9;&#x65F6;&#xFF0C;&#x8BE5;&#x9501;&#x7C7B;&#x578B;&#x4F1A;&#x53D8;&#x4E3A;&#x5168;&#x5C40;&#x7684;&#x9501;&#xFF0C;&#x5426;&#x5219;(&#x4E0D;&#x5728;&#x6269;&#x5BB9;&#x8FC7;&#x7A0B;&#x4E2D;)&#xFF0C;&#x5219;&#x662F;&#x5C40;&#x90E8;&#x9501;*/
  1044. pthread_key_create(&amp;item_lock_type_key, NULL);
  1045. pthread_mutex_init(&amp;item_global_lock, NULL);
  1046. //&#x7533;&#x8BF7;nthreds&#x4E2A;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;,LIBEVENT_THREAD&#x662F;Memcached&#x5185;&#x90E8;&#x5BF9;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x4E00;&#x4E2A;&#x5C01;&#x88C5;
  1047. threads = calloc(nthreads, sizeof(LIBEVENT_THREAD));
  1048. if (! threads) {
  1049. perror(&quot;Can&apos;t allocate thread descriptors&quot;);
  1050. exit(1);
  1051. }
  1052. /*&#x5206;&#x53D1;&#x7EBF;&#x7A0B;&#x7684;&#x521D;&#x59CB;&#x5316;,&#x5206;&#x53D1;&#x7EBF;&#x7A0B;&#x7684;base&#x4E3A;main_base
  1053. &#x7EBF;&#x7A0B;id&#x4E3A;main&#x7EBF;&#x7A0B;&#x7684;&#x7EBF;&#x7A0B;id*/
  1054. dispatcher_thread.base = main_base;
  1055. dispatcher_thread.thread_id = pthread_self();
  1056. //&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x521D;&#x59CB;&#x5316;,&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x548C;&#x4E3B;&#x7EBF;&#x7A0B;(main&#x7EBF;&#x7A0B;)&#x662F;&#x901A;&#x8FC7;pipe&#x7BA1;&#x9053;&#x8FDB;&#x884C;&#x901A;&#x4FE1;&#x7684;
  1057. for (i = 0; i &lt; nthreads; i++) {
  1058. int fds[2];
  1059. if (pipe(fds)) {//&#x521D;&#x59CB;&#x5316;pipe&#x7BA1;&#x9053;
  1060. perror(&quot;Can&apos;t create notify pipe&quot;);
  1061. exit(1);
  1062. }
  1063. threads[i].notify_receive_fd = fds[0];//&#x8BFB;&#x7BA1;&#x9053;&#x7ED1;&#x5B9A;&#x5230;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x63A5;&#x6536;&#x6D88;&#x606F;&#x7684;&#x63CF;&#x8FF0;&#x7B26;
  1064. threads[i].notify_send_fd = fds[1];//&#x5199;&#x7BA1;&#x9053;&#x7ED1;&#x5B9A;&#x5230;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x53D1;&#x9001;&#x6D88;&#x606F;&#x7684;&#x63CF;&#x8FF0;&#x7B26;
  1065. setup_thread(&amp;threads[i]);//&#x6DFB;&#x52A0;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x5230;libevent&#x4E2D;
  1066. /* Reserve three fds for the libevent base, and two for the pipe */
  1067. stats.reserved_fds += 5;//&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;&#x66F4;&#x65B0;
  1068. }
  1069. //&#x521B;&#x5EFA;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;
  1070. for (i = 0; i &lt; nthreads; i++) {
  1071. create_worker(worker_libevent, &amp;threads[i]);
  1072. }
  1073. //&#x7B49;&#x5F85;&#x6240;&#x6709;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x521B;&#x5EFA;&#x5B8C;&#x6BD5;
  1074. pthread_mutex_lock(&amp;init_lock);
  1075. wait_for_thread_registration(nthreads);
  1076. pthread_mutex_unlock(&amp;init_lock);
  1077. }
  1078. //Memcached&#x5185;&#x90E8;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;&#x5C01;&#x88C5;
  1079. typedef struct {
  1080. pthread_t thread_id; //&#x7EBF;&#x7A0B;ID
  1081. struct event_base *base; //libevent&#x7684;&#x4E0D;&#x662F;&#x7EBF;&#x7A0B;&#x5B89;&#x5168;&#x7684;&#xFF0C;&#x6BCF;&#x4E2A;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x6301;&#x6709;&#x4E00;&#x4E2A;libevent&#x5B9E;&#x4F8B;&#xFF0C;&#x7528;&#x4E8E;pipe&#x7BA1;&#x9053;&#x901A;&#x4FE1;&#x548C;socket&#x901A;&#x4FE1;
  1082. struct event notify_event; //&#x7528;&#x4E8E;&#x76D1;&#x542C;pipe&#x7BA1;&#x9053;&#x7684;libevent&#x4E8B;&#x4EF6;
  1083. int notify_receive_fd; //&#x63A5;&#x6536;pipe&#x7BA1;&#x9053;&#x6D88;&#x606F;&#x63CF;&#x8FF0;&#x7B26;
  1084. int notify_send_fd; //&#x53D1;&#x9001;pipe&#x7BA1;&#x9053;&#x6D88;&#x606F;&#x63CF;&#x8FF0;&#x7B26;
  1085. struct thread_stats stats; //&#x6BCF;&#x4E2A;&#x7EBF;&#x7A0B;&#x5BF9;&#x5E94;&#x7684;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;
  1086. struct conn_queue *new_conn_queue; //&#x6BCF;&#x4E2A;&#x7EBF;&#x7A0B;&#x90FD;&#x6709;&#x4E00;&#x4E2A;&#x5DE5;&#x4F5C;&#x961F;&#x5217;&#xFF0C;&#x4E3B;&#x7EBF;&#x7A0B;&#x63A5;&#x53D7;&#x7684;&#x8FDE;&#x63A5;&#xFF0C;&#x6302;&#x8F7D;&#x5230;&#x8BE5;&#x6D88;&#x606F;&#x961F;&#x5217;&#x4E2D;
  1087. cache_t *suffix_cache; //&#x540E;&#x7F00;cache
  1088. uint8_t item_lock_type; //&#x7EBF;&#x7A0B;&#x64CD;&#x4F5C;hash&#x8868;&#x6301;&#x6709;&#x7684;&#x9501;&#x7C7B;&#x578B;&#xFF0C;&#x6709;&#x5C40;&#x90E8;&#x9501;&#x548C;&#x5168;&#x5C40;&#x9501;
  1089. } LIBEVENT_THREAD;
  1090. //&#x5206;&#x53D1;&#x7EBF;&#x7A0B;&#x7684;&#x5C01;&#x88C5;
  1091. typedef struct {
  1092. pthread_t thread_id; //&#x7EBF;&#x7A0B;id
  1093. struct event_base *base; //libevent&#x5B9E;&#x4F8B;
  1094. } LIBEVENT_DISPATCHER_THREAD;
  1095. //&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7ED1;&#x5B9A;&#x5230;libevent&#x5B9E;&#x4F8B;
  1096. static void setup_thread(LIBEVENT_THREAD *me) {
  1097. me-&gt;base = event_init();//&#x521B;&#x5EFA;libevent&#x5B9E;&#x4F8B;
  1098. if (! me-&gt;base) {
  1099. fprintf(stderr, &quot;Can&apos;t allocate event base\n&quot;);
  1100. exit(1);
  1101. }
  1102. //&#x521B;&#x5EFA;&#x7BA1;&#x9053;&#x8BFB;&#x7684;libevent&#x4E8B;&#x4EF6;&#xFF0C;&#x4E8B;&#x4EF6;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x5904;&#x7406;&#x5177;&#x4F53;&#x7684;&#x4E1A;&#x52A1;&#x4FE1;&#x606F;&#xFF0C;&#x5173;&#x4E8E;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x7684;&#x5904;&#x7406;&#xFF0C;&#x540E;&#x7EED;&#x5206;&#x6790;
  1103. event_set(&amp;me-&gt;notify_event, me-&gt;notify_receive_fd,
  1104. EV_READ | EV_PERSIST, thread_libevent_process, me);
  1105. event_base_set(me-&gt;base, &amp;me-&gt;notify_event);//&#x8BBE;&#x7F6E;libevent&#x5B9E;&#x4F8B;
  1106. //&#x6DFB;&#x52A0;&#x4E8B;&#x4EF6;&#x5230;libevent&#x4E2D;
  1107. if (event_add(&amp;me-&gt;notify_event, 0) == -1) {
  1108. fprintf(stderr, &quot;Can&apos;t monitor libevent notify pipe\n&quot;);
  1109. exit(1);
  1110. }
  1111. //&#x521B;&#x5EFA;&#x6D88;&#x606F;&#x961F;&#x5217;&#xFF0C;&#x7528;&#x4E8E;&#x63A5;&#x53D7;&#x4E3B;&#x7EBF;&#x7A0B;&#x8FDE;&#x63A5;
  1112. me-&gt;new_conn_queue = malloc(sizeof(struct conn_queue));
  1113. if (me-&gt;new_conn_queue == NULL) {
  1114. perror(&quot;Failed to allocate memory for connection queue&quot;);
  1115. exit(EXIT_FAILURE);
  1116. }
  1117. cq_init(me-&gt;new_conn_queue);//&#x6D88;&#x606F;&#x961F;&#x5217;&#x521D;&#x59CB;&#x5316;
  1118. if (pthread_mutex_init(&amp;me-&gt;stats.mutex, NULL) != 0) {
  1119. perror(&quot;Failed to initialize mutex&quot;);
  1120. exit(EXIT_FAILURE);
  1121. }
  1122. //&#x521B;&#x5EFA;&#x7EBF;&#x7A0B;&#x7684;&#x540E;&#x7F00;cache,&#x6CA1;&#x641E;&#x61C2;&#x8FD9;&#x4E2A;cache&#x6709;&#x4EC0;&#x4E48;&#x4F5C;&#x7528;&#x3002;
  1123. me-&gt;suffix_cache = cache_create(&quot;suffix&quot;, SUFFIX_SIZE, sizeof(char*),
  1124. NULL, NULL);
  1125. if (me-&gt;suffix_cache == NULL) {
  1126. fprintf(stderr, &quot;Failed to create suffix cache\n&quot;);
  1127. exit(EXIT_FAILURE);
  1128. }
  1129. }
  1130. //&#x521B;&#x5EFA;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;
  1131. static void create_worker(void *(*func)(void *), void *arg) {
  1132. pthread_t thread;
  1133. pthread_attr_t attr;
  1134. int ret;
  1135. pthread_attr_init(&amp;attr);//Posix&#x7EBF;&#x7A0B;&#x90E8;&#x5206;&#xFF0C;&#x7EBF;&#x7A0B;&#x5C5E;&#x6027;&#x521D;&#x59CB;&#x5316;
  1136. //&#x901A;&#x8FC7;pthread_create&#x521B;&#x5EFA;&#x7EBF;&#x7A0B;&#xFF0C;&#x7EBF;&#x7A0B;&#x5904;&#x7406;&#x51FD;&#x6570;&#x662F;&#x901A;&#x8FC7;&#x5916;&#x90E8;&#x4F20;&#x5165;&#x7684;&#x5904;&#x7406;&#x51FD;&#x6570;&#x4E3A;worker_libevent
  1137. if ((ret = pthread_create(&amp;thread, &amp;attr, func, arg)) != 0) {
  1138. fprintf(stderr, &quot;Can&apos;t create thread: %s\n&quot;,
  1139. strerror(ret));
  1140. exit(1);
  1141. }
  1142. }
  1143. //&#x7EBF;&#x7A0B;&#x5904;&#x7406;&#x51FD;&#x6570;
  1144. static void *worker_libevent(void *arg) {
  1145. LIBEVENT_THREAD *me = arg;
  1146. //&#x9ED8;&#x8BA4;&#x7684;hash&#x8868;&#x7684;&#x9501;&#x4E3A;&#x5C40;&#x90E8;&#x9501;
  1147. me-&gt;item_lock_type = ITEM_LOCK_GRANULAR;
  1148. pthread_setspecific(item_lock_type_key, &amp;me-&gt;item_lock_type);//&#x8BBE;&#x5B9A;&#x7EBF;&#x7A0B;&#x7684;&#x5C5E;&#x6027;
  1149. //&#x7528;&#x4E8E;&#x63A7;&#x5236;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x901A;&#x8FC7;&#x6761;&#x4EF6;&#x53D8;&#x91CF;&#x6765;&#x63A7;&#x5236;
  1150. register_thread_initialized();
  1151. //&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;&#x7684;libevent&#x5B9E;&#x4F8B;&#x542F;&#x52A8;
  1152. event_base_loop(me-&gt;base, 0);
  1153. return NULL;
  1154. }
  1155. //&#x963B;&#x585E;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;
  1156. static void wait_for_thread_registration(int nthreads) {
  1157. while (init_count &lt; nthreads) {
  1158. pthread_cond_wait(&amp;init_cond, &amp;init_lock);//&#x5728;&#x6761;&#x4EF6;&#x53D8;&#x91CF;init_cond&#x4E0A;&#x9762;&#x963B;&#x585E;&#xFF0C;&#x963B;&#x585E;&#x4E2A;&#x6570;&#x4E3A;nthreads-init_count
  1159. }
  1160. }
  1161. //&#x5524;&#x9192;&#x5DE5;&#x4F5C;&#x7EBF;&#x7A0B;
  1162. static void register_thread_initialized(void) {
  1163. pthread_mutex_lock(&amp;init_lock);
  1164. init_count++;
  1165. pthread_cond_signal(&amp;init_cond);
  1166. pthread_mutex_unlock(&amp;init_lock);
  1167. }
  1168. //&#x6BCF;&#x4E2A;&#x7EBF;&#x7A0B;&#x6301;&#x6709;&#x7684;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;
  1169. struct thread_stats {
  1170. pthread_mutex_t mutex;
  1171. uint64_t get_cmds;
  1172. uint64_t get_misses;
  1173. uint64_t touch_cmds;
  1174. uint64_t touch_misses;
  1175. uint64_t delete_misses;
  1176. uint64_t incr_misses;
  1177. uint64_t decr_misses;
  1178. uint64_t cas_misses;
  1179. uint64_t bytes_read;
  1180. uint64_t bytes_written;
  1181. uint64_t flush_cmds;
  1182. uint64_t conn_yields; /* # of yields for connections (-R option)*/
  1183. uint64_t auth_cmds;
  1184. uint64_t auth_errors;
  1185. struct slab_stats slab_stats[MAX_NUMBER_OF_SLAB_CLASSES];
  1186. };
  1187. //&#x6BCF;&#x4E2A;slab&#x7684;&#x7EDF;&#x8BA1;&#x4FE1;&#x606F;
  1188. struct slab_stats {
  1189. uint64_t set_cmds;
  1190. uint64_t get_hits;
  1191. uint64_t touch_hits;
  1192. uint64_t delete_hits;
  1193. uint64_t cas_hits;
  1194. uint64_t cas_badval;
  1195. uint64_t incr_hits;
  1196. uint64_t decr_hits;
  1197. };
  1198. </code></pre><p><strong>4 &#x8FDE;&#x63A5;&#x7684;&#x521D;&#x59CB;&#x5316;</strong></p>
  1199. <pre class="language-"><code>static conn **freeconns;//&#x7A7A;&#x95F2;&#x8FDE;&#x63A5;&#x5217;&#x8868;
  1200. //&#x8FDE;&#x63A5;&#x521D;&#x59CB;&#x5316;
  1201. static void conn_init(void)
  1202. {
  1203. freetotal = 200;//&#x7A7A;&#x95F2;&#x8FDE;&#x63A5;&#x603B;&#x6570;
  1204. freecurr = 0;//&#x5F53;&#x524D;&#x7A7A;&#x95F2;&#x7684;&#x7D22;&#x5F15;
  1205. //&#x7533;&#x8BF7;200&#x4E2A;&#x7A7A;&#x95F4;
  1206. if ((freeconns = calloc(freetotal, sizeof(conn *))) == NULL)
  1207. {
  1208. fprintf(stderr, &quot;Failed to allocate connection structures\n&quot;);
  1209. }
  1210. return;
  1211. }
  1212. </code></pre><footer class="page-footer"><span class="copyright">&#x5982;&#x9700;&#x4E0B;&#x8F7D;&#x672C;&#x7AD9;&#x5168;&#x90E8;&#x6280;&#x672F;&#x6587;&#x7AE0;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x3010;&#x9AD8;&#x6027;&#x80FD;&#x670D;&#x52A1;&#x5668;&#x5F00;&#x53D1;&#x3011;&#x516C;&#x4F17;&#x53F7;&#x56DE;&#x590D;&#x5173;&#x952E;&#x5B57;&#x201C;&#x6587;&#x7AE0;&#x4E0B;&#x8F7D;&#x201D;&#x5373;&#x53EF;&#x3002;</span><span class="footer-modification">&#x6700;&#x8FD1;&#x66F4;&#x65B0;&#x65F6;&#x95F4;&#xFF1A;
  1213. 2020-10-03 14:14:47
  1214. </span></footer>
  1215. <script>console.log("plugin-popup....");document.onclick = function(e){ e.target.tagName === "IMG" && window.open(e.target.src,e.target.src)}</script><style>img{cursor:pointer}</style>
  1216. </section>
  1217. </div>
  1218. <div class="search-results">
  1219. <div class="has-results">
  1220. <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
  1221. <ul class="search-results-list"></ul>
  1222. </div>
  1223. <div class="no-results">
  1224. <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
  1225. </div>
  1226. </div>
  1227. </div>
  1228. </div>
  1229. </div>
  1230. </div>
  1231. <a href="04内存初始化.html" class="navigation navigation-prev " aria-label="Previous page: 04 内存初始化">
  1232. <i class="fa fa-angle-left"></i>
  1233. </a>
  1234. <a href="06get过程.html" class="navigation navigation-next " aria-label="Next page: 06 get过程">
  1235. <i class="fa fa-angle-right"></i>
  1236. </a>
  1237. </div>
  1238. <script>
  1239. var gitbook = gitbook || [];
  1240. gitbook.push(function() {
  1241. gitbook.page.hasChanged({"page":{"title":"05 资源初始化","level":"8.1.6","depth":2,"next":{"title":"06 get过程","level":"8.1.7","depth":2,"path":"articles/Memcached源码分析/06get过程.md","ref":"articles/Memcached源码分析/06get过程.md","articles":[]},"previous":{"title":"04 内存初始化","level":"8.1.5","depth":2,"path":"articles/Memcached源码分析/04内存初始化.md","ref":"articles/Memcached源码分析/04内存初始化.md","articles":[]},"dir":"ltr"},"config":{"plugins":["chapter-fold","-lunr","-search","search-pro","splitter","popup","back-to-top-button","hide-element","prism","-highlight","tbfed-pagefooter","code","anchor-navigation-ex","theme-fexa","livereload"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"tbfed-pagefooter":{"copyright":"如需下载本站全部技术文章,可以在【高性能服务器开发】公众号回复关键字“文章下载”即可。","modify_label":"最近更新时间:","modify_format":"YYYY-MM-DD HH:mm:ss"},"chapter-fold":{},"prism":{},"livereload":{},"splitter":{},"search-pro":{},"popup":{},"theme-fexa":{"search-placeholder":"输入关键字搜索","logo":"./logo.png","favicon":"./favicon.ico"},"code":{"copyButtons":true},"hide-element":{"elements":[".gitbook-link"]},"fontsettings":{"theme":"white","family":"sans","size":2},"anchor-navigation-ex":{"showLevel":false,"associatedWithSummary":true,"mode":"float","showGoTop":false,"printLog":false,"multipleH1":true,"float":{"floatIcon":"fa fa-navicon","showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""},"pageTop":{"showLevelIcon":false,"level1Icon":"","level2Icon":"","level3Icon":""}},"back-to-top-button":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","author":"easy_coder","pdf":{"pageBreaksBefore":"/","headerTemplate":null,"paperSize":"a4","margin":{"right":62,"left":62,"top":36,"bottom":36},"fontSize":12,"fontFamily":"Arial","footerTemplate":null,"chapterMark":"pagebreak","pageNumbers":false},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"isbn":"","variables":{},"title":"高性能服务器开发 技术专栏","links":{},"gitbook":"*","description":"","theme-default":{"showLevel":true},"extension":null},"file":{"path":"articles/Memcached源码分析/05资源初始化.md","mtime":"2020-10-03T06:14:47.675Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-10-09T15:31:57.905Z"},"basePath":"../..","book":{"language":""}});
  1242. });
  1243. </script>
  1244. </div>
  1245. <script src="../../gitbook/gitbook.js"></script>
  1246. <script src="../../gitbook/theme.js"></script>
  1247. <script src="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.js"></script>
  1248. <script src="../../gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
  1249. <script src="../../gitbook/gitbook-plugin-search-pro/search.js"></script>
  1250. <script src="../../gitbook/gitbook-plugin-splitter/splitter.js"></script>
  1251. <script src="../../gitbook/gitbook-plugin-back-to-top-button/plugin.js"></script>
  1252. <script src="../../gitbook/gitbook-plugin-hide-element/plugin.js"></script>
  1253. <script src="../../gitbook/gitbook-plugin-code/plugin.js"></script>
  1254. <script src="../../gitbook/gitbook-plugin-livereload/plugin.js"></script>
  1255. <script src="../../gitbook/gitbook-plugin-sharing/buttons.js"></script>
  1256. <script src="../../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
  1257. <script src="../../gitbook/gitbook-plugin-theme-fexa/fexa.js"></script>
  1258. </body>
  1259. </html>