blob: f8a4c84d8c4c0e620e4bebc55fa724e19fba1e7a [file] [log] [blame]
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title> </title>
<meta name="generator" content="VuePress 1.5.2">
<link rel="icon" href="/favicon.ico">
<meta name="description" content=" ">
<meta name="Description" content="Apache IoTDB: Time Series Database for IoT">
<meta name="Keywords" content="TSDB, time series, time series database, IoTDB, IoT database, IoT data management,时序数据库, 时间序列管理, IoTDB, 物联网数据库, 实时数据库, 物联网数据管理, 物联网数据">
<meta name="baidu-site-verification" content="wfKETzB3OT">
<meta name="google-site-verification" content="mZWAoRY0yj_HAr-s47zHCGHzx5Ju-RVm5wDbPnwQYFo">
<link rel="preload" href="/assets/css/0.styles.ec7af591.css" as="style"><link rel="preload" href="/assets/js/app.aab05fb2.js" as="script"><link rel="preload" href="/assets/js/3.1dc302ea.js" as="script"><link rel="preload" href="/assets/js/256.d559b233.js" as="script"><link rel="prefetch" href="/assets/js/10.df7ec35f.js"><link rel="prefetch" href="/assets/js/100.eb839982.js"><link rel="prefetch" href="/assets/js/101.62cc7e3c.js"><link rel="prefetch" href="/assets/js/102.4fb75106.js"><link rel="prefetch" href="/assets/js/103.d948e8d2.js"><link rel="prefetch" href="/assets/js/104.dc2ec975.js"><link rel="prefetch" href="/assets/js/105.8c9c6ca3.js"><link rel="prefetch" href="/assets/js/106.787e200d.js"><link rel="prefetch" href="/assets/js/107.48adb385.js"><link rel="prefetch" href="/assets/js/108.2dd434b6.js"><link rel="prefetch" href="/assets/js/109.d5bd6b44.js"><link rel="prefetch" href="/assets/js/11.fdd2791a.js"><link rel="prefetch" href="/assets/js/110.db673f1b.js"><link rel="prefetch" href="/assets/js/111.5786d2f6.js"><link rel="prefetch" href="/assets/js/112.40054610.js"><link rel="prefetch" href="/assets/js/113.78698039.js"><link rel="prefetch" href="/assets/js/114.1a34e10c.js"><link rel="prefetch" href="/assets/js/115.c5191fa3.js"><link rel="prefetch" href="/assets/js/116.b522d27c.js"><link rel="prefetch" href="/assets/js/117.d58b55e7.js"><link rel="prefetch" href="/assets/js/118.f996da1b.js"><link rel="prefetch" href="/assets/js/119.95d2c7eb.js"><link rel="prefetch" href="/assets/js/12.53a797d3.js"><link rel="prefetch" href="/assets/js/120.c1e94071.js"><link rel="prefetch" href="/assets/js/121.32bdde4b.js"><link rel="prefetch" href="/assets/js/122.00b68073.js"><link rel="prefetch" href="/assets/js/123.a9afc8fd.js"><link rel="prefetch" href="/assets/js/124.1497f406.js"><link rel="prefetch" href="/assets/js/125.70e1f532.js"><link rel="prefetch" href="/assets/js/126.dd069639.js"><link rel="prefetch" href="/assets/js/127.0a4bd1cd.js"><link rel="prefetch" href="/assets/js/128.66a4bdd6.js"><link rel="prefetch" href="/assets/js/129.31da435b.js"><link rel="prefetch" href="/assets/js/13.769b2d75.js"><link rel="prefetch" href="/assets/js/130.a55118c1.js"><link rel="prefetch" href="/assets/js/131.692c7e8c.js"><link rel="prefetch" href="/assets/js/132.92f478be.js"><link rel="prefetch" href="/assets/js/133.d8d1fda7.js"><link rel="prefetch" href="/assets/js/134.079a54eb.js"><link rel="prefetch" href="/assets/js/135.603463f1.js"><link rel="prefetch" href="/assets/js/136.1367f4f4.js"><link rel="prefetch" href="/assets/js/137.e2dd9afd.js"><link rel="prefetch" href="/assets/js/138.aef15ddd.js"><link rel="prefetch" href="/assets/js/139.0a4e81c3.js"><link rel="prefetch" href="/assets/js/14.c590e545.js"><link rel="prefetch" href="/assets/js/140.7fcac681.js"><link rel="prefetch" href="/assets/js/141.490f341e.js"><link rel="prefetch" href="/assets/js/142.8695a90f.js"><link rel="prefetch" href="/assets/js/143.2906308a.js"><link rel="prefetch" href="/assets/js/144.3ef9d83e.js"><link rel="prefetch" href="/assets/js/145.b7e21983.js"><link rel="prefetch" href="/assets/js/146.f4f05f49.js"><link rel="prefetch" href="/assets/js/147.2cf5fcc7.js"><link rel="prefetch" href="/assets/js/148.4ca7f432.js"><link rel="prefetch" href="/assets/js/149.b892eba8.js"><link rel="prefetch" href="/assets/js/15.4e36e03a.js"><link rel="prefetch" href="/assets/js/150.c3b675ab.js"><link rel="prefetch" href="/assets/js/151.573ed3bf.js"><link rel="prefetch" href="/assets/js/152.847be55c.js"><link rel="prefetch" href="/assets/js/153.ac2f5049.js"><link rel="prefetch" href="/assets/js/154.d8f17cf5.js"><link rel="prefetch" href="/assets/js/155.7e577cee.js"><link rel="prefetch" href="/assets/js/156.09e95d19.js"><link rel="prefetch" href="/assets/js/157.26abc4b8.js"><link rel="prefetch" href="/assets/js/158.77955f1f.js"><link rel="prefetch" href="/assets/js/159.c355ea29.js"><link rel="prefetch" href="/assets/js/16.0b89faa2.js"><link rel="prefetch" href="/assets/js/160.e4ef16f7.js"><link rel="prefetch" href="/assets/js/161.910be1d9.js"><link rel="prefetch" href="/assets/js/162.632afcfd.js"><link rel="prefetch" href="/assets/js/163.f5057cff.js"><link rel="prefetch" href="/assets/js/164.744b0d75.js"><link rel="prefetch" href="/assets/js/165.58f59259.js"><link rel="prefetch" href="/assets/js/166.ca91cb14.js"><link rel="prefetch" href="/assets/js/167.542edc26.js"><link rel="prefetch" href="/assets/js/168.bb4a1767.js"><link rel="prefetch" href="/assets/js/169.cd7762cb.js"><link rel="prefetch" href="/assets/js/17.54956aa7.js"><link rel="prefetch" href="/assets/js/170.bc1fbd49.js"><link rel="prefetch" href="/assets/js/171.957b8fc0.js"><link rel="prefetch" href="/assets/js/172.07512139.js"><link rel="prefetch" href="/assets/js/173.1dc87f34.js"><link rel="prefetch" href="/assets/js/174.8cc0b78c.js"><link rel="prefetch" href="/assets/js/175.fff490c7.js"><link rel="prefetch" href="/assets/js/176.8f18d71a.js"><link rel="prefetch" href="/assets/js/177.c14bf697.js"><link rel="prefetch" href="/assets/js/178.484171c5.js"><link rel="prefetch" href="/assets/js/179.db8ce2fc.js"><link rel="prefetch" href="/assets/js/18.74f41e6a.js"><link rel="prefetch" href="/assets/js/180.e2d90285.js"><link rel="prefetch" href="/assets/js/181.89d19240.js"><link rel="prefetch" href="/assets/js/182.d6a1e6c1.js"><link rel="prefetch" href="/assets/js/183.0e33f8be.js"><link rel="prefetch" href="/assets/js/184.4f2a386b.js"><link rel="prefetch" href="/assets/js/185.88f314d4.js"><link rel="prefetch" href="/assets/js/186.c88ddd9d.js"><link rel="prefetch" href="/assets/js/187.361a4180.js"><link rel="prefetch" href="/assets/js/188.3bd63846.js"><link rel="prefetch" href="/assets/js/189.a1cde7be.js"><link rel="prefetch" href="/assets/js/19.b2902618.js"><link rel="prefetch" href="/assets/js/190.6ada374d.js"><link rel="prefetch" href="/assets/js/191.3c92390c.js"><link rel="prefetch" href="/assets/js/192.79ef5864.js"><link rel="prefetch" href="/assets/js/193.f037d2e1.js"><link rel="prefetch" href="/assets/js/194.ea7f7dae.js"><link rel="prefetch" href="/assets/js/195.986eb514.js"><link rel="prefetch" href="/assets/js/196.647c1541.js"><link rel="prefetch" href="/assets/js/197.5b581b72.js"><link rel="prefetch" href="/assets/js/198.ffb0d3bb.js"><link rel="prefetch" href="/assets/js/199.2d0d96c8.js"><link rel="prefetch" href="/assets/js/20.6630eb9b.js"><link rel="prefetch" href="/assets/js/200.c5aad4aa.js"><link rel="prefetch" href="/assets/js/201.2008406c.js"><link rel="prefetch" href="/assets/js/202.8c1db698.js"><link rel="prefetch" href="/assets/js/203.d5203c70.js"><link rel="prefetch" href="/assets/js/204.e54acfa8.js"><link rel="prefetch" href="/assets/js/205.c4b100e4.js"><link rel="prefetch" href="/assets/js/206.e49b85d8.js"><link rel="prefetch" href="/assets/js/207.29a65e32.js"><link rel="prefetch" href="/assets/js/208.96c25b78.js"><link rel="prefetch" href="/assets/js/209.da5b902e.js"><link rel="prefetch" href="/assets/js/21.7348c820.js"><link rel="prefetch" href="/assets/js/210.0996b0bc.js"><link rel="prefetch" href="/assets/js/211.1daccc6a.js"><link rel="prefetch" href="/assets/js/212.30632baa.js"><link rel="prefetch" href="/assets/js/213.7c93918f.js"><link rel="prefetch" href="/assets/js/214.ef5415e3.js"><link rel="prefetch" href="/assets/js/215.efbf083a.js"><link rel="prefetch" href="/assets/js/216.4f8f1a97.js"><link rel="prefetch" href="/assets/js/217.aa94f853.js"><link rel="prefetch" href="/assets/js/218.7b852cd9.js"><link rel="prefetch" href="/assets/js/219.43f1e1a9.js"><link rel="prefetch" href="/assets/js/22.342c3455.js"><link rel="prefetch" href="/assets/js/220.46e3baeb.js"><link rel="prefetch" href="/assets/js/221.90351c5d.js"><link rel="prefetch" href="/assets/js/222.566b541a.js"><link rel="prefetch" href="/assets/js/223.e69b2bf7.js"><link rel="prefetch" href="/assets/js/224.4407f53f.js"><link rel="prefetch" href="/assets/js/225.5da34be9.js"><link rel="prefetch" href="/assets/js/226.0cd60a1c.js"><link rel="prefetch" href="/assets/js/227.5190fe78.js"><link rel="prefetch" href="/assets/js/228.d32ee20e.js"><link rel="prefetch" href="/assets/js/229.42f60648.js"><link rel="prefetch" href="/assets/js/23.a1dc7ce4.js"><link rel="prefetch" href="/assets/js/230.fb64689c.js"><link rel="prefetch" href="/assets/js/231.941ed40a.js"><link rel="prefetch" href="/assets/js/232.b76c5958.js"><link rel="prefetch" href="/assets/js/233.fdbc3089.js"><link rel="prefetch" href="/assets/js/234.e427f6ad.js"><link rel="prefetch" href="/assets/js/235.71d57a1d.js"><link rel="prefetch" href="/assets/js/236.043d2fa9.js"><link rel="prefetch" href="/assets/js/237.7935de95.js"><link rel="prefetch" href="/assets/js/238.3f43ff91.js"><link rel="prefetch" href="/assets/js/239.a3762b13.js"><link rel="prefetch" href="/assets/js/24.7d99b547.js"><link rel="prefetch" href="/assets/js/240.264dc456.js"><link rel="prefetch" href="/assets/js/241.d8ebf4e1.js"><link rel="prefetch" href="/assets/js/242.7883df9a.js"><link rel="prefetch" href="/assets/js/243.3d0545a3.js"><link rel="prefetch" href="/assets/js/244.b254bb28.js"><link rel="prefetch" href="/assets/js/245.721a0673.js"><link rel="prefetch" href="/assets/js/246.3d2e0605.js"><link rel="prefetch" href="/assets/js/247.db755fe6.js"><link rel="prefetch" href="/assets/js/248.70ba84e9.js"><link rel="prefetch" href="/assets/js/249.c1c45b75.js"><link rel="prefetch" href="/assets/js/25.e9c9b8c3.js"><link rel="prefetch" href="/assets/js/250.28854dfe.js"><link rel="prefetch" href="/assets/js/251.c64305bb.js"><link rel="prefetch" href="/assets/js/252.bfb4ef3d.js"><link rel="prefetch" href="/assets/js/253.7c4e160d.js"><link rel="prefetch" href="/assets/js/254.3bb9c624.js"><link rel="prefetch" href="/assets/js/255.d5d8be96.js"><link rel="prefetch" href="/assets/js/257.758697f3.js"><link rel="prefetch" href="/assets/js/258.7ddfde22.js"><link rel="prefetch" href="/assets/js/259.c1c40084.js"><link rel="prefetch" href="/assets/js/26.e429c51b.js"><link rel="prefetch" href="/assets/js/260.f918b40f.js"><link rel="prefetch" href="/assets/js/261.cd3ecfe4.js"><link rel="prefetch" href="/assets/js/262.4a65733d.js"><link rel="prefetch" href="/assets/js/263.d4643aa4.js"><link rel="prefetch" href="/assets/js/264.8034043d.js"><link rel="prefetch" href="/assets/js/265.2d6e5394.js"><link rel="prefetch" href="/assets/js/266.945130cb.js"><link rel="prefetch" href="/assets/js/267.5779d8ad.js"><link rel="prefetch" href="/assets/js/268.3b8f7bf7.js"><link rel="prefetch" href="/assets/js/269.a6ea55d0.js"><link rel="prefetch" href="/assets/js/27.1092da6f.js"><link rel="prefetch" href="/assets/js/270.9e898993.js"><link rel="prefetch" href="/assets/js/271.d92f29b1.js"><link rel="prefetch" href="/assets/js/272.1cde5105.js"><link rel="prefetch" href="/assets/js/273.1df9246d.js"><link rel="prefetch" href="/assets/js/274.1d6613c2.js"><link rel="prefetch" href="/assets/js/275.55412b2d.js"><link rel="prefetch" href="/assets/js/276.eea117ab.js"><link rel="prefetch" href="/assets/js/277.d8cfd95d.js"><link rel="prefetch" href="/assets/js/278.ffad1db7.js"><link rel="prefetch" href="/assets/js/279.47bf065d.js"><link rel="prefetch" href="/assets/js/28.53650c51.js"><link rel="prefetch" href="/assets/js/280.49a50966.js"><link rel="prefetch" href="/assets/js/281.77b2a706.js"><link rel="prefetch" href="/assets/js/282.2714e4c8.js"><link rel="prefetch" href="/assets/js/283.1575531b.js"><link rel="prefetch" href="/assets/js/284.2c0c07ad.js"><link rel="prefetch" href="/assets/js/285.1696a921.js"><link rel="prefetch" href="/assets/js/286.5d791a4f.js"><link rel="prefetch" href="/assets/js/287.22c1ce09.js"><link rel="prefetch" href="/assets/js/288.652aaa7e.js"><link rel="prefetch" href="/assets/js/289.a07dc9d5.js"><link rel="prefetch" href="/assets/js/29.066202c5.js"><link rel="prefetch" href="/assets/js/290.597e6c27.js"><link rel="prefetch" href="/assets/js/291.307b1ef3.js"><link rel="prefetch" href="/assets/js/292.2939b2d7.js"><link rel="prefetch" href="/assets/js/293.42df9e57.js"><link rel="prefetch" href="/assets/js/294.f686160c.js"><link rel="prefetch" href="/assets/js/295.6e9b105c.js"><link rel="prefetch" href="/assets/js/296.f7fc5047.js"><link rel="prefetch" href="/assets/js/297.8482da6f.js"><link rel="prefetch" href="/assets/js/298.c2879999.js"><link rel="prefetch" href="/assets/js/299.177ef1c1.js"><link rel="prefetch" href="/assets/js/30.8899de4a.js"><link rel="prefetch" href="/assets/js/300.c3011a98.js"><link rel="prefetch" href="/assets/js/301.7595ce9b.js"><link rel="prefetch" href="/assets/js/302.a4083048.js"><link rel="prefetch" href="/assets/js/303.20e1e819.js"><link rel="prefetch" href="/assets/js/304.e69eabb5.js"><link rel="prefetch" href="/assets/js/305.18813104.js"><link rel="prefetch" href="/assets/js/306.db4c539d.js"><link rel="prefetch" href="/assets/js/307.1eadef68.js"><link rel="prefetch" href="/assets/js/308.0c148c77.js"><link rel="prefetch" href="/assets/js/309.75f04fa5.js"><link rel="prefetch" href="/assets/js/31.74a260ea.js"><link rel="prefetch" href="/assets/js/310.956c93b3.js"><link rel="prefetch" href="/assets/js/311.fab6126e.js"><link rel="prefetch" href="/assets/js/312.472991b0.js"><link rel="prefetch" href="/assets/js/313.b8d0b24a.js"><link rel="prefetch" href="/assets/js/314.24577949.js"><link rel="prefetch" href="/assets/js/315.87d89712.js"><link rel="prefetch" href="/assets/js/316.570b8ece.js"><link rel="prefetch" href="/assets/js/317.8630c35a.js"><link rel="prefetch" href="/assets/js/318.1d9e6706.js"><link rel="prefetch" href="/assets/js/319.4097770a.js"><link rel="prefetch" href="/assets/js/32.7dba92e8.js"><link rel="prefetch" href="/assets/js/320.a4d30cfc.js"><link rel="prefetch" href="/assets/js/321.efd17a08.js"><link rel="prefetch" href="/assets/js/322.1975e542.js"><link rel="prefetch" href="/assets/js/323.f43938be.js"><link rel="prefetch" href="/assets/js/324.80e620c4.js"><link rel="prefetch" href="/assets/js/325.eea5c98b.js"><link rel="prefetch" href="/assets/js/326.b01277ee.js"><link rel="prefetch" href="/assets/js/327.7f068672.js"><link rel="prefetch" href="/assets/js/328.f2f456c1.js"><link rel="prefetch" href="/assets/js/329.7879d79b.js"><link rel="prefetch" href="/assets/js/33.6f1de65a.js"><link rel="prefetch" href="/assets/js/330.c4f06595.js"><link rel="prefetch" href="/assets/js/331.dcecbbb4.js"><link rel="prefetch" href="/assets/js/332.56b7ace5.js"><link rel="prefetch" href="/assets/js/333.5b3dc02e.js"><link rel="prefetch" href="/assets/js/334.2445b2e3.js"><link rel="prefetch" href="/assets/js/335.c1a7666e.js"><link rel="prefetch" href="/assets/js/336.14ea02eb.js"><link rel="prefetch" href="/assets/js/337.92a1eebf.js"><link rel="prefetch" href="/assets/js/338.e2c82f63.js"><link rel="prefetch" href="/assets/js/339.61ab3afc.js"><link rel="prefetch" href="/assets/js/34.bd36ea6d.js"><link rel="prefetch" href="/assets/js/340.e6381542.js"><link rel="prefetch" href="/assets/js/341.06d1a04a.js"><link rel="prefetch" href="/assets/js/342.0c7db480.js"><link rel="prefetch" href="/assets/js/343.eae84cc4.js"><link rel="prefetch" href="/assets/js/344.600f5857.js"><link rel="prefetch" href="/assets/js/345.895f6f4e.js"><link rel="prefetch" href="/assets/js/346.0f36054a.js"><link rel="prefetch" href="/assets/js/347.fb779741.js"><link rel="prefetch" href="/assets/js/348.c8c979e8.js"><link rel="prefetch" href="/assets/js/349.7c8c7182.js"><link rel="prefetch" href="/assets/js/35.8794367a.js"><link rel="prefetch" href="/assets/js/350.6594590a.js"><link rel="prefetch" href="/assets/js/351.53fce239.js"><link rel="prefetch" href="/assets/js/352.35ec8ac2.js"><link rel="prefetch" href="/assets/js/353.7b4fbfbb.js"><link rel="prefetch" href="/assets/js/354.23ecd67f.js"><link rel="prefetch" href="/assets/js/355.3036280e.js"><link rel="prefetch" href="/assets/js/356.6994b1c5.js"><link rel="prefetch" href="/assets/js/357.87843ebc.js"><link rel="prefetch" href="/assets/js/358.99fb8c0e.js"><link rel="prefetch" href="/assets/js/359.4a8e0f6b.js"><link rel="prefetch" href="/assets/js/36.dbfe70fd.js"><link rel="prefetch" href="/assets/js/360.3b6b56f2.js"><link rel="prefetch" href="/assets/js/361.6a890781.js"><link rel="prefetch" href="/assets/js/362.d7161ced.js"><link rel="prefetch" href="/assets/js/363.a9ab6794.js"><link rel="prefetch" href="/assets/js/364.5ea7b05c.js"><link rel="prefetch" href="/assets/js/365.6ee82532.js"><link rel="prefetch" href="/assets/js/366.695af3fe.js"><link rel="prefetch" href="/assets/js/367.fa247cc1.js"><link rel="prefetch" href="/assets/js/368.ce8203d7.js"><link rel="prefetch" href="/assets/js/369.07ce9f2d.js"><link rel="prefetch" href="/assets/js/37.7ad39219.js"><link rel="prefetch" href="/assets/js/370.1f03bbad.js"><link rel="prefetch" href="/assets/js/371.c53badb2.js"><link rel="prefetch" href="/assets/js/372.61dae475.js"><link rel="prefetch" href="/assets/js/373.19d3b9dc.js"><link rel="prefetch" href="/assets/js/374.deba685c.js"><link rel="prefetch" href="/assets/js/375.b8774b96.js"><link rel="prefetch" href="/assets/js/376.8ffb9732.js"><link rel="prefetch" href="/assets/js/377.a78a55c5.js"><link rel="prefetch" href="/assets/js/378.25a24939.js"><link rel="prefetch" href="/assets/js/379.ee6780ec.js"><link rel="prefetch" href="/assets/js/38.571d97a7.js"><link rel="prefetch" href="/assets/js/380.2c8e4c39.js"><link rel="prefetch" href="/assets/js/381.d2537d37.js"><link rel="prefetch" href="/assets/js/382.f188f5aa.js"><link rel="prefetch" href="/assets/js/383.19ba3299.js"><link rel="prefetch" href="/assets/js/384.14229453.js"><link rel="prefetch" href="/assets/js/385.e72e7623.js"><link rel="prefetch" href="/assets/js/386.e5fd2287.js"><link rel="prefetch" href="/assets/js/387.348649a0.js"><link rel="prefetch" href="/assets/js/388.91379896.js"><link rel="prefetch" href="/assets/js/389.ae818bc1.js"><link rel="prefetch" href="/assets/js/39.afda26e0.js"><link rel="prefetch" href="/assets/js/390.9bc0ecf2.js"><link rel="prefetch" href="/assets/js/391.96918708.js"><link rel="prefetch" href="/assets/js/392.ecb684cf.js"><link rel="prefetch" href="/assets/js/393.f1a2f009.js"><link rel="prefetch" href="/assets/js/394.1b21a999.js"><link rel="prefetch" href="/assets/js/395.b94a7ea2.js"><link rel="prefetch" href="/assets/js/396.e4592dfd.js"><link rel="prefetch" href="/assets/js/397.1c34de3b.js"><link rel="prefetch" href="/assets/js/398.5341fb9b.js"><link rel="prefetch" href="/assets/js/399.5585f448.js"><link rel="prefetch" href="/assets/js/4.256130eb.js"><link rel="prefetch" href="/assets/js/40.a7fda1a5.js"><link rel="prefetch" href="/assets/js/400.7202f552.js"><link rel="prefetch" href="/assets/js/401.42943381.js"><link rel="prefetch" href="/assets/js/402.90c70df5.js"><link rel="prefetch" href="/assets/js/403.9513b679.js"><link rel="prefetch" href="/assets/js/404.56ae1c4e.js"><link rel="prefetch" href="/assets/js/405.736155d7.js"><link rel="prefetch" href="/assets/js/406.0b7c929c.js"><link rel="prefetch" href="/assets/js/407.f1660a22.js"><link rel="prefetch" href="/assets/js/408.d77b4eed.js"><link rel="prefetch" href="/assets/js/409.57b13e89.js"><link rel="prefetch" href="/assets/js/41.d0455f88.js"><link rel="prefetch" href="/assets/js/410.0ac0b985.js"><link rel="prefetch" href="/assets/js/411.a24fe3ce.js"><link rel="prefetch" href="/assets/js/412.c8949d31.js"><link rel="prefetch" href="/assets/js/413.9348cdaf.js"><link rel="prefetch" href="/assets/js/414.5476bceb.js"><link rel="prefetch" href="/assets/js/415.367d85f6.js"><link rel="prefetch" href="/assets/js/416.556d1b58.js"><link rel="prefetch" href="/assets/js/417.43c05f09.js"><link rel="prefetch" href="/assets/js/418.120b5cef.js"><link rel="prefetch" href="/assets/js/419.9f19f44b.js"><link rel="prefetch" href="/assets/js/42.0918e90a.js"><link rel="prefetch" href="/assets/js/420.f104a309.js"><link rel="prefetch" href="/assets/js/421.9126aec5.js"><link rel="prefetch" href="/assets/js/422.5cf330d9.js"><link rel="prefetch" href="/assets/js/423.d7231f78.js"><link rel="prefetch" href="/assets/js/424.6df09c53.js"><link rel="prefetch" href="/assets/js/43.10d96685.js"><link rel="prefetch" href="/assets/js/44.a3535bf1.js"><link rel="prefetch" href="/assets/js/45.a70f329b.js"><link rel="prefetch" href="/assets/js/46.5b5905c7.js"><link rel="prefetch" href="/assets/js/47.7a327a86.js"><link rel="prefetch" href="/assets/js/48.6b166b34.js"><link rel="prefetch" href="/assets/js/49.649d442c.js"><link rel="prefetch" href="/assets/js/5.f601e2c6.js"><link rel="prefetch" href="/assets/js/50.c5fb2695.js"><link rel="prefetch" href="/assets/js/51.a0ab7916.js"><link rel="prefetch" href="/assets/js/52.d1ec2122.js"><link rel="prefetch" href="/assets/js/53.397b47bc.js"><link rel="prefetch" href="/assets/js/54.65465bf1.js"><link rel="prefetch" href="/assets/js/55.80ea5cb9.js"><link rel="prefetch" href="/assets/js/56.b2f340c6.js"><link rel="prefetch" href="/assets/js/57.19a2c675.js"><link rel="prefetch" href="/assets/js/58.30b2d7e4.js"><link rel="prefetch" href="/assets/js/59.680940a9.js"><link rel="prefetch" href="/assets/js/6.721631ef.js"><link rel="prefetch" href="/assets/js/60.a608a453.js"><link rel="prefetch" href="/assets/js/61.cc1db890.js"><link rel="prefetch" href="/assets/js/62.7e8f4824.js"><link rel="prefetch" href="/assets/js/63.1a495e69.js"><link rel="prefetch" href="/assets/js/64.bc808e35.js"><link rel="prefetch" href="/assets/js/65.4599fb61.js"><link rel="prefetch" href="/assets/js/66.9f519a71.js"><link rel="prefetch" href="/assets/js/67.c2eea14a.js"><link rel="prefetch" href="/assets/js/68.7dacd0ee.js"><link rel="prefetch" href="/assets/js/69.3cf6be47.js"><link rel="prefetch" href="/assets/js/7.ca2cff26.js"><link rel="prefetch" href="/assets/js/70.154db1d1.js"><link rel="prefetch" href="/assets/js/71.5e74a55e.js"><link rel="prefetch" href="/assets/js/72.04b04992.js"><link rel="prefetch" href="/assets/js/73.6d44ceae.js"><link rel="prefetch" href="/assets/js/74.46618890.js"><link rel="prefetch" href="/assets/js/75.cf1936c6.js"><link rel="prefetch" href="/assets/js/76.f16398a0.js"><link rel="prefetch" href="/assets/js/77.01918d4a.js"><link rel="prefetch" href="/assets/js/78.f9911849.js"><link rel="prefetch" href="/assets/js/79.23a27387.js"><link rel="prefetch" href="/assets/js/8.c47fdf90.js"><link rel="prefetch" href="/assets/js/80.3f146599.js"><link rel="prefetch" href="/assets/js/81.fd4cc088.js"><link rel="prefetch" href="/assets/js/82.99513a8e.js"><link rel="prefetch" href="/assets/js/83.c6be4217.js"><link rel="prefetch" href="/assets/js/84.421f5640.js"><link rel="prefetch" href="/assets/js/85.820ffd5a.js"><link rel="prefetch" href="/assets/js/86.497e18c6.js"><link rel="prefetch" href="/assets/js/87.ae9e8388.js"><link rel="prefetch" href="/assets/js/88.4c5105e2.js"><link rel="prefetch" href="/assets/js/89.1f652761.js"><link rel="prefetch" href="/assets/js/9.cc76f2db.js"><link rel="prefetch" href="/assets/js/90.4a9eb03c.js"><link rel="prefetch" href="/assets/js/91.7e226fac.js"><link rel="prefetch" href="/assets/js/92.dd96bf00.js"><link rel="prefetch" href="/assets/js/93.ec32463a.js"><link rel="prefetch" href="/assets/js/94.9575ff6e.js"><link rel="prefetch" href="/assets/js/95.99afeeb5.js"><link rel="prefetch" href="/assets/js/96.063584de.js"><link rel="prefetch" href="/assets/js/97.e7ed0e68.js"><link rel="prefetch" href="/assets/js/98.873a8141.js"><link rel="prefetch" href="/assets/js/99.9cd99ea3.js"><link rel="prefetch" href="/assets/js/vendors~docsearch.3b3aacb0.js">
<link rel="stylesheet" href="/assets/css/0.styles.ec7af591.css">
</head>
<body>
<div id="app" data-server-rendered="true"><div class="theme-container"><header class="navbar"><div class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/zh/" class="home-link router-link-active"><img src="/img/logo.png" alt=" " class="logo"></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">文档</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/UserGuide/Master/Get Started/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.8.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.8.x</a></li></ul></div></div><div class="nav-item"><a href="/zh/SystemDesign/Architecture/Architecture.html" class="nav-link">系统设计</a></div><div class="nav-item"><a href="/zh/Download/" class="nav-link">下载</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">社区</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
Wiki
<!----></a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Project Committers.html" class="nav-link">开发人员</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Powered By.html" class="nav-link">技术支持</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Materials.html" class="nav-link">活动与报告</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Feedback.html" class="nav-link">交流与反馈</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">开发</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/Development/VoteRelease.html" class="nav-link">如何投票</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/HowToCommit.html" class="nav-link">如何提交代码</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/Committer.html" class="nav-link">成为Committer</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/ContributeGuide.html" class="nav-link">项目开发指南</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/format-changelist.html" class="nav-link">TsFile的更改列表</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/rpc-changelist.html" class="nav-link">RPC变更清单</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">ASF</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://www.apache.org/" class="nav-link external">
基金会
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
许可证
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
安全
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
赞助
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
致谢
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
活动
<!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">语言</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/SystemDesign/StorageEngine/Recover.html" class="nav-link">English</a></li><li class="dropdown-item"><!----> <a href="/zh/SystemDesign/StorageEngine/Recover.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/incubator-iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
gitHub
<svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></nav></div></header> <div class="sidebar-mask"></div> <aside class="sidebar"><nav class="nav-links"><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">文档</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/UserGuide/Master/Get Started/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.8.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.8.x</a></li></ul></div></div><div class="nav-item"><a href="/zh/SystemDesign/Architecture/Architecture.html" class="nav-link">系统设计</a></div><div class="nav-item"><a href="/zh/Download/" class="nav-link">下载</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">社区</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
Wiki
<!----></a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Project Committers.html" class="nav-link">开发人员</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Powered By.html" class="nav-link">技术支持</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Materials.html" class="nav-link">活动与报告</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Feedback.html" class="nav-link">交流与反馈</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">开发</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/Development/VoteRelease.html" class="nav-link">如何投票</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/HowToCommit.html" class="nav-link">如何提交代码</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/Committer.html" class="nav-link">成为Committer</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/ContributeGuide.html" class="nav-link">项目开发指南</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/format-changelist.html" class="nav-link">TsFile的更改列表</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/rpc-changelist.html" class="nav-link">RPC变更清单</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">ASF</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://www.apache.org/" class="nav-link external">
基金会
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
许可证
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
安全
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
赞助
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
致谢
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
活动
<!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">语言</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/SystemDesign/StorageEngine/Recover.html" class="nav-link">English</a></li><li class="dropdown-item"><!----> <a href="/zh/SystemDesign/StorageEngine/Recover.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/incubator-iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
gitHub
<svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></nav> <ul class="sidebar-links"><li><section class="sidebar-group depth-0"><p class="sidebar-heading"><span>系统设计</span> <!----></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>应用概览</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>TsFile</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>查询引擎</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>元数据管理</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>存储引擎</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/zh/SystemDesign/StorageEngine/FileLists.html" class="sidebar-link">磁盘文件汇总</a></li><li><a href="/zh/SystemDesign/StorageEngine/StorageEngine.html" class="sidebar-link">存储引擎</a></li><li><a href="/zh/SystemDesign/StorageEngine/WAL.html" class="sidebar-link">写前日志</a></li><li><a href="/zh/SystemDesign/StorageEngine/FlushManager.html" class="sidebar-link">FlushManager</a></li><li><a href="/zh/SystemDesign/StorageEngine/MergeManager.html" class="sidebar-link">文件合并机制</a></li><li><a href="/zh/SystemDesign/StorageEngine/DataPartition.html" class="sidebar-link">数据分区</a></li><li><a href="/zh/SystemDesign/StorageEngine/DataManipulation.html" class="sidebar-link">数据增删改</a></li><li><a href="/zh/SystemDesign/StorageEngine/Recover.html" aria-current="page" class="active sidebar-link">重启恢复</a></li></ul></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>数据查询</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>工具</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>连接器</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>客户端</span> <span class="arrow right"></span></p> <!----></section></li></ul> </aside> <main class="page"> <div class="content content__default"><h1 id="重启恢复流程"><a href="#重启恢复流程" class="header-anchor">#</a> 重启恢复流程</h1> <p>重启恢复是以存储组为粒度进行的,恢复的入口是 StorageGroupProcessor 的 recover()</p> <h2 id="存储组恢复流程"><a href="#存储组恢复流程" class="header-anchor">#</a> 存储组恢复流程</h2> <ul><li><p>org.apache.iotdb.db.engine.storagegroup.StorageGroupProcessor.recover()</p></li> <li><p>首先获得该存储组下所有以.tsfile结尾的数据文件,返回 TsFileResource,共有如下几个文件列表</p></li> <li><p>顺序文件</p> <ul><li>0.10 版本的文件(封口/未封口)</li> <li>0.9 版本的文件(封口)</li></ul></li> <li><p>乱序文件</p> <ul><li>0.10 版本的文件(封口/未封口)</li> <li>0.9 版本的文件(封口)</li></ul></li> <li><p>若该存储组下有 0.9 版本的 TsFile 文件,则将旧版本的顺序和乱序文件分别加入<code>upgradeSeqFileList</code><code>upgradeSeqFileList</code>中,供升级和查询使用。</p></li> <li><p>将顺序、乱序文件按照分区分组 Map&lt;Long, List<TsFileResource>&gt;</TsFileResource></p></li> <li><p>恢复每个分区的顺序文件,将上一步获得的每个分区的顺序 TsFile 文件作为参数,调用<code>recoverTsFiles</code>进行恢复,该方法会将恢复后的顺序 TsFile 以TsFileResource 的形式放入<code>sequenceFileTreeSet</code>中,若该 TsFile 是此分区的最后一个,且未封口,则还要为其构造<code>TsFileProcessor</code>对象,并加入<code>workSequenceTsFileProcessors</code>中,该方法的具体细节会在下一小节阐述。</p></li> <li><p>恢复每个分区的乱序文件,将上一步获得的每个分区的乱序 TsFile 文件作为参数,调用<code>recoverTsFiles</code>进行恢复,该方法会将恢复后的乱序 TsFile 以 TsFileResource 的形式放入<code>unSequenceFileList</code>中,若该 TsFile 是此分区的最后一个,且未封口,则还要为其构造<code>TsFileProcessor</code>对象,并加入<code>workUnsequenceTsFileProcessors</code>中,该方法的具体细节会在下一小节阐述。</p></li> <li><p>分别遍历上两步得到的<code>sequenceFileTreeSet</code><code>unSequenceFileList</code>,更新分区对应的版本号</p></li> <li><p>检查有没有merge时候的Modification文件,并调用<code>RecoverMergeTask.recoverMerge</code>方法对merge进行恢复</p></li> <li><p>调用<code>updateLastestFlushedTime()</code>方法,用 0.9 版本的顺序tsfile文件,更新<code>latestTimeForEachDevice</code>, <code>partitionLatestFlushedTimeForEachDevice</code>以及<code>globalLatestFlushedTimeForEachDevice</code></p> <ul><li><code>latestTimeForEachDevice</code> 记录了所有device已经插入的各个分区下的最新的时间戳(包括未flush的和已flush的)</li> <li><code>partitionLatestFlushedTimeForEachDevice</code> 记录了所有device已经flush的各个分区下的最新的时间戳,它用来判断一个新插入的点是不是乱序点</li> <li><code>globalLatestFlushedTimeForEachDevice</code> 记录了所有device已经flush的最新时间戳(是各个分区的最新时间戳的汇总)</li></ul></li> <li><p>最后遍历<code>sequenceFileTreeSet</code>,用恢复出来的顺序文件,再次更新<code>latestTimeForEachDevice</code>, <code>partitionLatestFlushedTimeForEachDevice</code>以及<code>globalLatestFlushedTimeForEachDevice</code></p></li></ul> <h2 id="恢复一个分区的(顺序-乱序)-tsfile"><a href="#恢复一个分区的(顺序-乱序)-tsfile" class="header-anchor">#</a> 恢复一个分区的(顺序/乱序) TsFile</h2> <ul><li>org.apache.iotdb.db.engine.storagegroup.StorageGroupProcessor.recoverTsFiles</li></ul> <p>该方法主要负责遍历传进来的所有 TsFile,挨个进行恢复。</p> <ul><li><p>构造出<code>TsFileRecoverPerformer</code>对象,对 TsFile 文件进行恢复,恢复的逻辑封装在<code>TsFileRecoverPerformer</code><code>recover()</code>方法中(具体细节在下一小节展开阐述),该方法会返回一个恢复后的<code>RestorableTsFileIOWriter</code>对象。</p> <ul><li>若恢复过程失败,则记录log,并跳过该tsfile</li></ul></li> <li><p>若该 TsFile 文件不是最后一个文件,或者该 TsFile 文件是最后一个文件,但已经被关闭或标记被关闭,只需将该 TsFile 文件在内存中对应的<code>TsFileResource</code>对象的<code>closed</code>属性置成<code>true</code>即可。</p></li> <li><p>若该 TsFile 文件可以继续写入,则表示这是此分区的最后一个 TsFile,且未封口,则继续保持其未封口的状态,需要为它构造一个<code>TsFileProcessor</code>对象,并将其放到<code>workSequenceTsFileProcessors</code><code>workUnsequenceTsFileProcessors</code>中。</p></li> <li><p>最后将恢复出来的 TsFile 文件在内存中对应的<code>TsFileResource</code>对象放入<code>sequenceFileTreeSet</code><code>unSequenceFileList</code></p></li></ul> <h3 id="恢复一个-tsfile-文件"><a href="#恢复一个-tsfile-文件" class="header-anchor">#</a> 恢复一个 TsFile 文件</h3> <ul><li>org.apache.iotdb.db.writelog.recover.TsFileRecoverPerformer.recover</li></ul> <p>该方法主要负责每个具体的 TsFile 文件的恢复。</p> <ul><li><p>首先用tsfile文件构造出一个<code>RestorableTsFileIOWriter</code>对象,在<code>RestorableTsFileIOWriter</code>的构造方法中,会对该tsfile的文件内容进行检查,必要时进行截断</p> <ul><li>如果这个文件中没有任何内容,则为其写入<code>MAGIC_STRING</code><code>VERSION_NUMBER</code>后,直接返回,此时的<code>crashed</code><code>false</code><code>canWrite</code><code>true</code></li> <li>如果文件中有内容,构造<code>TsFileSequenceReader</code>对象对内容进行解析,调用<code>selfCheck</code>方法进行自检,并将不完整的内容截断,初始化<code>truncatedSize</code><code>HeaderLength</code> <ul><li>若文件内容完整(有完整的头部的<code>MAGIC_STRING</code><code>VERSION_NUMBER</code>,以及尾部的<code>MAGIC_STRING</code>),则返回<code>TsFileCheckStatus.COMPLETE_FILE</code></li> <li>若文件长度小于<code>HeaderLength(len(MAGIC_STRING) + len(VERSION_NUMBER))</code>,或者文件头部内容不是<code>MAGIC_STRING</code>,则返回<code>INCOMPATIBLE_FILE</code></li> <li>若文件长度刚好等于<code>HeaderLength</code>,且文件内容就是<code>MAGIC_STRING + VERSION_NUMBER</code>,则返回<code>HeaderLength</code></li> <li>若文件长度大于<code>HeaderLength</code>,且文件头合法,但文件尾部没有<code>MAGIC_STRING</code>,表示该文件不完整,需要进行截断。从<code>VERSION_NUMBER</code>往后读,读出chunk中的数据,并根据chunk中的数据恢复出ChunkMetadata,若遇到<code>CHUNK_GROUP_FOOTER</code>,则表示整个ChunkGroup是完整的,更新<code>truncatedSize</code>至当前位置</li> <li>返回<code>truncatedSize</code></li></ul></li> <li>根据返回的<code>truncatedSize</code>,对文件进行截断
<ul><li><code>truncatedSize</code>等于<code>TsFileCheckStatus.COMPLETE_FILE</code>,则将<code>crashed</code><code>canWrite</code>置为<code>false</code>,并关闭文件的输出流</li> <li><code>truncatedSize</code>等于<code>TsFileCheckStatus.INCOMPATIBLE_FILE</code>,则关闭文件的输出流,并抛异常</li> <li>否则,将<code>crashed</code><code>canWrite</code>置为<code>true</code>,并将文件截断至<code>truncatedSize</code></li></ul></li></ul></li> <li><p>通过返回的 RestorableTsFileIOWriter 判断文件是否完整</p> <ul><li><p>若该 TsFile 文件是完整的</p> <ul><li>若 TsFile 文件对应的 resource 文件存在,则将 resource 文件反序列化(包括每个设备在该tsfile文件中的最小和最大时间戳),并恢复文件版本号</li> <li>若 TsFile 文件对应的 resource 文件不存在,则重新生成resource 文件</li> <li>返回生成的 <code>RestorableTsFileIOWriter</code></li></ul></li> <li><p>若 TsFile 不完整</p> <ul><li>调用<code>recoverResourceFromWriter</code>,通过<code>RestorableTsFileIOWriter</code>中的ChunkMetadata信息,恢复出resource信息</li> <li>调用<code>redoLogs</code>方法将这个文件对应的一个或多个写前日志文件中的数据都写到一个临时 Memtable 中,并持久化到这个不完整的 TsFile 中
<ul><li>对于顺序文件,跳过时间戳小于等于当前 resource 的 WAL</li> <li>对于乱序文件,将 WAL 全部重做,有可能重复写入多个 device 的 ChunkGroup</li></ul></li> <li>如果该 TsFile 不是当前分区的最后一个 TsFile,或者该 TsFile 有<code>.closing</code>文件存在,则调用<code>RestorableTsFileIOWriter</code><code>endFile()</code>方法,将文件封口,并删除<code>.closing</code>文件,并为其生成resource文件</li></ul></li></ul></li></ul></div> <div class="page-nav"><p class="inner"><span class="prev">
<a href="/zh/SystemDesign/StorageEngine/DataManipulation.html" class="prev">
数据增删改
</a></span> <span class="next"><a href="/zh/SystemDesign/DataQuery/DataQuery.html">
数据查询
</a>
</span></p></div> <p style="text-align: center;">Copyright © 2020 The Apache Software Foundation.<br>
Apache and the Apache feather logo are trademarks of The Apache Software Foundation</p> <p style="text-align:justify!important;paddingLeft:10px;paddingRight:10px;">
Disclaimer: Apache IoTDB (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by the Apache Incubator. Incubation is required of all newly accepted projects until a further review indicates that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. While incubation status is not necessarily a reflection of the completeness or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.
</p></main></div><div class="global-ui"></div></div>
<script src="/assets/js/app.aab05fb2.js" defer></script><script src="/assets/js/3.1dc302ea.js" defer></script><script src="/assets/js/256.d559b233.js" defer></script>
</body>
</html>