【InfluxDB】InfluxDB学习实践笔记
InfluxDB是用Go编写的一个开源分布式时序、事件和指标数据库,无需外部依赖。它与Elasticsearch、Graphite等类似。比较适用于与事件紧密相关的数据,例如实时日志数据、实时监控数据等,详细信息可以自行网上搜索。
0x00 环境信息
基本信息:
- 系统:CentOS7.2
- IP地址:xx.xx.xx.xx
- 端口号:30040
- 运行环境:K8S测试集群中
- InfluxDB版本:1.5.1(该版本不再提供web界面)
- InfluxDB用户名:admin
- InfluxDB密码:admin
0x01 基本操作
InfluxDB支持三种方式的通信方式:
- InfluxDB客户端命令行
- HTTP API
- 各编程语言库
下面演示采用InfluxDB客户端命令行方式。
1、连接、认证
在windows系统中使用InfluxDB客户端命令行连接数据库,并进行认证:
注意,本地必须存在influxdb的一套指令程序,包括下面几个:
2、数据库操作
- show databases 查看数据库
- create database db_name 创建数据库
- drop database db_name 删除数据库
- use db_name 选择数据库
其中db_name表示具体的数据库名。
实际操作如下:
3、measurement操作
InfluxDB中的measurement类似于关系数据库中的数据表,后文中全部称其为数据表。
- show measurements 查看表
- insert measurement_name,tags fields timestamp 因为没有显示的创建表语句,所以通过向表中插入数据来创建表
- drop measurement measurement_name 删除表
其中,measurement_name代表具体的表名。在插入数据时有特定的格式要求,例如:
insert server_info,server_name=server1 cpu=intel,ram_capacity= timestamp
其中,从左到右依次为表名、逗号、tags<key-value,可多个>、空格、fields<key-value,可多个>、空格、timestamp,其中多个tags之间使用逗号分隔,多个fields之间使用逗号分隔。
4、数据操作(增删改查)
(1)新增数据
假设数据表格式如下面语句所示:
insert server_info,server_name=server1 cpu=intel,ram_capacity= timestamp
由上图结果可知,在插入数据时,可以不指定timestamp,此时数据库会自动添加。
(2)查询数据
查询数据使用SQL语句实现,同关系型数据库的查询方式几乎相同。如上图中所示。
(3)修改和删除数据
由于InfluxDB是时序数据库,所以未提供修改和删除数据的操作。不过,数据删除可以通过数据保存策略(Retention Policies)来自动实现。
5、series操作
series表示数据表中特定tags对应的数据,比如上面的表server_info,该表中保存了多个服务器的数据,不同服务器通过tags中的server_name不同值来表示,假如现在表中数据如下:
则此时series则表示不同服务器的cpu、ram_capacity随时间变化的一系列值。
6、账号管理
- 查看账号:show users
- 创建普通账号:create user “username”/username with password ‘password’,貌似创建的普通账号并没有什么数据库操作权限
- 创建管理和账号:create user “username”/username with password ‘password’ with all privileges
- 删除账号:drop user “username”/username
- 设置账号密码:set password for username=’password’
其中,账号支持两种书写方式:英文双引号括起来、直接账号字符串,而密码则必须以英文单引号括起来,否则会出错。
0x02 参考链接
- 系列教程:https://www.linuxdaxue.com/influxdb-study-series-manual.html
- 账号管理:https://blog.csdn.net/u014087707/article/details/52700946
【InfluxDB】InfluxDB学习实践笔记的更多相关文章
- 前端学习实践笔记--JavaScript深入【1】
这一年中零零散散看过几本javascript的书,回过头看之前写过的javascript学习笔记,未免有点汗颜,突出“肤浅”二字,然越深入越觉得javascript的博大精深,有种只缘身在此山中的感觉 ...
- 前端学习实践笔记--JavaScript深入【3】
这章主要讨论闭包和原型,以及面向对象和继承. 闭包 闭包充分利用了JS里面作用域的概念,作用域的好处是内部函数可以访问定义它们的外部函数的参数和变量.使用闭包主要是为了读取函数内部的变量或者将函数内部 ...
- 前端学习实践笔记--JavaScript深入【2】
趁热继续再来学习一波,接下来主要介绍函数,object,数组,面向对象,new实例化. 在介绍“对象”之前,首先得梳妆打扮一番吧,那这梳妆打扮主要有两条路线,一条是淑女范(利用函数对象化),一条是邻家 ...
- hadoop2.5.2学习及实践笔记(二)—— 编译源代码及导入源码至eclipse
生产环境中hadoop一般会选择64位版本,官方下载的hadoop安装包中的native库是32位的,因此运行64位版本时,需要自己编译64位的native库,并替换掉自带native库. 源码包下的 ...
- spring boot +RabbitMQ +InfluxDB+Grafara监控实践
本文需要有相关spring boot 或spring cloud 相关微服务框架的基础,如果您具备相关基础可以很容易的实现下述过程!!!!!!! 希望本文的所说对需要的您有所帮助 从这里我们开始进入闲 ...
- hadoop2.5.2学习及实践笔记(四)—— namenode启动过程源码概览
对namenode启动时的相关操作及相关类有一个大体了解,后续深入研究时,再对本文进行补充 >实现类 HDFS启动脚本为$HADOOP_HOME/sbin/start-dfs.sh,查看star ...
- Influxdb时序数据库阅读笔记
时序数据库 2017年2月Facebook开源了beringei时序数据库:到了4月基于PostgreSQL打造的时序数据库TimeScaleDB也开源了,而早在2016年7月,百度云在其天工物联网平 ...
- influxDB初步学习
influxdb的安装等操作在我的文章. 首先得装influxdb,其次操作如下. application.properties spring.datasource.test1.jdbc-url=jd ...
- ReactNative学习实践--Navigator实践
离上次写RN笔记有一段时间了,期间参与了一个新项目,只在最近的空余时间继续学习实践,因此进度比较缓慢,不过这并不代表没有新进展,其实这个小东西离上次发文时已经有了相当大的变化了,其中影响最大的变化就是 ...
随机推荐
- 分布式文件系统 fastdfs搭建
fastdfs第一步:在home文件夹下建立tar文件夹第二步:cd /home/tar///(Libevent 是一个用C语言编写的.轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( e ...
- 【翻译】Flume 1.8.0 User Guide(用户指南) source
翻译自官网flume1.8用户指南,原文地址:Flume 1.8.0 User Guide 篇幅限制,分为以下5篇: [翻译]Flume 1.8.0 User Guide(用户指南) [翻译]Flum ...
- (24)How generational stereotypes hold us back at work
https://www.ted.com/talks/leah_georges_how_generational_stereotypes_hold_us_back_at_work/transcript ...
- dva-counter
dva实例Counter. import dva, { connect } from 'dva'; import { Router, Route } from 'dva/router'; import ...
- 网络操作系统 第十章 DNS服务器管理与配置
1.什么是域名系统?描述域名解析的过程. 1)域名系统:Domain Name System缩写DNS,是因特网的一项核心服务 域名系统作为可以将域名和IP地址相互映射的一个分布式数据库,能够使人更方 ...
- python的基本数据类型(一)
一.运算符逻辑运算and:两边都真则真or:有真则真not:非假是真 顺序:()>==>not==>and>=or 二.while.. elsewhile 条件: 代码块els ...
- 深入Java集合学习系列:LinkedHashMap的实现原理
参考下面链接: http://zhangshixi.iteye.com/blog/673789
- LVS简单介绍
一.LVS简介 linux virtual server简称LVS,Internet的快速增长使多媒体网络服务器面对的访问数量快速增加,服务器需要具备提供大量并发访问服务的能力,因此对于大负载的服务器 ...
- prim最小生成树
prim和DIjkstra相似,都使用了贪心策略,加一些限制条件. prim每次会找出尽量小的那个边,将其加入到树中,最终使得生成树长大. 树中有n-1个节点时或者剩下的所有边都是INF,算法结束. ...
- git常用的命令行
git管理相关基础命令行,因为现在很多公司都用git管理代码,所以被问及的概率很大,可以用pycharm的git系统,也可以用git代码管理 $git init #初始化仓库$git branch 分 ...