如何正确的关闭Elasticsearch集群

如何正确的关闭ElasticSearch集群

背景

接触Elasticsearch也快半年时间了,一直也没弄明白如何的关闭ES和ES集群。经常在测试和生产环境遇到这样的问题“重启ES后数据怎么没了?”,“启动ES后,怎么一直有大量的数据在迁移?”

问题原因

其本质原因有两点:

  • ES中的数据不是实时写入磁盘的。数据进入ES后先进入data buffer和log buffer,然后进入数据段,最后再特定时机下才刷入磁盘。即在内存中有很多数据是没写入磁盘的。
  • ES的自动分片机制。当集群发现经过一分钟后(index.unassigned.node_left.delayed_timeout参数设置)还连接不上某个节点,就会把集群内的数据重新进行分布,即使后来节点重新连接上,原来的数据因为重新分布也无效了。

ES内存数据模型

如何正确的关闭ES或者ES集群

  • 第一步,禁止分片自动分布
PUT _cluster/settings
{
  "persistent": {
    "cluster.routing.allocation.enable": "none"
  }
}
  • 第二步,执行同步刷新
POST _flush/synced
  • 第三步,各节点逐个关闭
# 通过服务关闭
# sudo systemctl stop elasticsearch.service
# 杀进程关闭
kill $(cat pid.txt)

如何启动ES集群

  • 第一步,执行完操作后逐个启动节点
cd $ES_HOME/bin
./elasticsearch -d -p $ES_HOME/pid.txt
  • 第二步,等待所有节点加入集群
    查看集群状态是否为"green"
GET _cat/health

GET _cat/nodes
  • 第三步,启用分片自动分布
PUT _cluster/settings
{
  "persistent": {
    "cluster.routing.allocation.enable": null
  }
}
  • 第四步,等待集群可用
    通过集群的状态和恢复进程监控集群是否可用
GET _cat/health

GET _cat/recovery
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是一段使用 Elasticsearch Java API 编写的三节点 ES 集群代码示例: ``` import org.elasticsearch.client.Client; import org.elasticsearch.client.transport.TransportClient; import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.transport.TransportAddress; import org.elasticsearch.transport.client.PreBuiltTransportClient; import java.net.InetAddress; public class ThreeNodeESCluster { public static void main(String[] args) throws Exception { // 设置集群名称 Settings settings = Settings.builder().put("cluster.name", "my-es-cluster").build(); // 创建一个 TransportClient TransportClient client = new PreBuiltTransportClient(settings); // 添加三个节点 client.addTransportAddress(new TransportAddress(InetAddress.getByName("node1"), 9300)); client.addTransportAddress(new TransportAddress(InetAddress.getByName("node2"), 9300)); client.addTransportAddress(new TransportAddress(InetAddress.getByName("node3"), 9300)); // 关闭客户端连接 client.close(); } } ``` 请注意,在上面的代码中,我们假设您的三个节点分别命名为 `node1`,`node2` 和 `node3`,并且每个节点的 Elasticsearch 实例在 9300 端口上监听。此外,您需要在代码中添加更多的实际操作,以完整使用 ES 集群。 ### 回答2: 编写一个三节点的ES集群代码的例子如下: ``` # 导入必要的模块 from elasticsearch import Elasticsearch # 创建一个ES集群实例 es = Elasticsearch([ {'host': '节点1的IP地址', 'port': '节点1的端口号'}, {'host': '节点2的IP地址', 'port': '节点2的端口号'}, {'host': '节点3的IP地址', 'port': '节点3的端口号'} ]) # 测试连接是否成功 if es.ping(): print("ES集群连接成功!") else: print("ES集群连接失败!") # 示例:创建索引 index_name = "my_index" index_body = { "settings": { "number_of_shards": 1, "number_of_replicas": 1 }, "mappings": { "properties": { "title": {"type": "text"}, "content": {"type": "text"} } } } es.indices.create(index=index_name, body=index_body) print("索引创建成功!") ``` 在这个例子中,我们通过导入`elasticsearch`模块来创建一个ES集群的实例。我们需要指定每个节点的IP地址和端口号来初始化连接。然后,我们可以使用`ping()`方法来测试集群的连接是否成功。 在示例中,我们展示了如何创建一个名为`my_index`的索引。我们使用`create()`方法来指定索引名称和索引的设置和映射。在这里,我们创建了一个只有一个分片和一个副本的索引,并定义了`title`和`content`字段的数据类型。 需要注意的是,这只是一个简单的示例,实际上一个真正的ES集群还需要进行更多的配置和设置,比如使用正确的用户名和密码、配置TLS/SSL等。在实际使用中,还需要根据具体需求来编写更复杂的代码。 ### 回答3: 要编写一个包含三个节点的Elasticsearch集群,可以使用以下代码: ```python from elasticsearch import Elasticsearch from elasticsearch.exceptions import ElasticsearchException # 定义集群节点的主机地址和端口 nodes = [ {'host': 'node1', 'port': 9200}, {'host': 'node2', 'port': 9200}, {'host': 'node3', 'port': 9200} ] try: # 创建一个Elasticsearch集群对象 es = Elasticsearch(hosts=nodes) # 检查集群的健康状态 health = es.cluster.health() if health['status'] == 'green': print("集群健康状态:绿色") elif health['status'] == 'yellow': print("集群健康状态:黄色") elif health['status'] == 'red': print("集群健康状态:红色") # 查看集群中的节点信息 nodes_info = es.nodes.info() for node_id, node_info in nodes_info['nodes'].items(): print("节点ID:", node_id) print("主机名:", node_info['name']) print("协议:", node_info['http_address']) print("IP地址:", node_info['ip']) print() except ElasticsearchException as e: print("连接Elasticsearch集群出错:", e) ``` 这段代码使用elasticsearch-py库来与Elasticsearch集群进行通信。首先,定义了三个节点的主机地址和端口。然后,通过`Elasticsearch`类创建了一个Elasticsearch集群对象,并使用指定的节点进行连接。接下来,使用`cluster.health()`方法获取集群的健康状态,并根据状态输出相应的信息。最后,使用`nodes.info()`方法获取集群中所有节点的信息,并逐个输出每个节点的相关信息。 注意,你需要提前安装elasticsearch-py库(使用`pip install elasticsearch`命令)才能运行以上代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值