报错 blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];ElasticSearch 报错

报错 Caused by: org.elasticsearch.cluster.block.ClusterBlockException: blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];

描述

ElasticSearch 报错 blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];

解决方案

记录一次es报错的解决过程。在kibana中创建es的索引模式,结果点击创建索引模式后页面没有任何跳转。打开浏览器控制台发现实际上在这里是es报错了,返回状态码403,错误信息为。blocked by: [FORBIDDEN/12/index read-only / allow delete (api)];而kibana没有将错误信息提示出来。
尝试解决该报错。根据错误信息,是索引只有只读和删除权限。
执行从网上找到的方案:

curl -XPUT -H ‘Content-Type: application/json’ http://127.0.0.1:9200/_all/_settings -d{
"index": {
"blocks":{
"read_only_allow_delete":"false"
}
}
}

将所有的索引设为非只读删除权限。
再次尝试发现问题解决。然而事情没有这么简单。过了几分钟后创建索引模式发现又报这个错误了。最后发现是因为服务器磁盘剩余空间不足(<5%),es会每隔30S自动将索引设为只读。再清理磁盘空间后解决问题。

文章来源:https://blog.csdn.net/lplwww/article/details/112555838

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这个错误是由于浏览器的同源策略(Same-origin policy)引起的。同源策略要求在进行跨域请求时,服务器必须在响应中添加 `Access-Control-Allow-Origin` 头来明确允许的来源域名,否则浏览器会拒绝该请求。 在这个错误中,你的应用程序试图从 `http://localhost` 的源发起一个跨域请求到 `http://localhost:8080`,但是服务器没有在响应中添加 `Access-Control-Allow-Origin` 头,因此浏览器拒绝了该请求。 要解决这个问题,你需要在服务器端添加 `Access-Control-Allow-Origin` 头来允许来自 `http://localhost` 的跨域请求。具体来说,你可以在服务器端的响应中添加以下头信息: ``` Access-Control-Allow-Origin: http://localhost Access-Control-Allow-Methods: GET, POST, PUT, DELETE Access-Control-Allow-Headers: Content-Type ``` 其中,`Access-Control-Allow-Origin` 指定允许的来源域名,`Access-Control-Allow-Methods` 指定允许的 HTTP 方法,`Access-Control-Allow-Headers` 指定允许的请求头。你可以根据实际需要进行调整。 如果你使用的是 Express 框架,可以使用 `cors` 中间件来简化跨域设置。例如: ```javascript const express = require('express'); const cors = require('cors'); const app = express(); app.use(cors({ origin: 'http://localhost', methods: ['GET', 'POST', 'PUT', 'DELETE'], allowedHeaders: ['Content-Type'] })); // ... 其他路由定义 app.listen(8080); ``` 在这个例子中,我们使用了 `cors` 中间件来设置跨域策略。`origin` 参数指定允许的来源域名,`methods` 参数指定允许的 HTTP 方法,`allowedHeaders` 参数指定允许的请求头。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值