leveldb源码分析20.html 105 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767
  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>leveldb源码分析20 · 高性能服务器开发 技术专栏</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="leveldb源码分析21.html" />
  29. <link rel="prev" href="leveldb源码分析19.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="./">
  463. <a href="./">
  464. leveldb源码分析
  465. </a>
  466. <ul class="articles">
  467. <li class="chapter " data-level="7.2.1" data-path="leveldb源码分析1.html">
  468. <a href="leveldb源码分析1.html">
  469. leveldb源码分析1
  470. </a>
  471. </li>
  472. <li class="chapter " data-level="7.2.2" data-path="leveldb源码分析2.html">
  473. <a href="leveldb源码分析2.html">
  474. leveldb源码分析2
  475. </a>
  476. </li>
  477. <li class="chapter " data-level="7.2.3" data-path="leveldb源码分析3.html">
  478. <a href="leveldb源码分析3.html">
  479. leveldb源码分析3
  480. </a>
  481. </li>
  482. <li class="chapter " data-level="7.2.4" data-path="leveldb源码分析4.html">
  483. <a href="leveldb源码分析4.html">
  484. leveldb源码分析4
  485. </a>
  486. </li>
  487. <li class="chapter " data-level="7.2.5" data-path="leveldb源码分析5.html">
  488. <a href="leveldb源码分析5.html">
  489. leveldb源码分析5
  490. </a>
  491. </li>
  492. <li class="chapter " data-level="7.2.6" data-path="leveldb源码分析6.html">
  493. <a href="leveldb源码分析6.html">
  494. leveldb源码分析6
  495. </a>
  496. </li>
  497. <li class="chapter " data-level="7.2.7" data-path="leveldb源码分析7.html">
  498. <a href="leveldb源码分析7.html">
  499. leveldb源码分析7
  500. </a>
  501. </li>
  502. <li class="chapter " data-level="7.2.8" data-path="leveldb源码分析8.html">
  503. <a href="leveldb源码分析8.html">
  504. leveldb源码分析8
  505. </a>
  506. </li>
  507. <li class="chapter " data-level="7.2.9" data-path="leveldb源码分析9.html">
  508. <a href="leveldb源码分析9.html">
  509. leveldb源码分析9
  510. </a>
  511. </li>
  512. <li class="chapter " data-level="7.2.10" data-path="leveldb源码分析10.html">
  513. <a href="leveldb源码分析10.html">
  514. leveldb源码分析10
  515. </a>
  516. </li>
  517. <li class="chapter " data-level="7.2.11" data-path="leveldb源码分析11.html">
  518. <a href="leveldb源码分析11.html">
  519. leveldb源码分析11
  520. </a>
  521. </li>
  522. <li class="chapter " data-level="7.2.12" data-path="leveldb源码分析12.html">
  523. <a href="leveldb源码分析12.html">
  524. leveldb源码分析12
  525. </a>
  526. </li>
  527. <li class="chapter " data-level="7.2.13" data-path="leveldb源码分析13.html">
  528. <a href="leveldb源码分析13.html">
  529. leveldb源码分析13
  530. </a>
  531. </li>
  532. <li class="chapter " data-level="7.2.14" data-path="leveldb源码分析14.html">
  533. <a href="leveldb源码分析14.html">
  534. leveldb源码分析14
  535. </a>
  536. </li>
  537. <li class="chapter " data-level="7.2.15" data-path="leveldb源码分析15.html">
  538. <a href="leveldb源码分析15.html">
  539. leveldb源码分析15
  540. </a>
  541. </li>
  542. <li class="chapter " data-level="7.2.16" data-path="leveldb源码分析16.html">
  543. <a href="leveldb源码分析16.html">
  544. leveldb源码分析16
  545. </a>
  546. </li>
  547. <li class="chapter " data-level="7.2.17" data-path="leveldb源码分析17.html">
  548. <a href="leveldb源码分析17.html">
  549. leveldb源码分析17
  550. </a>
  551. </li>
  552. <li class="chapter " data-level="7.2.18" data-path="leveldb源码分析18.html">
  553. <a href="leveldb源码分析18.html">
  554. leveldb源码分析18
  555. </a>
  556. </li>
  557. <li class="chapter " data-level="7.2.19" data-path="leveldb源码分析19.html">
  558. <a href="leveldb源码分析19.html">
  559. leveldb源码分析19
  560. </a>
  561. </li>
  562. <li class="chapter active" data-level="7.2.20" data-path="leveldb源码分析20.html">
  563. <a href="leveldb源码分析20.html">
  564. leveldb源码分析20
  565. </a>
  566. </li>
  567. <li class="chapter " data-level="7.2.21" data-path="leveldb源码分析21.html">
  568. <a href="leveldb源码分析21.html">
  569. leveldb源码分析21
  570. </a>
  571. </li>
  572. <li class="chapter " data-level="7.2.22" data-path="leveldb源码分析22.html">
  573. <a href="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="../Memcached源码分析/">
  581. <a href="../Memcached源码分析/">
  582. Memcached源码分析
  583. </a>
  584. <ul class="articles">
  585. <li class="chapter " data-level="8.1.1" data-path="../Memcached源码分析/00服务器资源调整.html">
  586. <a href="../Memcached源码分析/00服务器资源调整.html">
  587. 00 服务器资源调整
  588. </a>
  589. </li>
  590. <li class="chapter " data-level="8.1.2" data-path="../Memcached源码分析/01初始化参数解析.html">
  591. <a href="../Memcached源码分析/01初始化参数解析.html">
  592. 01 初始化参数解析
  593. </a>
  594. </li>
  595. <li class="chapter " data-level="8.1.3" data-path="../Memcached源码分析/02网络监听的建立.html">
  596. <a href="../Memcached源码分析/02网络监听的建立.html">
  597. 02 网络监听的建立
  598. </a>
  599. </li>
  600. <li class="chapter " data-level="8.1.4" data-path="../Memcached源码分析/03网络连接建立.html">
  601. <a href="../Memcached源码分析/03网络连接建立.html">
  602. 03 网络连接建立
  603. </a>
  604. </li>
  605. <li class="chapter " data-level="8.1.5" data-path="../Memcached源码分析/04内存初始化.html">
  606. <a href="../Memcached源码分析/04内存初始化.html">
  607. 04 内存初始化
  608. </a>
  609. </li>
  610. <li class="chapter " data-level="8.1.6" data-path="../Memcached源码分析/05资源初始化.html">
  611. <a href="../Memcached源码分析/05资源初始化.html">
  612. 05 资源初始化
  613. </a>
  614. </li>
  615. <li class="chapter " data-level="8.1.7" data-path="../Memcached源码分析/06get过程.html">
  616. <a href="../Memcached源码分析/06get过程.html">
  617. 06 get过程
  618. </a>
  619. </li>
  620. <li class="chapter " data-level="8.1.8" data-path="../Memcached源码分析/07cas属性.html">
  621. <a href="../Memcached源码分析/07cas属性.html">
  622. 07 cas属性
  623. </a>
  624. </li>
  625. <li class="chapter " data-level="8.1.9" data-path="../Memcached源码分析/08内存池.html">
  626. <a href="../Memcached源码分析/08内存池.html">
  627. 08 内存池
  628. </a>
  629. </li>
  630. <li class="chapter " data-level="8.1.10" data-path="../Memcached源码分析/09连接队列.html">
  631. <a href="../Memcached源码分析/09连接队列.html">
  632. 09 连接队列
  633. </a>
  634. </li>
  635. <li class="chapter " data-level="8.1.11" data-path="../Memcached源码分析/10Hash表操作.html">
  636. <a href="../Memcached源码分析/10Hash表操作.html">
  637. 10 Hash表操作
  638. </a>
  639. </li>
  640. <li class="chapter " data-level="8.1.12" data-path="../Memcached源码分析/12set操作.html">
  641. <a href="../Memcached源码分析/12set操作.html">
  642. 12 set操作
  643. </a>
  644. </li>
  645. <li class="chapter " data-level="8.1.13" data-path="../Memcached源码分析/13do_item_alloc操作.html">
  646. <a href="../Memcached源码分析/13do_item_alloc操作.html">
  647. 13 do_item_alloc操作
  648. </a>
  649. </li>
  650. <li class="chapter " data-level="8.1.14" data-path="../Memcached源码分析/14item结构.html">
  651. <a href="../Memcached源码分析/14item结构.html">
  652. 14 item结构
  653. </a>
  654. </li>
  655. <li class="chapter " data-level="8.1.15" data-path="../Memcached源码分析/15Hash表扩容.html">
  656. <a href="../Memcached源码分析/15Hash表扩容.html">
  657. 15 Hash表扩容
  658. </a>
  659. </li>
  660. <li class="chapter " data-level="8.1.16" data-path="../Memcached源码分析/16线程交互.html">
  661. <a href="../Memcached源码分析/16线程交互.html">
  662. 16 线程交互
  663. </a>
  664. </li>
  665. <li class="chapter " data-level="8.1.17" data-path="../Memcached源码分析/17状态机.html">
  666. <a href="../Memcached源码分析/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="../.." >leveldb源码分析20</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="#leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20"><b></b>leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20</a></li><ul><li><span class="title-icon "></span><a href="#&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;"><b></b>&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;</a></li><ul><li><span class="title-icon "></span><a href="#12-db&#x7684;&#x6253;&#x5F00;"><b></b>12 DB&#x7684;&#x6253;&#x5F00;</a></li><li><span class="title-icon "></span><a href="#121-dbopen"><b></b>12.1 DB::Open()</a></li><li><span class="title-icon "></span><a href="#123-dbimpnewdb"><b></b>12.3 DBImp::NewDB()</a></li><li><span class="title-icon "></span><a href="#125-dbimpldeleteobsoletefiles"><b></b>12.5 DBImpl::DeleteObsoleteFiles()</a></li><li><span class="title-icon "></span><a href="#126-dbimplrecoverlogfile"><b></b>12.6 DBImpl::RecoverLogFile()</a></li></ul><li><span class="title-icon "></span><a href="#_1"><b></b> </a></li><ul><li><span class="title-icon "></span><a href="#13-db&#x7684;&#x5173;&#x95ED;&#x9500;&#x6BC1;"><b></b>13 DB&#x7684;&#x5173;&#x95ED;&amp;&#x9500;&#x6BC1;</a></li><li><span class="title-icon "></span><a href="#131-db&#x5173;&#x95ED;"><b></b>13.1 DB&#x5173;&#x95ED;</a></li><li><span class="title-icon "></span><a href="#132-db&#x9500;&#x6BC1;"><b></b>13.2 DB&#x9500;&#x6BC1;</a></li></ul></ul></ul></div><h1 id="leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20"><a name="leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20" class="anchor-navigation-ex-anchor" href="#leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20"><i class="fa fa-link" aria-hidden="true"></i></a>leveldb&#x6E90;&#x7801;&#x5206;&#x6790;20</h1>
  922. <h2 id="&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;"><a name="&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;" class="anchor-navigation-ex-anchor" href="#&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x672C;&#x7CFB;&#x5217;&#x300A;leveldb&#x6E90;&#x7801;&#x5206;&#x6790;&#x300B;&#x5171;&#x6709;22&#x7BC7;&#x6587;&#x7AE0;&#xFF0C;&#x8FD9;&#x662F;&#x7B2C;&#x4E8C;&#x5341;&#x7BC7;</h2>
  923. <h3 id="12-db&#x7684;&#x6253;&#x5F00;"><a name="12-db&#x7684;&#x6253;&#x5F00;" class="anchor-navigation-ex-anchor" href="#12-db&#x7684;&#x6253;&#x5F00;"><i class="fa fa-link" aria-hidden="true"></i></a>12 DB&#x7684;&#x6253;&#x5F00;</h3>
  924. <p>&#x5148;&#x5206;&#x6790;LevelDB&#x662F;&#x5982;&#x4F55;&#x6253;&#x5F00;db&#x7684;&#xFF0C;&#x4E07;&#x7269;&#x59CB;&#x4E8E;&#x521B;&#x5EFA;&#x3002;&#x5728;&#x6253;&#x5F00;&#x6D41;&#x7A0B;&#x4E2D;&#x6709;&#x51E0;&#x4E2A;&#x8F85;&#x52A9;&#x51FD;&#x6570;&#xFF1A;<strong>DBImpl()&#xFF0C;DBImpl::Recover, DBImpl::DeleteObsoleteFiles, DBImpl::RecoverLogFile, DBImpl::MaybeScheduleCompaction</strong>&#x3002;</p>
  925. <h3 id="121-dbopen"><a name="121-dbopen" class="anchor-navigation-ex-anchor" href="#121-dbopen"><i class="fa fa-link" aria-hidden="true"></i></a>12.1 DB::Open()</h3>
  926. <p>&#x6253;&#x5F00;&#x4E00;&#x4E2A;db&#xFF0C;&#x8FDB;&#x884C;PUT&#x3001;GET&#x64CD;&#x4F5C;&#xFF0C;&#x5C31;&#x662F;&#x524D;&#x9762;&#x7684;&#x9759;&#x6001;&#x51FD;&#x6570;<strong>DB::Open</strong>&#x7684;&#x5DE5;&#x4F5C;&#x3002;&#x5982;&#x679C;&#x64CD;&#x4F5C;&#x6210;&#x529F;&#xFF0C;&#x5B83;&#x5C31;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;db&#x6307;&#x9488;&#x3002;&#x524D;&#x9762;&#x8BF4;&#x8FC7;DB&#x5C31;&#x662F;&#x4E00;&#x4E2A;&#x63A5;&#x53E3;&#x7C7B;&#xFF0C;&#x5176;&#x5177;&#x4F53;&#x5B9E;&#x73B0;&#x5728;DBImp&#x7C7B;&#x4E2D;&#xFF0C;&#x8FD9;&#x662F;&#x4E00;&#x4E2A;DB&#x7684;&#x5B50;&#x7C7B;&#x3002;
  927. &#x51FD;&#x6570;&#x58F0;&#x660E;&#x4E3A;&#xFF1A;</p>
  928. <pre class="language-"><code>Status DB::Open(const Options&amp; options, const std::string&amp;dbname, DB** dbptr);
  929. </code></pre><p>&#x5206;&#x89E3;&#x6765;&#x770B;&#xFF0C;Open()&#x51FD;&#x6570;&#x4E3B;&#x8981;&#x6709;&#x4EE5;&#x4E0B;5&#x4E2A;&#x6267;&#x884C;&#x6B65;&#x9AA4;&#x3002;
  930. S1 &#x521B;&#x5EFA;DBImpl&#x5BF9;&#x8C61;&#xFF0C;&#x5176;&#x540E;&#x8FDB;&#x5165;<strong>DBImpl::Recover()</strong>&#x51FD;&#x6570;&#x6267;&#x884C;S2&#x548C;S3&#x3002;
  931. S2 &#x4ECE;&#x5DF2;&#x5B58;&#x5728;&#x7684;db&#x6587;&#x4EF6;&#x6062;&#x590D;db&#x6570;&#x636E;&#xFF0C;&#x6839;&#x636E;CURRENT&#x8BB0;&#x5F55;&#x7684;MANIFEST&#x6587;&#x4EF6;&#x8BFB;&#x53D6;db&#x5143;&#x4FE1;&#x606F;&#xFF1B;&#x8FD9;&#x901A;&#x8FC7;&#x8C03;&#x7528;<strong>VersionSet::Recover()</strong>&#x5B8C;&#x6210;&#x3002;
  932. S3 &#x7136;&#x540E;&#x8FC7;&#x6EE4;&#x51FA;&#x90A3;&#x4E9B;&#x6700;&#x8FD1;&#x7684;&#x66F4;&#x65B0;log&#xFF0C;&#x524D;&#x4E00;&#x4E2A;&#x7248;&#x672C;&#x53EF;&#x80FD;&#x65B0;&#x52A0;&#x4E86;&#x8FD9;&#x4E9B;log&#xFF0C;&#x4F46;&#x5E76;&#x6CA1;&#x6709;&#x8BB0;&#x5F55;&#x5728;MANIFEST&#x4E2D;&#x3002;&#x7136;&#x540E;&#x4F9D;&#x6B21;&#x6839;&#x636E;&#x65F6;&#x95F4;&#x987A;&#x5E8F;&#xFF0C;&#x8C03;&#x7528;<strong>DBImpl::RecoverLogFile()</strong>&#x4ECE;&#x65E7;&#x5230;&#x65B0;&#x56DE;&#x653E;&#x8FD9;&#x4E9B;&#x64CD;&#x4F5C;log&#x3002;&#x56DE;&#x653E;log&#x65F6;&#x53EF;&#x80FD;&#x4F1A;&#x4FEE;&#x6539;db&#x5143;&#x4FE1;&#x606F;&#xFF0C;&#x6BD4;&#x5982;dump&#x4E86;&#x65B0;&#x7684;level 0&#x6587;&#x4EF6;&#xFF0C;&#x56E0;&#x6B64;&#x5B83;&#x5C06;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;VersionEdit&#x5BF9;&#x8C61;&#xFF0C;&#x8BB0;&#x5F55;db&#x5143;&#x4FE1;&#x606F;&#x7684;&#x53D8;&#x52A8;&#x3002;
  933. S4 &#x5982;&#x679C;<strong>DBImpl::Recover()</strong>&#x8FD4;&#x56DE;&#x6210;&#x529F;&#xFF0C;&#x5C31;&#x6267;&#x884C;<strong>VersionSet::LogAndApply()</strong>&#x5E94;&#x7528;VersionEdit&#xFF0C;&#x5E76;&#x4FDD;&#x5B58;&#x5F53;&#x524D;&#x7684;DB&#x4FE1;&#x606F;&#x5230;&#x65B0;&#x7684;MANIFEST&#x6587;&#x4EF6;&#x4E2D;&#x3002;
  934. S5 &#x6700;&#x540E;&#x5220;&#x9664;&#x4E00;&#x4E9B;&#x8FC7;&#x671F;&#x6587;&#x4EF6;&#xFF0C;&#x5E76;&#x68C0;&#x67E5;&#x662F;&#x5426;&#x9700;&#x8981;&#x6267;&#x884C;compaction&#xFF0C;&#x5982;&#x679C;&#x9700;&#x8981;&#xFF0C;&#x5C31;&#x542F;&#x52A8;&#x540E;&#x53F0;&#x7EBF;&#x7A0B;&#x6267;&#x884C;&#x3002;
  935. &#x4E0B;&#x9762;&#x5C31;&#x6765;&#x5177;&#x4F53;&#x5206;&#x6790;Open&#x51FD;&#x6570;&#x7684;&#x4EE3;&#x7801;&#xFF0C;&#x5728;Open&#x51FD;&#x6570;&#x4E2D;&#x6D89;&#x53CA;&#x5230;&#x4E0A;&#x9762;&#x7684;3&#x4E2A;&#x6D41;&#x7A0B;&#x3002;
  936. S1 &#x9996;&#x5148;&#x521B;&#x5EFA;DBImpl&#x5BF9;&#x8C61;&#xFF0C;&#x9501;&#x5B9A;&#x5E76;&#x8BD5;&#x56FE;&#x505A;Recover&#x64CD;&#x4F5C;&#x3002;Recover&#x64CD;&#x4F5C;&#x7528;&#x6765;&#x5904;&#x7406;&#x521B;&#x5EFA;flag&#xFF0C;&#x6BD4;&#x5982;&#x5B58;&#x5728;&#x5C31;&#x8FD4;&#x56DE;&#x5931;&#x8D25;&#x7B49;&#x7B49;&#xFF0C;&#x5C1D;&#x8BD5;&#x4ECE;&#x5DF2;&#x5B58;&#x5728;&#x7684;sstable&#x6587;&#x4EF6;&#x6062;&#x590D;db&#x3002;&#x5E76;&#x8FD4;&#x56DE;db&#x5143;&#x4FE1;&#x606F;&#x7684;&#x53D8;&#x52A8;&#x4FE1;&#x606F;&#xFF0C;&#x4E00;&#x4E2A;VersionEdit&#x5BF9;&#x8C61;&#x3002;</p>
  937. <pre class="language-"><code>1DBImpl* impl = newDBImpl(options, dbname);
  938. 2impl-&gt;mutex_.Lock(); // &#x9501;db
  939. 3VersionEdit edit;
  940. 4Status s =impl-&gt;Recover(&amp;edit); // &#x5904;&#x7406;flag&amp;&#x6062;&#x590D;&#xFF1A;create_if_missing,error_if_exists
  941. </code></pre><p>S2 &#x5982;&#x679C;Recover&#x8FD4;&#x56DE;&#x6210;&#x529F;&#xFF0C;&#x5219;&#x8C03;&#x7528;VersionSet&#x53D6;&#x5F97;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#x2014;&#x2014;&#x5B9E;&#x9645;&#x4E0A;&#x662F;&#x5728;&#x5F53;&#x524D;&#x57FA;&#x7840;&#x4E0A;+1&#xFF0C;&#x51C6;&#x5907;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#x3002;&#x5982;&#x679C;log&#x6587;&#x4EF6;&#x521B;&#x5EFA;&#x6210;&#x529F;&#xFF0C;&#x5219;&#x6839;&#x636E;log&#x6587;&#x4EF6;&#x521B;&#x5EFA;log::Writer&#x3002;&#x7136;&#x540E;&#x6267;&#x884C;VersionSet::LogAndApply&#xFF0C;&#x6839;&#x636E;edit&#x8BB0;&#x5F55;&#x7684;&#x589E;&#x91CF;&#x53D8;&#x52A8;&#x751F;&#x6210;&#x65B0;&#x7684;current version&#xFF0C;&#x5E76;&#x5199;&#x5165;MANIFEST&#x6587;&#x4EF6;&#x3002;</p>
  942. <p>&#x51FD;&#x6570;<strong>NewFileNumber(){returnnext<em>file_number</em>++;}</strong>&#xFF0C;&#x76F4;&#x63A5;&#x8FD4;&#x56DE;<strong>next<em>file_number</em></strong>&#x3002;</p>
  943. <pre class="language-"><code> 1uint64_t new_log_number = impl-&gt;versions_-&gt;NewFileNumber();
  944. 2WritableFile* lfile;
  945. 3s = options.env-&gt;NewWritableFile(LogFileName(dbname, new_log_number), &amp;lfile);
  946. 4if (s.ok()) {
  947. 5 edit.SetLogNumber(new_log_number);
  948. 6 impl-&gt;logfile_ = lfile;
  949. 7 impl-&gt;logfile_number_ = new_log_number;
  950. 8 impl-&gt;log_ = newlog::Writer(lfile);
  951. 9 s = impl-&gt;versions_-&gt;LogAndApply(&amp;edit, &amp;impl-&gt;mutex_);
  952. 10}
  953. </code></pre><p>S3 &#x5982;&#x679C;VersionSet::LogAndApply&#x8FD4;&#x56DE;&#x6210;&#x529F;&#xFF0C;&#x5219;&#x5220;&#x9664;&#x8FC7;&#x671F;&#x6587;&#x4EF6;&#xFF0C;&#x68C0;&#x67E5;&#x662F;&#x5426;&#x9700;&#x8981;&#x6267;&#x884C;compaction&#xFF0C;&#x6700;&#x7EC8;&#x8FD4;&#x56DE;&#x521B;&#x5EFA;&#x7684;DBImpl&#x5BF9;&#x8C61;&#x3002;</p>
  954. <pre class="language-"><code>1if (s.ok()) {
  955. 2 impl-&gt;DeleteObsoleteFiles();
  956. 3 impl-&gt;MaybeScheduleCompaction();
  957. 4}
  958. 5impl-&gt;mutex_.Unlock();
  959. 6if (s.ok()) *dbptr = impl;
  960. 7return s;
  961. </code></pre><p>&#x4EE5;&#x4E0A;&#x5C31;&#x662F;DB::Open&#x7684;&#x4E3B;&#x9898;&#x903B;&#x8F91;&#x3002;</p>
  962. <p><strong>12.2 DBImpl::DBImpl()</strong></p>
  963. <p>&#x6784;&#x9020;&#x51FD;&#x6570;&#x505A;&#x7684;&#x90FD;&#x662F;&#x521D;&#x59CB;&#x5316;&#x64CD;&#x4F5C;&#xFF0C;</p>
  964. <pre class="language-"><code>DBImpl::DBImpl(const Options&amp; options, const std::string&amp;dbname)
  965. </code></pre><p>&#x9996;&#x5148;&#x662F;&#x521D;&#x59CB;&#x5316;&#x5217;&#x8868;&#x4E2D;&#xFF0C;&#x76F4;&#x63A5;&#x6839;&#x636E;&#x53C2;&#x6570;&#x8D4B;&#x503C;&#xFF0C;&#x6216;&#x8005;&#x76F4;&#x63A5;&#x521D;&#x59CB;&#x5316;&#x3002;Comparator&#x548C;filter policy&#x90FD;&#x662F;&#x53C2;&#x6570;&#x4F20;&#x5165;&#x7684;&#x3002;&#x5728;&#x4F20;&#x9012;option&#x65F6;&#x4F1A;&#x9996;&#x5148;&#x5C06;option&#x4E2D;&#x7684;&#x53C2;&#x6570;&#x5408;&#x6CD5;&#x5316;&#xFF0C;<strong>logfile<em>number</em></strong>&#x521D;&#x59CB;&#x5316;&#x4E3A;0&#xFF0C;&#x6307;&#x9488;&#x521D;&#x59CB;&#x5316;&#x4E3A;NULL&#x3002;
  966. &#x521B;&#x5EFA;MemTable&#xFF0C;&#x5E76;&#x589E;&#x52A0;&#x5F15;&#x7528;&#x8BA1;&#x6570;&#xFF0C;&#x521B;&#x5EFA;WriteBatch&#x3002;</p>
  967. <pre class="language-"><code>1mem_(newMemTable(internal_comparator_)),
  968. 2tmp_batch_(new WriteBatch),
  969. 3mem_-&gt;Ref();
  970. 4// &#x7136;&#x540E;&#x5728;&#x51FD;&#x6570;&#x4F53;&#x4E2D;&#xFF0C;&#x521B;&#x5EFA;TableCache&#x548C;VersionSet&#x3002;
  971. 5// &#x4E3A;&#x5176;&#x4ED6;&#x9884;&#x7559;10&#x4E2A;&#x6587;&#x4EF6;&#xFF0C;&#x5176;&#x4F59;&#x7684;&#x90FD;&#x7ED9;TableCache.
  972. 6const int table_cache_size = options.max_open_files - 10;
  973. 7table_cache_ = newTableCache(dbname_, &amp;options_, table_cache_size);
  974. 8versions_ = newVersionSet(dbname_, &amp;options_, table_cache_, &amp;internal_comparator_);
  975. </code></pre><h3 id=""> </h3>
  976. <h3 id="123-dbimpnewdb"><a name="123-dbimpnewdb" class="anchor-navigation-ex-anchor" href="#123-dbimpnewdb"><i class="fa fa-link" aria-hidden="true"></i></a>12.3 DBImp::NewDB()</h3>
  977. <p>&#x5F53;&#x5916;&#x90E8;&#x5728;&#x8C03;&#x7528;DB::Open()&#x65F6;&#x8BBE;&#x7F6E;&#x4E86;option&#x6307;&#x5B9A;&#x5982;&#x679C;db&#x4E0D;&#x5B58;&#x5728;&#x5C31;&#x521B;&#x5EFA;&#xFF0C;&#x5982;&#x679C;db&#x4E0D;&#x5B58;&#x5728;leveldb&#x5C31;&#x4F1A;&#x8C03;&#x7528;&#x51FD;&#x6570;&#x521B;&#x5EFA;&#x65B0;&#x7684;db&#x3002;&#x5224;&#x65AD;db&#x662F;&#x5426;&#x5B58;&#x5728;&#x7684;&#x4F9D;&#x636E;&#x662F;<strong><db name="">/CURRENT</db></strong>&#x6587;&#x4EF6;&#x662F;&#x5426;&#x5B58;&#x5728;&#x3002;&#x5176;&#x903B;&#x8F91;&#x5F88;&#x7B80;&#x5355;&#x3002;</p>
  978. <pre class="language-"><code> 1// S1&#x9996;&#x5148;&#x751F;&#x4EA7;DB&#x5143;&#x4FE1;&#x606F;&#xFF0C;&#x8BBE;&#x7F6E;comparator&#x540D;&#xFF0C;&#x4EE5;&#x53CA;log&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#x3001;&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#xFF0C;&#x4EE5;&#x53CA;seq no&#x3002;
  979. 2VersionEdit new_db;
  980. 3new_db.SetComparatorName(user_comparator()-&gt;Name());
  981. 4new_db.SetLogNumber(0);
  982. 5new_db.SetNextFile(2);
  983. 6new_db.SetLastSequence(0);
  984. 7// S2 &#x751F;&#x4EA7;MANIFEST&#x6587;&#x4EF6;&#xFF0C;&#x5C06;db&#x5143;&#x4FE1;&#x606F;&#x5199;&#x5165;MANIFEST&#x6587;&#x4EF6;&#x3002;
  985. 8const std::string manifest = DescriptorFileName(dbname_, 1);
  986. 9WritableFile* file;
  987. 10Status s = env_-&gt;NewWritableFile(manifest, &amp;file);
  988. 11if (!s.ok()) return s;
  989. 12{
  990. 13 log::Writer log(file);
  991. 14 std::string record;
  992. 15 new_db.EncodeTo(&amp;record);
  993. 16 s = log.AddRecord(record);
  994. 17 if (s.ok()) s = file-&gt;Close();
  995. 18}
  996. 19delete file;
  997. 20// S3 &#x5982;&#x679C;&#x6210;&#x529F;&#xFF0C;&#x5C31;&#x628A;MANIFEST&#x6587;&#x4EF6;&#x540D;&#x5199;&#x5165;&#x5230;CURRENT&#x6587;&#x4EF6;&#x4E2D;
  998. 21if (s.ok()) s = SetCurrentFile(env_, dbname_, 1);
  999. 22elseenv_-&gt;DeleteFile(manifest);
  1000. 23return s;
  1001. </code></pre><p>&#x8FD9;&#x5C31;&#x662F;&#x521B;&#x5EFA;&#x65B0;DB&#x7684;&#x903B;&#x8F91;&#xFF0C;&#x5F88;&#x7B80;&#x5355;&#x3002;</p>
  1002. <p><strong>12.4 DBImpl::Recover()</strong></p>
  1003. <p>&#x51FD;&#x6570;&#x58F0;&#x660E;&#x4E3A;&#xFF1A;</p>
  1004. <pre class="language-"><code>StatusDBImpl::Recover(VersionEdit* edit)
  1005. </code></pre><p>&#x5982;&#x679C;&#x8C03;&#x7528;&#x6210;&#x529F;&#x5219;&#x8BBE;&#x7F6E;VersionEdit&#x3002;Recover&#x7684;&#x57FA;&#x672C;&#x529F;&#x80FD;&#x662F;&#xFF1A;&#x9996;&#x5148;&#x662F;&#x5904;&#x7406;&#x521B;&#x5EFA;flag&#xFF0C;&#x6BD4;&#x5982;&#x5B58;&#x5728;&#x5C31;&#x8FD4;&#x56DE;&#x5931;&#x8D25;&#x7B49;&#x7B49;&#xFF1B;&#x7136;&#x540E;&#x662F;&#x5C1D;&#x8BD5;&#x4ECE;&#x5DF2;&#x5B58;&#x5728;&#x7684;sstable&#x6587;&#x4EF6;&#x6062;&#x590D;db&#xFF1B;&#x6700;&#x540E;&#x5982;&#x679C;&#x53D1;&#x73B0;&#x6709;&#x5927;&#x4E8E;&#x539F;&#x4FE1;&#x606F;&#x8BB0;&#x5F55;&#x7684;log&#x7F16;&#x53F7;&#x7684;log&#x6587;&#x4EF6;&#xFF0C;&#x5219;&#x9700;&#x8981;&#x56DE;&#x653E;log&#xFF0C;&#x66F4;&#x65B0;db&#x6570;&#x636E;&#x3002;&#x56DE;&#x653E;&#x671F;&#x95F4;db&#x53EF;&#x80FD;&#x4F1A;dump&#x65B0;&#x7684;level 0&#x6587;&#x4EF6;&#xFF0C;&#x56E0;&#x6B64;&#x9700;&#x8981;&#x628A;db&#x5143;&#x4FE1;&#x606F;&#x7684;&#x53D8;&#x52A8;&#x8BB0;&#x5F55;&#x5230;edit&#x4E2D;&#x8FD4;&#x56DE;&#x3002;&#x51FD;&#x6570;&#x903B;&#x8F91;&#x5982;&#x4E0B;&#xFF1A;</p>
  1006. <p>S1 &#x521B;&#x5EFA;&#x76EE;&#x5F55;&#xFF0C;&#x76EE;&#x5F55;&#x4EE5;db name&#x547D;&#x540D;&#xFF0C;&#x5FFD;&#x7565;&#x4EFB;&#x4F55;&#x521B;&#x5EFA;&#x9519;&#x8BEF;&#xFF0C;&#x7136;&#x540E;&#x5C1D;&#x8BD5;&#x83B7;&#x53D6;d<strong>b name/LOCK</strong>&#x6587;&#x4EF6;&#x9501;&#xFF0C;&#x5931;&#x8D25;&#x5219;&#x8FD4;&#x56DE;&#x3002;</p>
  1007. <pre class="language-"><code>1env_-&gt;CreateDir(dbname_);
  1008. 2Status s = env_-&gt;LockFile(LockFileName(dbname_), &amp;db_lock_);
  1009. 3if (!s.ok()) return s;
  1010. </code></pre><p>S2 &#x6839;&#x636E;CURRENT&#x6587;&#x4EF6;&#x662F;&#x5426;&#x5B58;&#x5728;&#xFF0C;&#x4EE5;&#x53CA;option&#x53C2;&#x6570;&#x6267;&#x884C;&#x68C0;&#x67E5;&#x3002;
  1011. &#x5982;&#x679C;&#x6587;&#x4EF6;&#x4E0D;&#x5B58;&#x5728;<strong>&amp;create_is_missing=true</strong>&#xFF0C;&#x5219;&#x8C03;&#x7528;&#x51FD;&#x6570;NewDB()&#x521B;&#x5EFA;&#xFF1B;&#x5426;&#x5219;&#x62A5;&#x9519;&#x3002;
  1012. &#x5982;&#x679C;&#x6587;&#x4EF6;&#x5B58;&#x5728;&amp; error_if_exists=true&#xFF0C;&#x5219;&#x62A5;&#x9519;&#x3002;
  1013. S3 &#x8C03;&#x7528;VersionSet&#x7684;<strong>Recover()</strong>&#x51FD;&#x6570;&#xFF0C;&#x5C31;&#x662F;&#x4ECE;&#x6587;&#x4EF6;&#x4E2D;&#x6062;&#x590D;&#x6570;&#x636E;&#x3002;&#x5982;&#x679C;&#x51FA;&#x9519;&#x5219;&#x6253;&#x5F00;&#x5931;&#x8D25;&#xFF0C;&#x6210;&#x529F;&#x5219;&#x5411;&#x4E0B;&#x6267;&#x884C;S4&#x3002;</p>
  1014. <pre class="language-"><code>s = versions_-&gt;Recover();
  1015. </code></pre><p>S4&#x5C1D;&#x8BD5;&#x4ECE;&#x6240;&#x6709;&#x6BD4;manifest&#x6587;&#x4EF6;&#x4E2D;&#x8BB0;&#x5F55;&#x7684;log&#x8981;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#x4E2D;&#x6062;&#x590D;&#xFF08;&#x524D;&#x4E00;&#x4E2A;&#x7248;&#x672C;&#x53EF;&#x80FD;&#x4F1A;&#x6DFB;&#x52A0;&#x65B0;&#x7684;log&#x6587;&#x4EF6;&#xFF0C;&#x5374;&#x6CA1;&#x6709;&#x8BB0;&#x5F55;&#x5728;manifest&#x4E2D;&#xFF09;&#x3002;&#x53E6;&#x5916;&#xFF0C;&#x51FD;&#x6570;PrevLogNumber()&#x5DF2;&#x7ECF;&#x4E0D;&#x518D;&#x7528;&#x4E86;&#xFF0C;&#x4EC5;&#x4E3A;&#x4E86;&#x517C;&#x5BB9;&#x8001;&#x7248;&#x672C;&#x3002;</p>
  1016. <pre class="language-"><code> 1// S4.1 &#x8FD9;&#x91CC;&#x5148;&#x627E;&#x51FA;&#x6240;&#x6709;&#x6EE1;&#x8DB3;&#x6761;&#x4EF6;&#x7684;log&#x6587;&#x4EF6;&#xFF1A;&#x6BD4;manifest&#x6587;&#x4EF6;&#x8BB0;&#x5F55;&#x7684;log&#x7F16;&#x53F7;&#x66F4;&#x65B0;&#x3002;
  1017. 2SequenceNumber max_sequence(0);
  1018. 3const uint64_t min_log = versions_-&gt;LogNumber();
  1019. 4const uint64_t prev_log = versions_-&gt;PrevLogNumber();
  1020. 5std::vector<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span><span class="token namespace">std:</span>:string</span><span class="token punctuation">&gt;</span></span>filenames;
  1021. 6s = env_-&gt;GetChildren(dbname_, &amp;filenames); // &#x5217;&#x51FA;&#x76EE;&#x5F55;&#x5185;&#x7684;&#x6240;&#x6709;&#x6587;&#x4EF6;
  1022. 7uint64_t number;
  1023. 8FileType type;
  1024. 9std::vector<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>uint64_t</span><span class="token punctuation">&gt;</span></span>logs;
  1025. 10for (size_t i = 0; i &lt; filenames.size(); i++) { // &#x68C0;&#x67E5;log&#x6587;&#x4EF6;&#x662F;&#x5426;&#x6BD4;min log&#x66F4;&#x65B0;
  1026. 11 if (ParseFileName(filenames[i], &amp;number, &amp;type) &amp;&amp; type == kLogFile
  1027. 12 &amp;&amp; ((number &gt;= min_log) || (number == prev_log))) {
  1028. 13 logs.push_back(number);
  1029. 14 }
  1030. 15}
  1031. 16// S4.2 &#x627E;&#x5230;log&#x6587;&#x4EF6;&#x540E;&#xFF0C;&#x9996;&#x5148;&#x6392;&#x5E8F;&#xFF0C;&#x4FDD;&#x8BC1;&#x6309;&#x7167;&#x751F;&#x6210;&#x987A;&#x5E8F;&#xFF0C;&#x4F9D;&#x6B21;&#x56DE;&#x653E;log&#x3002;&#x5E76;&#x628A;DB&#x5143;&#x4FE1;&#x606F;&#x7684;&#x53D8;&#x52A8;&#xFF08;sstable&#x6587;&#x4EF6;&#x7684;&#x53D8;&#x52A8;&#xFF09;&#x8FFD;&#x52A0;&#x5230;edit&#x4E2D;&#x8FD4;&#x56DE;&#x3002;
  1032. 17std::sort(logs.begin(), logs.end());
  1033. 18for (size_t i = 0; i &lt; logs.size(); i++) {
  1034. 19 s = RecoverLogFile(logs[i], edit, &amp;max_sequence);
  1035. 20 // &#x524D;&#x4E00;&#x7248;&#x53EF;&#x80FD;&#x5728;&#x751F;&#x6210;&#x8BE5;log&#x7F16;&#x53F7;&#x540E;&#x6CA1;&#x6709;&#x8BB0;&#x5F55;&#x5728;MANIFEST&#x4E2D;&#xFF0C;
  1036. 21 //&#x6240;&#x4EE5;&#x8FD9;&#x91CC;&#x6211;&#x4EEC;&#x624B;&#x52A8;&#x66F4;&#x65B0;VersionSet&#x4E2D;&#x7684;&#x6587;&#x4EF6;&#x7F16;&#x53F7;&#x8BA1;&#x6570;&#x5668;
  1037. 22 versions_-&gt;MarkFileNumberUsed(logs[i]);
  1038. 23}
  1039. 24// S4.3 &#x66F4;&#x65B0;VersionSet&#x7684;sequence
  1040. 25if (s.ok()) {
  1041. 26 if (versions_-&gt;LastSequence() &lt; max_sequence)
  1042. 27 versions_-&gt;SetLastSequence(max_sequence);
  1043. 28}
  1044. </code></pre><p>&#x4E0A;&#x9762;&#x5C31;&#x662F;Recover&#x7684;&#x6267;&#x884C;&#x6D41;&#x7A0B;&#x3002;</p>
  1045. <h3 id="125-dbimpldeleteobsoletefiles"><a name="125-dbimpldeleteobsoletefiles" class="anchor-navigation-ex-anchor" href="#125-dbimpldeleteobsoletefiles"><i class="fa fa-link" aria-hidden="true"></i></a>12.5 DBImpl::DeleteObsoleteFiles()</h3>
  1046. <p>&#x8FD9;&#x4E2A;&#x662F;&#x5783;&#x573E;&#x56DE;&#x6536;&#x51FD;&#x6570;&#xFF0C;&#x5982;&#x524D;&#x6240;&#x8FF0;&#xFF0C;&#x6BCF;&#x6B21;compaction&#x548C;recovery&#x4E4B;&#x540E;&#x90FD;&#x4F1A;&#x6709;&#x6587;&#x4EF6;&#x88AB;&#x5E9F;&#x5F03;&#x3002;DeleteObsoleteFiles&#x5C31;&#x662F;&#x5220;&#x9664;&#x8FD9;&#x4E9B;&#x5783;&#x573E;&#x6587;&#x4EF6;&#x7684;&#xFF0C;&#x5B83;&#x5728;&#x6BCF;&#x6B21;compaction&#x548C;recovery&#x5B8C;&#x6210;&#x4E4B;&#x540E;&#x88AB;&#x8C03;&#x7528;&#x3002;
  1047. &#x5176;&#x8C03;&#x7528;&#x70B9;&#x5305;&#x62EC;&#xFF1A;<strong>DBImpl::CompactMemTable,DBImpl::BackgroundCompaction,</strong> &#x4EE5;&#x53CA;DB::Open&#x7684;<strong>recovery</strong>&#x6B65;&#x9AA4;&#x4E4B;&#x540E;&#x3002;
  1048. &#x5B83;&#x4F1A;&#x5220;&#x9664;&#x6240;&#x6709;&#x8FC7;&#x671F;&#x7684;log&#x6587;&#x4EF6;&#xFF0C;&#x6CA1;&#x6709;&#x88AB;&#x4EFB;&#x4F55;level&#x5F15;&#x7528;&#x5230;&#x3001;&#x6216;&#x4E0D;&#x662F;&#x6B63;&#x5728;&#x6267;&#x884C;&#x7684;compaction&#x7684;output&#x7684;sstable&#x6587;&#x4EF6;&#x3002;
  1049. &#x8BE5;&#x51FD;&#x6570;&#x6CA1;&#x6709;&#x53C2;&#x6570;&#xFF0C;&#x5176;&#x4EE3;&#x7801;&#x903B;&#x8F91;&#x4E5F;&#x5F88;&#x76F4;&#x89C2;&#xFF0C;&#x5C31;&#x662F;&#x5217;&#x51FA;db&#x7684;&#x6240;&#x6709;&#x6587;&#x4EF6;&#xFF0C;&#x5BF9;&#x4E0D;&#x540C;&#x7C7B;&#x578B;&#x7684;&#x6587;&#x4EF6;&#x5206;&#x522B;&#x5224;&#x65AD;&#xFF0C;&#x5982;&#x679C;&#x662F;&#x8FC7;&#x671F;&#x6587;&#x4EF6;&#xFF0C;&#x5C31;&#x5220;&#x9664;&#x4E4B;&#xFF0C;&#x5982;&#x4E0B;&#xFF1A;</p>
  1050. <pre class="language-"><code> 1// S1 &#x9996;&#x5148;&#xFF0C;&#x786E;&#x4FDD;&#x4E0D;&#x4F1A;&#x5220;&#x9664;pending&#x6587;&#x4EF6;&#xFF0C;&#x5C06;versionset&#x6B63;&#x5728;&#x4F7F;&#x7528;&#x7684;&#x6240;&#x6709;&#x6587;&#x4EF6;&#x52A0;&#x5165;&#x5230;live&#x4E2D;&#x3002;
  1051. 2std::set<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>uint64_t</span><span class="token punctuation">&gt;</span></span> live = pending_outputs_;
  1052. 3versions_-&gt;AddLiveFiles(&amp;live); //&#x8BE5;&#x51FD;&#x6570;&#x5176;&#x540E;&#x5206;&#x6790;
  1053. 4 // S2 &#x5217;&#x4E3E;db&#x7684;&#x6240;&#x6709;&#x6587;&#x4EF6;
  1054. 5std::vector<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span><span class="token namespace">std:</span>:string</span><span class="token punctuation">&gt;</span></span>filenames;
  1055. 6env_-&gt;GetChildren(dbname_, &amp;filenames);
  1056. 7// S3 &#x904D;&#x5386;&#x6240;&#x6709;&#x5217;&#x4E3E;&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x6839;&#x636E;&#x6587;&#x4EF6;&#x7C7B;&#x578B;&#xFF0C;&#x5206;&#x522B;&#x5904;&#x7406;&#xFF1B;
  1057. 8uint64_t number;
  1058. 9FileType type;
  1059. 10for (size_t i = 0; i &lt; filenames.size(); i++) {
  1060. 11 if (ParseFileName(filenames[i], &amp;number, &amp;type)) {
  1061. 12 bool keep = true; //false&#x8868;&#x660E;&#x662F;&#x8FC7;&#x671F;&#x6587;&#x4EF6;
  1062. 13 // S3.1 kLogFile&#xFF0C;log&#x6587;&#x4EF6;&#xFF0C;&#x6839;&#x636E;log&#x7F16;&#x53F7;&#x5224;&#x65AD;&#x662F;&#x5426;&#x8FC7;&#x671F;
  1063. 14 keep = ((number &gt;= versions_-&gt;LogNumber()) ||
  1064. 15 (number == versions_-&gt;PrevLogNumber()));
  1065. 16 // S3.2 kDescriptorFile&#xFF0C;MANIFEST&#x6587;&#x4EF6;&#xFF0C;&#x6839;&#x636E;versionset&#x8BB0;&#x5F55;&#x7684;&#x7F16;&#x53F7;&#x5224;&#x65AD;
  1066. 17 keep = (number &gt;= versions_-&gt;ManifestFileNumber());
  1067. 18 // S3.3 kTableFile&#xFF0C;sstable&#x6587;&#x4EF6;&#xFF0C;&#x53EA;&#x8981;&#x5728;live&#x4E2D;&#x5C31;&#x4E0D;&#x80FD;&#x5220;&#x9664;
  1068. 19 // S3.4 kTempFile&#xFF0C;&#x5982;&#x679C;&#x662F;&#x6B63;&#x5728;&#x5199;&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x53EA;&#x8981;&#x5728;live&#x4E2D;&#x5C31;&#x4E0D;&#x80FD;&#x5220;&#x9664;
  1069. 20 keep = (live.find(number) != live.end());
  1070. 21 // S3.5 kCurrentFile,kDBLockFile, kInfoLogFile&#xFF0C;&#x4E0D;&#x80FD;&#x5220;&#x9664;
  1071. 22 keep = true;
  1072. 23 // S3.6 &#x5982;&#x679C;keep&#x4E3A;false&#xFF0C;&#x8868;&#x660E;&#x9700;&#x8981;&#x5220;&#x9664;&#x6587;&#x4EF6;&#xFF0C;&#x5982;&#x679C;&#x662F;table&#x8FD8;&#x8981;&#x4ECE;cache&#x4E2D;&#x5220;&#x9664;
  1073. 24 if (!keep) {
  1074. 25 if (type == kTableFile) table_cache_-&gt;Evict(number);
  1075. 26 Log(options_.info_log, &quot;Delete type=%d #%lld\n&quot;, type, number);
  1076. 27 env_-&gt;DeleteFile(dbname_ + &quot;/&quot; + filenames[i]);
  1077. 28 }
  1078. 29 }
  1079. 30}
  1080. </code></pre><p>&#x8FD9;&#x5C31;&#x662F;&#x5220;&#x9664;&#x8FC7;&#x671F;&#x6587;&#x4EF6;&#x7684;&#x903B;&#x8F91;&#xFF0C;&#x5176;&#x4E2D;&#x8C03;&#x7528;&#x5230;&#x4E86;<strong>VersionSet::AddLiveFiles</strong>&#x51FD;&#x6570;&#xFF0C;&#x4FDD;&#x8BC1;&#x4E0D;&#x4F1A;&#x5220;&#x9664;active&#x7684;&#x6587;&#x4EF6;&#x3002;</p>
  1081. <p>&#x51FD;&#x6570;DbImpl::MaybeScheduleCompaction()&#x653E;&#x5728;Compaction&#x4E00;&#x8282;&#x5206;&#x6790;&#xFF0C;&#x57FA;&#x672C;&#x903B;&#x8F91;&#x5C31;&#x662F;&#x5982;&#x679C;&#x9700;&#x8981;compaction&#xFF0C;&#x5C31;&#x542F;&#x52A8;&#x540E;&#x53F0;&#x7EBF;&#x7A0B;&#x6267;&#x884C;compaction&#x64CD;&#x4F5C;&#x3002;</p>
  1082. <h3 id="126-dbimplrecoverlogfile"><a name="126-dbimplrecoverlogfile" class="anchor-navigation-ex-anchor" href="#126-dbimplrecoverlogfile"><i class="fa fa-link" aria-hidden="true"></i></a>12.6 DBImpl::RecoverLogFile()</h3>
  1083. <p>&#x51FD;&#x6570;&#x58F0;&#x660E;&#xFF1A;</p>
  1084. <pre class="language-"><code>StatusRecoverLogFile(uint64_t log_number, VersionEdit* edit,SequenceNumber* max_sequence)
  1085. </code></pre><p>&#x53C2;&#x6570;&#x8BF4;&#x660E;&#xFF1A;
  1086. @log_number&#x662F;&#x6307;&#x5B9A;&#x7684;log&#x6587;&#x4EF6;&#x7F16;&#x53F7;
  1087. @edit&#x8BB0;&#x5F55;db&#x5143;&#x4FE1;&#x606F;&#x7684;&#x53D8;&#x5316;&#x2014;&#x2014;sstable&#x6587;&#x4EF6;&#x53D8;&#x52A8;
  1088. @max_sequence &#x8FD4;&#x56DE;max{log&#x8BB0;&#x5F55;&#x7684;&#x6700;&#x5927;&#x5E8F;&#x53F7;, *max_sequence}
  1089. &#x8BE5;&#x51FD;&#x6570;&#x6253;&#x5F00;&#x6307;&#x5B9A;&#x7684;log&#x6587;&#x4EF6;&#xFF0C;&#x56DE;&#x653E;&#x65E5;&#x5FD7;&#x3002;&#x671F;&#x95F4;&#x53EF;&#x80FD;&#x4F1A;&#x6267;&#x884C;compaction&#xFF0C;&#x751F;&#x4EA7;&#x65B0;&#x7684;level 0sstable&#x6587;&#x4EF6;&#xFF0C;&#x8BB0;&#x5F55;&#x6587;&#x4EF6;&#x53D8;&#x52A8;&#x5230;edit&#x4E2D;&#x3002;
  1090. &#x5B83;&#x58F0;&#x660E;&#x4E86;&#x4E00;&#x4E2A;&#x5C40;&#x90E8;&#x7C7B;LogReporter&#x4EE5;&#x6253;&#x5370;&#x9519;&#x8BEF;&#x65E5;&#x5FD7;&#xFF0C;&#x6CA1;&#x4EC0;&#x4E48;&#x597D;&#x8BF4;&#x7684;&#xFF0C;&#x4E0B;&#x9762;&#x6765;&#x770B;&#x4EE3;&#x7801;&#x903B;&#x8F91;&#x3002;</p>
  1091. <pre class="language-"><code> 1// S1 &#x6253;&#x5F00;log&#x6587;&#x4EF6;&#x8FD4;&#x56DE;SequentialFile*file&#xFF0C;&#x51FA;&#x9519;&#x5C31;&#x8FD4;&#x56DE;&#xFF0C;&#x5426;&#x5219;&#x5411;&#x4E0B;&#x6267;&#x884C;S2&#x3002;
  1092. 2// S2 &#x6839;&#x636E;log&#x6587;&#x4EF6;&#x53E5;&#x67C4;file&#x521B;&#x5EFA;log::Reader&#xFF0C;&#x51C6;&#x5907;&#x8BFB;&#x53D6;log&#x3002;
  1093. 3log::Reader reader(file, &amp;reporter, true/*checksum*/, 0/*initial_offset*/);
  1094. 4// S3 &#x4F9D;&#x6B21;&#x8BFB;&#x53D6;&#x6240;&#x6709;&#x7684;log&#x8BB0;&#x5F55;&#xFF0C;&#x5E76;&#x63D2;&#x5165;&#x5230;&#x65B0;&#x751F;&#x6210;&#x7684;memtable&#x4E2D;&#x3002;&#x8FD9;&#x91CC;&#x4F7F;&#x7528;&#x5230;&#x4E86;&#x6279;&#x91CF;&#x66F4;&#x65B0;&#x63A5;&#x53E3;WriteBatch&#xFF0C;&#x5177;&#x4F53;&#x540E;&#x9762;&#x518D;&#x5206;&#x6790;&#x3002;
  1095. 5std::string scratch;
  1096. 6Slice record;
  1097. 7WriteBatch batch;
  1098. 8MemTable* mem = NULL;
  1099. 9while (reader.ReadRecord(&amp;record, &amp;scratch) &amp;&amp; status.ok()) { // &#x8BFB;&#x53D6;&#x5168;&#x90E8;log
  1100. 10 if (record.size() &lt; 12) { // log&#x6570;&#x636E;&#x9519;&#x8BEF;&#xFF0C;&#x4E0D;&#x6EE1;&#x8DB3;&#x6700;&#x5C0F;&#x957F;&#x5EA6;12
  1101. 11 reporter.Corruption(record.size(), Status::Corruption(&quot;log recordtoo small&quot;));
  1102. 12 continue;
  1103. 13 }
  1104. 14 WriteBatchInternal::SetContents(&amp;batch, record); // log&#x5185;&#x5BB9;&#x8BBE;&#x7F6E;&#x5230;WriteBatch&#x4E2D;
  1105. 15 if (mem == NULL) { // &#x521B;&#x5EFA;memtable
  1106. 16 mem = new MemTable(internal_comparator_);
  1107. 17 mem-&gt;Ref();
  1108. 18 }
  1109. 19 status = WriteBatchInternal::InsertInto(&amp;batch, mem); // &#x63D2;&#x5165;&#x5230;memtable&#x4E2D;
  1110. 20 MaybeIgnoreError(&amp;status);
  1111. 21 if (!status.ok()) break;
  1112. 22 const SequenceNumber last_seq =
  1113. 23 WriteBatchInternal::Sequence(&amp;batch) + WriteBatchInternal::Count(&amp;batch) - 1;
  1114. 24 if (last_seq &gt; *max_sequence) *max_sequence = last_seq; // &#x66F4;&#x65B0;max sequence
  1115. 25 // &#x5982;&#x679C;mem&#x7684;&#x5185;&#x5B58;&#x8D85;&#x8FC7;&#x8BBE;&#x7F6E;&#x503C;&#xFF0C;&#x5219;&#x6267;&#x884C;compaction&#xFF0C;&#x5982;&#x679C;compaction&#x51FA;&#x9519;&#xFF0C;
  1116. 26 // &#x7ACB;&#x523B;&#x8FD4;&#x56DE;&#x9519;&#x8BEF;&#xFF0C;DB::Open&#x5931;&#x8D25;
  1117. 27 if (mem-&gt;ApproximateMemoryUsage() &gt; options_.write_buffer_size) {
  1118. 28 status = WriteLevel0Table(mem, edit, NULL);
  1119. 29 if (!status.ok()) break;
  1120. 30 mem-&gt;Unref(); // &#x91CA;&#x653E;&#x5F53;&#x524D;memtable
  1121. 31 mem = NULL;
  1122. 32 }
  1123. 33}
  1124. 34// S4 &#x626B;&#x5C3E;&#x5DE5;&#x4F5C;&#xFF0C;&#x5982;&#x679C;mem != NULL&#xFF0C;&#x8BF4;&#x660E;&#x8FD8;&#x9700;&#x8981;dump&#x5230;&#x65B0;&#x7684;sstable&#x6587;&#x4EF6;&#x4E2D;&#x3002;
  1125. 35if (status.ok() &amp;&amp; mem != NULL) {// &#x5982;&#x679C;compaction&#x51FA;&#x9519;&#xFF0C;&#x7ACB;&#x523B;&#x8FD4;&#x56DE;&#x9519;&#x8BEF;
  1126. 36 status = WriteLevel0Table(mem, edit, NULL);
  1127. 37}
  1128. 38if (mem != NULL)mem-&gt;Unref();
  1129. 39delete file;
  1130. 40return status;
  1131. </code></pre><p>&#x628A;MemTabledump&#x5230;sstable&#x662F;&#x51FD;&#x6570;WriteLevel0Table&#x7684;&#x5DE5;&#x4F5C;&#xFF0C;&#x5176;&#x5B9E;&#x8FD9;&#x662F;compaction&#x7684;&#x4E00;&#x90E8;&#x5206;&#xFF0C;&#x51C6;&#x5907;&#x653E;&#x5728;compaction&#x4E00;&#x8282;&#x6765;&#x5206;&#x6790;&#x3002;</p>
  1132. <p><strong>12.7 &#x5C0F;&#x7ED3;</strong></p>
  1133. <p>&#x5982;&#x4E0A;DB&#x6253;&#x5F00;&#x7684;&#x903B;&#x8F91;&#x5C31;&#x5DF2;&#x7ECF;&#x5206;&#x6790;&#x5B8C;&#x4E86;&#xFF0C;&#x6253;&#x5F00;&#x903B;&#x8F91;&#x53C2;&#x89C1;DB::Open()&#x4E2D;&#x63CF;&#x8FF0;&#x7684;5&#x4E2A;&#x6B65;&#x9AA4;&#x3002;&#x6B64;&#x5916;&#x8FD8;&#x6709;&#x4E24;&#x4E2A;&#x4E1C;&#x4E1C;&#xFF1A;&#x628A;Memtable dump&#x5230;sstable&#x7684;WriteLevel0Table()&#x51FD;&#x6570;&#xFF0C;&#x4EE5;&#x53CA;&#x6279;&#x91CF;&#x4FEE;&#x6539;WriteBatch&#x3002;&#x7B2C;&#x4E00;&#x4E2A;&#x653E;&#x5728;&#x540E;&#x9762;&#x7684;compaction&#x4E00;&#x8282;&#xFF0C;&#x7B2C;&#x4E8C;&#x4E2A;&#x653E;&#x5728;DB&#x66F4;&#x65B0;&#x64CD;&#x4F5C;&#x4E2D;&#x3002;&#x63A5;&#x4E0B;&#x6765;&#x5C31;&#x662F;db&#x7684;&#x5173;&#x95ED;&#x3002;</p>
  1134. <h2 id="_1"><a name="_1" class="anchor-navigation-ex-anchor" href="#_1"><i class="fa fa-link" aria-hidden="true"></i></a> </h2>
  1135. <h3 id="13-db&#x7684;&#x5173;&#x95ED;&#x9500;&#x6BC1;"><a name="13-db&#x7684;&#x5173;&#x95ED;&#x9500;&#x6BC1;" class="anchor-navigation-ex-anchor" href="#13-db&#x7684;&#x5173;&#x95ED;&#x9500;&#x6BC1;"><i class="fa fa-link" aria-hidden="true"></i></a>13 DB&#x7684;&#x5173;&#x95ED;&amp;&#x9500;&#x6BC1;</h3>
  1136. <h3 id="131-db&#x5173;&#x95ED;"><a name="131-db&#x5173;&#x95ED;" class="anchor-navigation-ex-anchor" href="#131-db&#x5173;&#x95ED;"><i class="fa fa-link" aria-hidden="true"></i></a>13.1 DB&#x5173;&#x95ED;</h3>
  1137. <p>&#x5916;&#x90E8;&#x8C03;&#x7528;&#x8005;&#x901A;&#x8FC7;DB::Open()&#x83B7;&#x53D6;&#x4E00;&#x4E2A;DB<em>&#x5BF9;&#x8C61;&#xFF0C;&#x5982;&#x679C;&#x8981;&#x5173;&#x95ED;&#x6253;&#x5F00;&#x7684;DB</em>db&#x5BF9;&#x8C61;&#xFF0C;&#x5219;&#x76F4;&#x63A5;delete db&#x5373;&#x53EF;&#xFF0C;&#x8FD9;&#x4F1A;&#x8C03;&#x7528;&#x5230;DBImpl&#x7684;&#x6790;&#x6784;&#x51FD;&#x6570;&#x3002;
  1138. &#x6790;&#x6784;&#x4F9D;&#x6B21;&#x6267;&#x884C;&#x5982;&#x4E0B;&#x7684;5&#x4E2A;&#x903B;&#x8F91;&#xFF1A;
  1139. S1 &#x7B49;&#x5F85;&#x540E;&#x53F0;compaction&#x4EFB;&#x52A1;&#x7ED3;&#x675F;
  1140. S2 &#x91CA;&#x653E;db&#x6587;&#x4EF6;&#x9501;&#xFF0C;<dbname>/lock&#x6587;&#x4EF6;
  1141. S3 &#x5220;&#x9664;VersionSet&#x5BF9;&#x8C61;&#xFF0C;&#x5E76;&#x91CA;&#x653E;MemTable&#x5BF9;&#x8C61;
  1142. S4 &#x5220;&#x9664;log&#x76F8;&#x5173;&#x4EE5;&#x53CA;TableCache&#x5BF9;&#x8C61;
  1143. S5 &#x5220;&#x9664;options&#x7684;block_cache&#x4EE5;&#x53CA;info_log&#x5BF9;&#x8C61;</dbname></p>
  1144. <h3 id="132-db&#x9500;&#x6BC1;"><a name="132-db&#x9500;&#x6BC1;" class="anchor-navigation-ex-anchor" href="#132-db&#x9500;&#x6BC1;"><i class="fa fa-link" aria-hidden="true"></i></a>13.2 DB&#x9500;&#x6BC1;</h3>
  1145. <p>&#x51FD;&#x6570;&#x58F0;&#x660E;&#xFF1A;</p>
  1146. <pre class="language-"><code>StatusDestroyDB(const std::string&amp; dbname, const Options&amp; options)
  1147. </code></pre><p>&#x8BE5;&#x51FD;&#x6570;&#x4F1A;&#x5220;&#x9664;&#x6389;db&#x7684;&#x6570;&#x636E;&#x5185;&#x5BB9;&#xFF0C;&#x8981;&#x8C28;&#x614E;&#x4F7F;&#x7528;&#x3002;&#x51FD;&#x6570;&#x903B;&#x8F91;&#x4E3A;&#xFF1A;
  1148. S1 &#x83B7;&#x53D6;dbname&#x76EE;&#x5F55;&#x7684;&#x6587;&#x4EF6;&#x5217;&#x8868;&#x5230;filenames&#x4E2D;&#xFF0C;&#x5982;&#x679C;&#x4E3A;&#x7A7A;&#x5219;&#x76F4;&#x63A5;&#x8FD4;&#x56DE;&#xFF0C;&#x5426;&#x5219;&#x8FDB;&#x5165;S2&#x3002;
  1149. S2 &#x9501;&#x6587;&#x4EF6;<dbname>/lock&#xFF0C;&#x5982;&#x679C;&#x9501;&#x6210;&#x529F;&#x5C31;&#x6267;&#x884C;S3
  1150. S3 &#x904D;&#x5386;filenames&#x6587;&#x4EF6;&#x5217;&#x8868;&#xFF0C;&#x8FC7;&#x6EE4;&#x6389;lock&#x6587;&#x4EF6;&#xFF0C;&#x4F9D;&#x6B21;&#x8C03;&#x7528;DeleteFile&#x5220;&#x9664;&#x3002;
  1151. S4 &#x91CA;&#x653E;lock&#x6587;&#x4EF6;&#xFF0C;&#x5E76;&#x5220;&#x9664;&#x4E4B;&#xFF0C;&#x7136;&#x540E;&#x5220;&#x9664;&#x6587;&#x4EF6;&#x5939;&#x3002;
  1152. Destory&#x5C31;&#x6267;&#x884C;&#x5B8C;&#x4E86;&#xFF0C;&#x5982;&#x679C;&#x5220;&#x9664;&#x6587;&#x4EF6;&#x51FA;&#x73B0;&#x9519;&#x8BEF;&#xFF0C;&#x8BB0;&#x5F55;&#x4E4B;&#xFF0C;&#x4F9D;&#x7136;&#x7EE7;&#x7EED;&#x5220;&#x9664;&#x4E0B;&#x4E00;&#x4E2A;&#x3002;&#x6700;&#x540E;&#x8FD4;&#x56DE;&#x9519;&#x8BEF;&#x4EE3;&#x7801;&#x3002;
  1153. &#x770B;&#x6765;&#x8FD9;&#x4E00;&#x7AE0;&#x5F88;&#x77ED;&#x5C0F;&#x3002;DB&#x7684;&#x6253;&#x5F00;&#x5173;&#x95ED;&#x5206;&#x6790;&#x5B8C;&#x6BD5;&#x3002; </dbname></p>
  1154. <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;
  1155. 2020-09-13 18:56:48
  1156. </span></footer>
  1157. <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>
  1158. </section>
  1159. </div>
  1160. <div class="search-results">
  1161. <div class="has-results">
  1162. <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
  1163. <ul class="search-results-list"></ul>
  1164. </div>
  1165. <div class="no-results">
  1166. <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
  1167. </div>
  1168. </div>
  1169. </div>
  1170. </div>
  1171. </div>
  1172. </div>
  1173. <a href="leveldb源码分析19.html" class="navigation navigation-prev " aria-label="Previous page: leveldb源码分析19">
  1174. <i class="fa fa-angle-left"></i>
  1175. </a>
  1176. <a href="leveldb源码分析21.html" class="navigation navigation-next " aria-label="Next page: leveldb源码分析21">
  1177. <i class="fa fa-angle-right"></i>
  1178. </a>
  1179. </div>
  1180. <script>
  1181. var gitbook = gitbook || [];
  1182. gitbook.push(function() {
  1183. gitbook.page.hasChanged({"page":{"title":"leveldb源码分析20","level":"7.2.20","depth":2,"next":{"title":"leveldb源码分析21","level":"7.2.21","depth":2,"path":"articles/leveldb源码分析/leveldb源码分析21.md","ref":"articles/leveldb源码分析/leveldb源码分析21.md","articles":[]},"previous":{"title":"leveldb源码分析19","level":"7.2.19","depth":2,"path":"articles/leveldb源码分析/leveldb源码分析19.md","ref":"articles/leveldb源码分析/leveldb源码分析19.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/leveldb源码分析/leveldb源码分析20.md","mtime":"2020-09-13T10:56:48.829Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2020-10-09T15:31:57.905Z"},"basePath":"../..","book":{"language":""}});
  1184. });
  1185. </script>
  1186. </div>
  1187. <script src="../../gitbook/gitbook.js"></script>
  1188. <script src="../../gitbook/theme.js"></script>
  1189. <script src="../../gitbook/gitbook-plugin-chapter-fold/chapter-fold.js"></script>
  1190. <script src="../../gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
  1191. <script src="../../gitbook/gitbook-plugin-search-pro/search.js"></script>
  1192. <script src="../../gitbook/gitbook-plugin-splitter/splitter.js"></script>
  1193. <script src="../../gitbook/gitbook-plugin-back-to-top-button/plugin.js"></script>
  1194. <script src="../../gitbook/gitbook-plugin-hide-element/plugin.js"></script>
  1195. <script src="../../gitbook/gitbook-plugin-code/plugin.js"></script>
  1196. <script src="../../gitbook/gitbook-plugin-livereload/plugin.js"></script>
  1197. <script src="../../gitbook/gitbook-plugin-sharing/buttons.js"></script>
  1198. <script src="../../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
  1199. <script src="../../gitbook/gitbook-plugin-theme-fexa/fexa.js"></script>
  1200. </body>
  1201. </html>