InfluxDB源碼目錄結構解析

来源:https://www.cnblogs.com/MikeZhang/archive/2017/12/28/InfluxdbSourceTree20171228.html
-Advertisement-
Play Games

操作系統 : CentOS7.3.1611_x64 go語言版本:1.8.3 linux/amd64 InfluxDB版本:1.1.0 influxdata主目錄結構 目錄解析說明: influxdb 為源碼的主目錄 influxql 實現了InfluxDB查詢語言的解析器(源碼主目錄裡面引用的是i ...


操作系統 : CentOS7.3.1611_x64

go語言版本:1.8.3 linux/amd64

InfluxDB版本:1.1.0

influxdata主目錄結構

[root@localhost influxdata]# pwd
/root/dev/golib/src/github.com/influxdata
[root@localhost influxdata]# tree -d -L 1
.
├── influxdb
├── influxql
├── usage-client
├── yamux
└── yarpc

目錄解析說明:

  • influxdb

  為源碼的主目錄

  • influxql

  實現了InfluxDB查詢語言的解析器(源碼主目錄裡面引用的是influxdata/influxdb/influxql,沒有該目錄的相關引用)

  • usage-client

  client lib V1版本

  • yamux

  Yet another Multiplexer(又一個多路復用器)是Golang的多路復用庫

  • yarpc

  Yet Another RPC (又一個RPC)是Golang的RPC庫

源碼主目錄結構

一級目錄結構如下:

[root@localhost influxdb]# pwd
/root/dev/golib/src/github.com/influxdata/influxdb
[root@localhost influxdb]# tree -d -L 1
.
├── client
├── cmd
├── coordinator
├── etc
├── importer
├── influxql
├── internal
├── man
├── models
├── monitor
├── pkg
├── scripts
├── services
├── stress
├── tcp
├── tests
├── toml
├── tsdb
└── uuid

二級目錄結構如下:

[root@localhost influxdb]# tree -d -L 2
.
├── client
│   └── v2
├── cmd
│   ├── influx
│   ├── influxd
│   ├── influx_inspect
│   ├── influx_stress
│   └── influx_tsm
├── coordinator
├── etc
│   └── burn-in
├── importer
│   └── v8
├── influxql
│   ├── internal
│   └── neldermead
├── internal
├── man
├── models
├── monitor
│   └── diagnostics
├── pkg
│   ├── deep
│   ├── escape
│   ├── limiter
│   ├── pool
│   └── slices
├── scripts
├── services
│   ├── admin
│   ├── collectd
│   ├── continuous_querier
│   ├── graphite
│   ├── httpd
│   ├── meta
│   ├── opentsdb
│   ├── precreator
│   ├── retention
│   ├── snapshotter
│   ├── subscriber
│   └── udp
├── stress
│   ├── stress_test_server
│   └── v2
├── tcp
├── tests
│   ├── siege
│   ├── tmux
│   └── urlgen
├── toml
├── tsdb
│   ├── engine
│   └── internal
└── uuid
View Code

目錄解析說明:

  • client

  client lib V2版本

  • cmd

  InfluxDB相關程式所在目錄。其中:

  influxd目錄為InfluxDB主程式代碼;

  influx為InfluxDB自帶的控制台管理工具源碼;

  influx_inspect為InfluxDB數據查看工具源碼;

  influx_stress為InfluxDB壓力測試工具源碼;

  influx_tsm為資料庫轉換工具(將資料庫從b1或bz1格式轉換為tsm1格式)源碼

  • coordinator

  協調器,負責數據的寫入和一些創建語句的執行。

  在InfluxDB的ChangeLog中顯示在v1.0.0中使用coordinator替換cluster,感覺自建集群功能可以通過此模塊實現。

  • etc

  存放預設配置

  • importer

  版本向後相容相關代碼,在ReadMe中已經提到:Version 0.8.9 of InfluxDB adds support to export your data to a format that can be imported into 0.9.3 and later.

  • influxql

  實現了InfluxDB查詢語言的解析器

  • internal

  主要實現了MetaClient介面

  • man

  幫助手冊

  • models

  基礎數據類型定義

  • monitor

  InfluxDB系統監控

  • pkg

  一些通用包的集合。

  deep裡面主要實現了deepValueEqual方法,用於深層次比較兩個值是否相等;

  escape裡面主要實現了byte和string兩種數據類型轉義字元的相關操作;

  limiter裡面主要是一個基於channel實現的簡單併發限制器Fixed;

  pool裡面主要實現了Bytes和Generic兩種類型的Pool,在Pool中的對象不使用時不會被垃圾回收自動清理掉;

  slices 裡面主要實現了一些string數組的操作;

  • scripts

  該目錄存放的是一些關於InfluxDB的腳本。

  • services

  該目錄存放的是一些關於InfluxDB的服務。

  admin 為InfluxDB內置的管理服務;

  collectd 為collectd(https://collectd.org)對接服務,可以接收通過UDP發送過來的collectd格式數據;

  continuous_querier 為InfluxDB的CQ服務;

  graphite 為InfluxDB的graphite服務;

  httpd 為InfluxDB的http服務,可以通過該介面進行資料庫數據的寫入和查詢等操作;

  meta 為InfluxDB的元數據服務,用於管理資料庫的元數據相關內容;

  opentsdb 為InfluxDB的opentsdb服務,可用於替換opentsdb;

  precreator 為InfluxDB的Shard預創建服務;

  retention 為InfluxDB的數據保留策略的強制執行服務,主要用於定時刪除文件;

  snapshotter 為InfluxDB的快照服務;

  subscriber 為InfluxDB的訂閱服務;

  udp 為InfluxDB的udp服務,可以通過該介面進行資料庫的寫入和查詢等操作;

  • stress

  該目錄存放的是壓力測試相關內容。

  • tcp

  網路連接的多路復用。

  • tests

  測試相關內容

  • toml

  toml的解析器,和另一個toml解析器(github.com/BurntSushi/toml)不同,為獨立的解析模塊,主要是解析時間字元串和磁碟容量數據。

  • tsdb

  tsdb目錄主要是時序資料庫的實現。

  • uuid

  該目錄裡面主要存放uuid生成的相關代碼。

好,就這些了,希望對你有幫助。

本文github地址:

https://github.com/mike-zhang/mikeBlogEssays/blob/master/2017/20171228_InfluxDB源碼目錄結構解析.rst

歡迎補充


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 操作前需要以下軟體,且,Ubuntu已經安裝在VMware Workstation上。 Ubuntu16.04 LTSVMware WorkstationSecureCRT VMware的編輯tab >虛擬網路編輯 菜單查看網路配置: 子網IP:192.168.92.0子網掩碼:255.255 ...
  • 本節總結: uboot啟動流程如下: 1)設置CPU為管理模式 2)關看門狗 3)關中斷 4)設置時鐘頻率 5)關mmu,初始化各個bank 6)進入board_init_f()函數 (初始化定時器,GPIO,串口等,劃分記憶體區域) 7)重定位 複製uboot,然後修改SDRAM上的uboot鏈接地 ...
  • 前言 一款不錯的代碼質量管理工具Sonar 前期準備 官方參考文檔 https://docs.sonarqube.org/display/SONAR/Documentation 軟體下載 https://www.sonarqube.org/downloads/ https://dev.mysql.c ...
  • 問題背景: 一塊近似最小系統的控制小板,主要用於對電機,氣閥,集成液晶屏以及其他的部件控制。考慮電流會較大採用DC-DC穩壓管。 電路焊接完成後,最小系統正常工作。 問題: 加上液晶屏後,串口屏出現閃爍,5V電壓不穩。排除線路板線徑過細問題。 更換晶元後問題依然存在,但是穩壓晶元在某寶買的,還是擔心 ...
  • 原文:http://os.51cto.com/art/201609/518191.htm 經常使用Linux的開發人員或者運維人員,可能對configure->make->make install相當熟悉。事實上,這叫GNU構建系統,利用腳本和make程式在特定平臺上構建軟體。這種方式成為一種習慣, ...
  • awk是一種編程語言,主要用於在linux/unix下對文本和數據進行處理,是linux/unix下的一個工具。數據可以來自標準輸入、一個或多個文件,或其它命令的輸出。awk的處理文本和數據的方式:逐行掃描文件,預設從第一行到最後一行,尋找匹配的特定模式的行,併在這些行上進行你想要的操作。gawk是 ...
  • 背景 預設都是筆記本鍵盤才有Fn組合功能鍵,台式機很少有。今天領到的是聯想鍵盤,給我的台式機使用後F12很麻煩,必須Fn+F12才可以。 需求 恢復預設的F1~F12功能 方案 只需要下載驅動安裝: Windows 7 32-bit,Windows Vista 32-bit,Windows XP(3 ...
  • 常用功能差異 1. 鎖差異 : • Oracle鎖加在數據塊上 • InnoDB 是在索引上加鎖,所以MySQL鎖的粒度沒有Oracle 精細。 2. 導入導出 : • Oracle採用EXP /IMP ,EXPDP/IMPDP導入導出。 • MySQL採用mysqldump導出,導入可以採用管道或 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...