【运维】ElasticSearch部署、查看状态、索引操作
Elasticsearch(后面简称ES)是一个分布式、高扩展、高实时的搜索与数据分析引擎,基于Lucene搜索服务器,它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口1.非root账号也许是处于安全考虑,ElasticSearch默认是禁止使用root启动的,所以我们这里新建一个账户来管理ESuseradd -m elastic# 创建用户echo elastic:12
·
Elasticsearch(后面简称ES)是一个分布式、高扩展、高实时的搜索与数据分析引擎,基于Lucene搜索服务器,它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口
1.非root账号
也许是处于安全考虑,ElasticSearch默认是禁止使用root启动的,所以我们这里新建一个账户来管理ES
useradd -m elastic # 创建用户
echo elastic:12345 | chpasswd # 设置密码
顺便给它设置免密sudo
echo "elastic ALL=(ALL) NOPASSWD:ALL" > /etc/sudoers.d/elastic
chomd 0440 /etc/sudoers.d/elastic
2.安装软件
下载解压
mkdir /data/softs/
cd /data/softs/
# 下载安装包,也可以直接使用其他方式下载然后弄进来
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.3.2-linux-x86_64.tar. gz
mkdir /data/server/ -p
tar -xf elasticsearch-7.3.2-linux-x86_64.tar.gz -C /data/server/
cd /data/server/
ln -s elasticsearch-7.3.2/ elasticsearch
配置环境变量
新建 /etc/profile.d/elastic.sh,输入以下代码
export ELASTIC_HOME=/data/server/elasticsearch
export PATH=$ELASTIC_HOME/bin:$PATH
使生效
su elastic
source /etc/profile.d/elastic.sh
chmod +x /etc/profile.d/elastic.sh
3.配置ES
打开ES解压包里的配置文件进行如下配置
vim elasticsearch/config/elasticsearch.yml
# 设定elasticsearch集群的名称
cluster.name: elastic.mysite.com
# 设定集群master界面的名称
node.name: master.mysite.com
node.master: true
node.data: true
# 设定elasticsearch的存储目录,包括数据目录和日志目录
path.data: /data/server/elasticsearch/data
path.logs: /data/server/elasticsearch/logs
# 允许所有主机都能访问我们的 elasticsearch
network.host: 192.168.203.151 #这是主服务器的IP
# 设置elasticsearch对外的访问端口
http.port: 9200
# 设定主机发现
discovery.seed_hosts: ["master.mysite.com","node.mysite.com"]
cluster.initial_master_nodes: ["master.mysite.com"]
# 开启跨域访问支持,默认为false
http.cors.enabled: true
# 跨域访问允许的域名地址,(允许所有域名)以上使用正则
http.cors.allow-origin: "*"
以上的主服务器的配置, 从服务器 的其他配置一样,但节点不能跟主服务器一样
node.name: node.mysite.com
node.master: false
network.host: 192.168.203.152 # 从服务器的IP
其他配置
# 修改虚拟内存为262144
echo 'vm.max_map_count=262144' > /etc/sysctl.d/elastic.conf
sysctl -p /etc/sysctl.d/elastic.conf
# 因为ES启动的时候对文件描述有限制,所以我们需要设置限制的数量
echo 'elastic - nofile 65536' > /etc/security/limits.d/elastic.conf
# 因为我们在ES的配置文件中指定了数据和日志的目录,所以要先建好
mkdir /data/server/elasticsearch/{data,logs} -p
# 因为我们要基于elastic用户来启动软件,所以需要提前设置相关属性
chown -R elastic:elastic /data/server/elasticsearch
chown -R elastic:elastic /data/server/elasticsearch-7.3.2/
4.启动ES
我们使用elastic账户启动
elasticsearch
或
elasticsearch -d # 后台启动
查看是否启动
netstat -tnulp | grep 9200 # 根据端口查看
curl 192.168.203.151:9200 # 查看返回值
5.简单操作
5.1 查看状态和节点
# 查看健康状态
curl 192.168.203.151:9200/_cat/health?v
# 查看节点
curl 192.168.203.151:9200/_cat/nodes
5.2 索引操作(创建、查看、删除)
创建和查看索引
# 创建索引
curl -XPUT 192.168.203.151:9200/index_test
# 查看索引
curl 192.168.203.151:9200/_cat/indices
# 格式化显示
curl 192.168.203.151:9200/index_test?pretty
删除索引
# 删除索引
curl -XDELETE 192.168.203.151:9200/index_test
# 返回 {"acknowledged":true}
# 查看索引
curl 192.168.203.151:9200/_cat/indices
配置切片属性
curl -X PUT 192.168.203.151:9200/index_test -H 'Content-Type:application/json' -d '{"settings": {"number_of_shards": 3,"number_of_replicas": 1}}'
# number_of_shards:切片数,number_of_replicas:副本数
# 查看效果
curl 192.168.203.151:9200/_cat/indices
curl 192.168.203.151:9200/index_test?pretty
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
已为社区贡献6条内容
所有评论(0)