使用 Makefile 构建指令集
使用 Makefile 构建指令集
make
是一个历史悠久的构建工具,通过配置 Makefile
文件就可以很方便的使用你自己自定义的各种指令集,且与具体的编程语言无关。
例如配置如下的 Makefile
:
make
是一个历史悠久的构建工具,通过配置 Makefile
文件就可以很方便的使用你自己自定义的各种指令集,且与具体的编程语言无关。
例如配置如下的 Makefile
:
废话不多说,文本将带你实现一个简单的 memcached 客户端。
memcached 本身并不支持集群,为了使用集群,我们可以自己在客户端实现路由分发,将相同的 key 路由到同一台 memcached 上去即可。 路由算法有很多,这里我们使用一致性哈希算法。
InfluxDB 开源的社区版本面临的最大的问题就是单点故障和容灾备份,有没有一个简单的方案去解决这个问题呢?
既然有单点故障的可能,那么索性写入多个节点,同时也解决了容灾备份的问题:
连续查询 Continuous Queries( CQ )是 InfluxDB 很重要的一项功能,它的作用是在 InfluxDB 数据库内部自动定期的执行查询,然后将查询结果存储到指定的 measurement 里。
配置文件中的相关配置:
InfluxDB 自带有一个监控系统,默认情况下此功能是开启的,每隔 10 秒中采集一次系统数据并把数据写入到 _internal 数据库中,其默认使用名称为 monitor 的 RP(数据保留 7 天),相关配置见配置文件中的:
InfluxDB 数据的写入如下图所示:
所有数据先写入到 WAL( Write Ahead Log )预写日志文件,并同步到 Cache 缓存中,当 Cache 缓存的数据达到了一定的大小,或者达到一定的时间间隔之后,数据会被写入到 TSM 文件中。
InfluxDB 是一个无结构模式,这也就是说你无需事先定义好表以及表的数据结构。
InfluxDB 支持的数据类型非常简单:
你可以看到除了 field value 支持的数据类型多一点之外,其余全是字符串类型。
先回顾一下 RP 策略( retention policy ),它由三个部分构成:
前两个部分没啥好说的,而 shard duration 和 shard group 的概念你可能会感到比较陌生。
数据库种类有很多,比如传统的关系型数据库 RDBMS( 如 MySQL ),NoSQL 数据库( 如 MongoDB ),Key-Value 类型( 如 redis ),Wide column 类型( 如 HBase )等等等等,当然还有本系列文章将会介绍的时序数据库 TSDB( 如 InfluxDB )。
Golang 中的 error 是一个内置的特殊的接口类型:
|
|
在 Go 1.13 版本之前,有关 error 的方法只有两个:
errors.New
:
|
|
fmt.Errorf
:
|
|
这两个方法都是用来生成一个新的 error 类型的数据。