grafana 创建es elasticsearch数据源时,指定了索引index name,但是使用该数据源查询不到数据

个人感觉应该是我 安装的grafana有问题或者grafana这个软件的问题。我在下图index name中输入“metrics-2020-7”,然后按F12,查看grafana发送的_mapping请求发现该请求的index参数竟然不是我设定的metrics-2020-7,而是03trics5-2020-7,所以_mapping请求在es中找不到对应索引,索引_mapping请求失败。这应该是导致后来使用该数据源查询不到任何数据的原因。

解决方法:经过尝试发现将index name设定为“[metrics]-2020-07”,然后按F12查看grafana发送的_mapping请求的请求参数中的索引名为“metrics-2020-07”,正好是我es中的索引名称,这时_mapping请求是成功的,使用该数据源也可以查询出数据。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的实现: 1. 首先需要在pom.xml文件中添加elasticsearch的依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency> ``` 2. 在application.properties中配置elasticsearch的连接信息: ```properties spring.data.elasticsearch.cluster-nodes=localhost:9300 spring.data.elasticsearch.cluster-name=my-application ``` 3. 创建一个Elasticsearch的Repository类: ```java import org.springframework.data.elasticsearch.repository.ElasticsearchRepository; public interface ElasticsearchIndexRepository extends ElasticsearchRepository<Index, String> { Index findByDataSourceIdAndTableName(String dataSourceId, String tableName); } ``` 4. 创建一个Controller类: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RestController; @RestController public class ElasticsearchIndexController { @Autowired private ElasticsearchIndexRepository elasticsearchIndexRepository; @GetMapping("/indices/{dataSourceId}/{tableName}") public Index getIndex(@PathVariable String dataSourceId, @PathVariable String tableName) { return elasticsearchIndexRepository.findByDataSourceIdAndTableName(dataSourceId, tableName); } } ``` 5. Index类需要实现序列化接口,并且需要定义@Document注解: ```java import org.springframework.data.annotation.Id; import org.springframework.data.elasticsearch.annotations.Document; import java.io.Serializable; @Document(indexName = "indices", type = "index") public class Index implements Serializable { @Id private String id; private String dataSourceId; private String tableName; // getters and setters } ``` 6. 运行项目,访问`http://localhost:8080/indices/{dataSourceId}/{tableName}`即可查询对应的索引信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值