自己记录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"

相关推荐
愚者大大19 分钟前
小白入门:GitHub 远程仓库使用全攻略
大数据·elasticsearch·搜索引擎
程序员沉梦听雨2 小时前
【Elasticsearch】DSL 篇
elasticsearch
贵沫末2 小时前
docker-compose——安装redis
redis·docker·eureka
小声读源码9 小时前
【技巧】离线安装docker镜像的方法
docker·镜像·技巧·离线
李匠202413 小时前
C++GO语言微服务之Dockerfile && docker-compose②
c++·容器
斤斤计较14 小时前
Docker 环境安装(2025最新版)
运维·docker·容器
小锋学长生活大爆炸14 小时前
【教程】Docker方式本地部署Overleaf
运维·docker·容器
欧先生^_^14 小时前
Docker 的各种网络模式
网络·docker·容器
掘金者说14 小时前
docker系列-DockerDesktop报错信息(Windows Hypervisor is not present)
运维·docker·容器
我不是秃头sheep19 小时前
Ubuntu 安装 Docker(镜像加速)完整教程
linux·ubuntu·docker