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

报错信息如下

{
	"index": {
		"_index": "xxxx",
		"_type": "level3_tags",
		"_id": "1042015:park_poi7576987",
		"status": 403,
		"error": {
			"type": "cluster_block_exception",
			"reason": "blocked by: [FORBIDDEN\/12\/index read-only \/ allow delete (api)];"
		}
	}
}

参考

链接: Stack Overflow的提问

修改cluster配置

put http://10.75.13.18:9200/_cluster/settings

{
	"transient": {
		"cluster.routing.allocation.disk.watermark.flood_stage": "98%"
	}
}

修改索引的配置

put http://10.75.13.18:9200/xxx/_settings

{
  "index.blocks.read_only_allow_delete": null
}
这个错误是由于浏览器的同源策略(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` 参数指定允许的请求头。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值