自己记录docker和ES集群

LINUX 安装docker 和ES完全详细过程。

(https://blog.csdn.net/weixin_45844208/article/details/140521002)

安装的docker版本为 26.1.0

https://download.docker.com/linux/static/stable/x86_64/

安装的docker-compose的版本为:2.28.1

https://github.com/docker/compose/releases/download

https://github.com/docker/compose/releases/download/v2.27.1/docker-compose-linux-x86_64

1:上传到服务器然后解压

sudo tar -zxvf docker-26.1.4-x86_64.tgz

2:给权限

sudo chmod 755 -R docker

3:复制到环境变量目录

sudo cp docker/* /usr/bin/

4:配置创建docker服务配置文件docker.service

sudo vim /etc/systemd/system/docker.service

添加如下内容

[Unit]

Description=Docker Application Container Engine

Documentation=https://docs.docker.com

After=network-online.target firewalld.service

Wants=network-online.target

[Service]

Type=notify

ExecStart=/usr/bin/dockerd

ExecReload=/bin/kill -s HUP $MAINPID

TimeoutSec=0

RestartSec=2

ExecStartPost=/usr/sbin/iptables -P FORWARD ACCEPT

Restart=always

TimeoutStartSec=0

LimitNOFILE=infinity

LimitNPROC=infinity

LimitCORE=infinity

Delegate=yes

KillMode=process

StartLimitBurst=3

StartLimitInterval=60s

[Install]

WantedBy=multi-user.target

5:# 赋予docker服务配置文件docker.service执行权限

sudo chmod +x /etc/systemd/system/docker.service

6:docker服务相关命令

加载systemctl配置

sudo systemctl daemon-reload

启用docker服务开机自启动

sudo systemctl enable docker.service

启动docker服务

sudo systemctl start docker

检查docker服务状态

sudo systemctl status docker

查看安装的docker版本

sudo docker -v

查看更改自定义后的docker服务信息

sudo docker info

二:安装docker-compose

复制docker-compose到/usr/local/bin/目录下

sudo cp -f docker-compose-linux-x86_64.v2.28.1 /usr/local/bin/docker-compose

赋予docker-compose可执行权限

sudo chmod +x /usr/local/bin/docker-compose

查看docker-compose版本

sudo docker-compose -v

三:安装部署ES集群

本次安装的ES版本为7.17.25

-1:本次为离线安装,首先需要在有线电脑下载镜像

docker pull docker.elastic.co/elasticsearch/elasticsearch:7.17.25

0:将镜像打包然后上传到服务器

docker save docker.elastic.co/elasticsearch/elasticsearch:7.17.25 -o elasticsearch-7.17.25.tar

0.1:然后在服务器上通过docker加载这个镜像

docker load -i elasticsearch-7.17.25.tar

0.2然后通过docker就可以看大这个镜像了

[root@a_pnw_nginx03 ~]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

docker.elastic.co/elasticsearch/elasticsearch 7.17.25 2574569e84a1 5 weeks ago 634MB

  1. 创建Docker网络
    为了让集群中的各个节点可以互相通信,我们需要先创建一个Docker网络:

docker network create es-network

2编写:docker-compose.yml 内容如下

注意:下面image 的内容就是上面展示镜像REPOSITORY的名字

services:

es01:

image: "docker.elastic.co/elasticsearch/elasticsearch:7.17.25"

container_name: es01

ports:

  • "9200:9200"

  • "9300:9300"

environment:

node.name: es01

discovery.seed_hosts: es01,es02,10.189.131.82:9300,10.189.131.82:9301

cluster.initial_master_nodes: es01,es02,10.189.131.82:9300,10.189.131.82:9301

cluster.name: myescluster

http.cors.enabled: true

http.cors.allow-origin: "*"
ES_JAVA_OPTS: -Xms512m -Xmx512m
xpack.security.enabled: true
ELASTIC_PASSWORD: QAZ2@wsx
volumes:

  • "/usr/local/es_cluster/node_1/data:/usr/share/elasticsearch/data"
  • "/usr/local/es_cluster/node_1/logs:/usr/share/elasticsearch/logs"
  • "/usr/local/es_cluster/node_1/plugins:/usr/share/elasticsearch/plugins"
    networks:
  • es-network
    ulimits:
    memlock:
    soft: -1
    hard: -1
    es02:
    image: "docker.elastic.co/elasticsearch/elasticsearch:7.17.25"
    container_name: es02
    ports:
  • "9201:9200"
  • "9301:9300"
    environment:
    node.name: es02
    discovery.seed_hosts: es01,es02,10.189.131.82:9300,10.189.131.82:9301
    cluster.initial_master_nodes: es01,es02,10.189.131.82:9300,10.189.131.82:9301
    cluster.name: myescluster
    http.cors.enabled: true
    http.cors.allow-origin: "* "

ES_JAVA_OPTS: -Xms512m -Xmx512m

xpack.security.enabled: true

ELASTIC_PASSWORD: QAZ2@wsx

volumes:

  • "/usr/local/es_cluster/node_2/data:/usr/share/elasticsearch/data"

  • "/usr/local/es_cluster/node_2/logs:/usr/share/elasticsearch/logs"

  • "/usr/local/es_cluster/node_2/plugins:/usr/share/elasticsearch/plugins"

networks:

  • es-network

ulimits:

memlock:

soft: -1

hard: -1

networks:

es-network:

driver: bridge

3:服务器创建挂载目录

mkdir -p /usr/local/es_cluster/node_1/data

mkdir -p /usr/local/es_cluster/node_1/logs

mkdir -p /usr/local/es_cluster/node_1/plugins/ik

mkdir -p /usr/local/es_cluster/node_2/data

mkdir -p /usr/local/es_cluster/node_2/logs

mkdir -p /usr/local/es_cluster/node_2/plugins/ik

并给予执行权限

sudo chmod +x /usr/local/es_cluster/

4:下载中文分词器

https://github.com/medcl/elasticsearch-analysis-ik/releases

在这个链接找对应版本的分词器版本。没有就下载当前版本最高的

然后注意 如果分词版本和ES版本不一致需要将分词版本改为一致

分词下载后需要解压到 映射目录

执行

unzip /wls/pansky/elasticsearch-analysis-ik-7.17.6.zip -d /usr/local/es_cluster/node_1/plugins/ik

unzip /wls/pansky/elasticsearch-analysis-ik-7.17.6.zip -d /usr/local/es_cluster/node_2/plugins/ik

然后修改版本号

cd /usr/local/es_cluster/node_1/plugins/ik

vim plugin-descriptor.properties

修改两处地方哦。

改为和ES版本一致的版本号

5:然后在服务新建一个目录单独存放ES的docker-compose.yml

用户名不可以自己定义 是系统默认的 elastic

然后执行:docker-compose up -d

就可以启动成功。

通过 docker ps -a 查看启动情况

如果报错 可以通过 docker-compose up 查看错误原因。

或者 docker logs 服务名字查看日志

docker-compose down

curl -u elastic:QAZ2@wsx -X GET "http://10.190.131.81:9200/_cat/nodes?v"

相关推荐
Dontla6 分钟前
Docker Desktop Engine Stopped原因分析(docker桌面停止)WSL没装或没更新
运维·docker·容器
Java 第一深情1 小时前
Linux上安装单机版Kibana6.8.1
elasticsearch·kibana
小诸葛的博客1 小时前
如何使用docker启动一个gitlab
docker·容器·gitlab
LeonNo112 小时前
ElasticSearch学习了解笔记
笔记·学习·elasticsearch
爱写Bug的小孙2 小时前
docker搭建私有的仓库
java·运维·spring boot·docker·容器
小费的部落2 小时前
记 centos9 安装 docker
docker·容器·eureka
Evenurs2 小时前
【git】取消一个已提交的文件或路径的追踪
大数据·git·elasticsearch
三天不学习3 小时前
Docker 常用命令大全(基础、镜像、容器、数据卷)
docker·容器·eureka
farewell-Calm3 小时前
分布式搜索引擎之elasticsearch单机部署与测试
大数据·分布式·elasticsearch