go开源项目influxdb-relay源码分析(一)
influxdb-relay项目地址: https://github.com/influxdata/influxdb-relay,主要作为负载均衡节点,写入多个influxdb节点,起到高可用效果。
不多说,开搞~
1、main.go
package main import (
"flag"
"fmt"
"log"
"os"
"os/signal" "github.com/influxdata/influxdb-relay/relay"
) var (
//influxdb-realy启动时接收的配置文件参数,因为是falg.String所以接收的是一个字符串类型的参数
//flag.String 函数第一个参数代表启动时参数的名称,第二个参数代表默认值,第三个参数代表用途描述,此方法返回一个指针
//那么启动realy时应该是这个样子的: ./influxdb-relay -config relay.toml ———— "-config" 就是匹配上面flag.String函数第一个参数, "relay.toml" 是-config的值,这里代表配置文件的路径
configFile = flag.String("config", "", "Configuration file to use")
) func main() {
//flag.Parse是用来解析启动时传入的参数,必须调用
flag.Parse() //如果启动参数,配置文件路径为空
if *configFile == "" {
//记录日志
fmt.Fprintln(os.Stderr, "Missing configuration file")
//打印需要的参数提示,也就是会输出上面flag.String函数第三个参数
flag.PrintDefaults()
//退出
os.Exit()
}
//加载配置文件
cfg, err := relay.LoadConfigFile(*configFile)
//LoadConfigFile方法如下: 主要做的事情是把配置文件反序列化成一个Config对象然后return,也就是cfg
// func LoadConfigFile(filename string) (cfg Config, err error) {
// f, err := os.Open(filename)
// if err != nil {
// return cfg, err
// }
// defer f.Close()
// return cfg, toml.NewDecoder(f).Decode(&cfg)
// }
if err != nil {
fmt.Fprintln(os.Stderr, "Problem loading config file:", err)
}
//根据Config对象 创建relay组件
r, err := relay.New(cfg)
if err != nil {
log.Fatal(err)
}
//定义接收操作系统信号的channel
sigChan := make(chan os.Signal, )
//notify用于监听信号,如果操作系统向当前进程发送中断信号(os.Interrupt 表示中断信号)
signal.Notify(sigChan, os.Interrupt)
//如果接收到中断信号,开一个协程调用relay的Stop方法 停止http监听
go func() {
<-sigChan
r.Stop()
}() log.Println("starting relays...")
//relay 运行
r.Run()
}
2、配置文件 relay.toml
[[http]]
name = "example-http"
bind-addr = "127.0.0.1:9096"
output = [
{ name="influxdb-1", location = "http://127.0.0.1:8086/write" },
{ name="influxdb-2", location = "http://127.0.0.1:7086/write" },
] [[udp]]
name = "example-udp"
bind-addr = "127.0.0.1:19096"
read-buffer = # default
output = [
{ name="influxdb-1", location="127.0.0.1:8089", mtu= },
{ name="influxdb-", location="127.0.0.1:7089", mtu= },
]
总结:
1、加载配置文件 relay.toml
2、根据配置文件创建relay,启动监听端口,接收请求
3、把接收到的请求写入到influxdb1-2节点
后面再研究下核心模块relay怎么把接收到的数据同时写入,influxdb多个节点。
go开源项目influxdb-relay源码分析(一)的更多相关文章
- 谷歌开源项目Chromium的源码获取与项目构建(Win7+vs10/vs13)
转自:http://blog.csdn.net/kuerjinjin/article/details/23563059 从12年那会儿开始获取源码和构建chromium项目都是按照那时候的官方要求用w ...
- Android开源项目 Universal imageloader 源码研究之Lru算法
https://github.com/nostra13/Android-Universal-Image-Loader universal imageloader 源码研究之Lru算法 LRU - Le ...
- Android开源项目 Universal imageloader 源码研究之项目框架
Universal imageloader 的代码并不复杂 重点是缓存,线程池任务 下面都用UML图进行了绘制 基本使用流程就是 初始化配置,设置Options参数,最后Dispaly提交下载 pub ...
- 「从零单排canal 03」 canal源码分析大纲
在前面两篇中,我们从基本概念理解了canal是一个什么项目,能应用于什么场景,然后通过一个demo体验,有了基本的体感和认识. 从这一篇开始,我们将从源码入手,深入学习canal的实现方式.了解can ...
- 介绍开源的.net通信框架NetworkComms框架 源码分析
原文网址: http://www.cnblogs.com/csdev Networkcomms 是一款C# 语言编写的TCP/UDP通信框架 作者是英国人 以前是收费的 售价249英镑 我曾经花了 ...
- MyBatis 源码分析-项目总览
MyBatis 源码分析-项目总览 1.概述 本文主要大致介绍一下MyBatis的项目结构.引用参考资料<MyBatis技术内幕> 此外,https://mybatis.org/mybat ...
- ABP源码分析一:整体项目结构及目录
ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...
- 开源分布式数据库中间件MyCat源码分析系列
MyCat是当下很火的开源分布式数据库中间件,特意花费了一些精力研究其实现方式与内部机制,在此针对某些较为重要的源码进行粗浅的分析,希望与感兴趣的朋友交流探讨. 本源码分析系列主要针对代码实现,配置. ...
- 【.NET Core项目实战-统一认证平台】第八章 授权篇-IdentityServer4源码分析
[.NET Core项目实战-统一认证平台]开篇及目录索引 上篇文章我介绍了如何在网关上实现客户端自定义限流功能,基本完成了关于网关的一些自定义扩展需求,后面几篇将介绍基于IdentityServer ...
- 开源网站流量统计系统Piwik源码分析——参数统计(一)
Piwik现已改名为Matomo,这是一套国外著名的开源网站统计系统,类似于百度统计.Google Analytics等系统.最大的区别就是可以看到其中的源码,这正合我意.因为我一直对统计的系统很好奇 ...
随机推荐
- 《Linux内核精髓:精通Linux内核必会的75个绝技》一HACK #11cpuset
HACK #11cpuset 本节介绍控制物理CPU分配的cpuset.cpuset是Linux控制组(Cgroup)之一,其功能是指定特定进程或线程所使用的CPU组.另外,除CPU以外,同样还能指定 ...
- RabbitMQ 信道(channel)挂掉,但连接仍然存在,同时出现错误:Received remote Channel.Close (406): PRECONDITION_FAILED - unknown delivery tag x 的问题
该问题经过一番试验,发现是消费者(consumer)程序逻辑错误导致:在消息处理的回调函数中多次ack或nack. 开启Python日志,并在回调函数中两次ack得到如下信息: F:\software ...
- leetcode814
class Solution { public: TreeNode* pruneTree(TreeNode* root) { if(root==NULL) { return nullptr; } if ...
- x264改变输出分辨率的算法<转>
x264改变输出分辨率的算法 在某些应用场景下,x264的输入视频分辨率与接收端输出的视频分辨率不同.例如编码端摄像头采集到的YUV数据为1280x720,而接收端视频显示窗口为640x480.对于这 ...
- #region 常量和静态变量静态类readonly
#region 常量和静态变量静态类readonly //---------------------------------------------------------------------- ...
- LUA表的引用理解
--lua中引用类型都是分配在堆上的 --因此,我们在使用LUA的table时,可尽可能的使用表的引用,而不需要拷贝表里的元素 --比如,通过RPC协议传来一个表A,我们想要缓存这个表,只需要保存该表 ...
- U3D屏幕坐标,世界坐标,像素坐标之间的关系
U3D中,屏幕坐标和世界坐标单位一样,二者之间是直接的一一对应关系,不受屏幕分辨率影响.默认情况下屏幕空间画布的左下角坐标是世界原点(0,0,0),这种情形下,世界空间的点(1920,1080,任何值 ...
- eclipse怎么自定义工具栏
1.点击透视图按钮---->右键---->Customize: 2.勾选或者去掉相关项目:
- lda spark 代码官方文档
http://spark.apache.org/docs/1.6.1/mllib-clustering.html#latent-dirichlet-allocation-lda http://spar ...
- manjaro i3 配置笔记
更改国内源 sudo pacman-mirrors -GB testing -c China 增加Arch linuxcn源 在/etc/pacman.conf文件末尾添加两行: [archlinux ...