【Docker】宿主机上装个ES和使用docker装个ES有啥不一样

直接在宿主机上安装Elasticsearch

  1. 安装过程:

    • 你需要下载Elasticsearch的二进制包或使用包管理器(如apt、yum等)来安装。
    • 安装过程可能涉及配置文件的编辑、服务的启动和管理等步骤。
  2. 资源管理:

    • Elasticsearch直接运行在宿主机的操作系统上,它直接访问宿主机的资源(如CPU、内存、磁盘等)。
    • 这意味着Elasticsearch的性能直接受宿主机的资源限制。
  3. 隔离性:

    • 直接在宿主机上运行Elasticsearch可能会与其他应用程序共享资源,这可能会影响性能或安全性。
    • 你需要手动配置防火墙规则、用户权限等来确保Elasticsearch的安全性。
  4. 升级维护:

    • 升级Elasticsearch通常需要停止服务、替换二进制文件、重新配置等步骤。
    • 维护和管理Elasticsearch可能需要更多的手动操作。
  5. 配置和数据持久化:

    • 配置文件通常位于宿主机的某个目录中。
    • 数据存储在宿主机上的指定目录中。

在Docker容器中启动Elasticsearch

  1. 安装过程:

    • 你不需要手动下载和安装Elasticsearch,而是使用docker pull命令从Docker Hub或其他镜像仓库下载Elasticsearch的Docker镜像。
    • 使用docker run命令启动Elasticsearch容器。
  2. 资源管理:

    • Docker容器提供了一种轻量级的虚拟化技术,Elasticsearch运行在一个隔离的环境中,它不会直接访问宿主机的资源。
    • 你可以通过Docker命令轻松地设置容器的资源限制(如CPU、内存等)。
  3. 隔离性:

    • Docker容器提供了良好的隔离性,这意味着Elasticsearch与其他容器或宿主机上的应用程序是隔离的。
    • 你可以轻松地为容器设置网络规则、端口映射等,以确保安全性。
  4. 升级维护:

    • 升级Elasticsearch通常只需要拉取最新的镜像并重新启动容器。
    • Docker容器的生命周期管理更加简单和自动化。
  5. 配置和数据持久化:

    • 你可以使用docker run命令中的-v参数将宿主机上的目录挂载到容器内,以实现配置文件和数据的持久化。
    • 这样做可以确保即使容器被删除,配置文件和数据仍然保留在宿主机上。

总结

直接在宿主机上安装Elasticsearch与在Docker容器中启动Elasticsearch的主要区别在于资源管理、隔离性、升级维护和配置数据持久化等方面。

  • 资源管理:

    • 直接在宿主机上安装Elasticsearch会直接使用宿主机的资源。
    • 在Docker容器中启动Elasticsearch则通过容器进行资源管理,提供更好的隔离性。
  • 隔离性:

    • 直接安装可能会与其他应用程序共享资源。
    • Docker容器提供了更好的隔离性。
  • 升级维护:

    • 直接安装通常需要手动操作。
    • Docker容器可以更轻松地进行升级和维护。
  • 配置和数据持久化:

    • 直接安装通常需要手动管理配置文件和数据。
    • Docker容器可以通过挂载宿主机目录来实现配置和数据的持久化。
相关推荐
Elasticsearch24 分钟前
使用 Elastic 实现端到端的大语言模型(LLM)可观测性:洞察生成式 AI 应用这个不透明的世界
elasticsearch
码哝小鱼1 小时前
docker swarm常用命令
java·docker·eureka
gsls2008082 小时前
使用dockerbuildx在x86机器上构建arm版docker镜像
arm开发·docker·容器
終不似少年遊*4 小时前
操作系统、虚拟化技术与云原生及云原生AI简述
docker·ai·云原生·容器·华为云·云计算·k8s
Red丶哞7 小时前
Stitching Together Multiple Input and Output Plugins
elasticsearch
2401_8401922711 小时前
k8s的StorageClass存储类和pv、pvc、provisioner、物理存储的链路
docker·容器·kubernetes
2401_8979300613 小时前
Kibana 连接 Elasticsearch(8.11.3)教程
大数据·elasticsearch·jenkins
小王不会写code15 小时前
Docker安装、配置Redis
redis·docker
SDL大华16 小时前
【备忘】在Docker中安装宝塔面板,实现环境隔离,又能快速迁移服务器环境
服务器·docker·容器
TC139817 小时前
docker 终端打不开rviz2界面,报错qt.qpa.xcb: could not connect to display
docker·容器