当前位置: 首页 > article >正文

Docker 搭建 Doris

在 Docker 上搭建 Apache Doris 是一个快速部署分布式 SQL 数据库的方式。以下是通过 Docker 安装 Apache Doris 的步骤。

  1. 准备工作
    安装 Docker: 确保 Docker 已经安装并在你的系统中运行。可以通过命令检查 Docker 是否正确安装:
docker --version

安装 Docker Compose (可选): 如果你希望使用 Docker Compose 来管理容器,可以安装它。

  1. 下载 Apache Doris Docker 镜像
    Doris 官方并没有提供 Docker 镜像,因此通常我们使用社区维护的镜像或者自己构建。这里假设使用社区提供的镜像。
    拉取 Doris 镜像:

复制代码

docker pull apachedoris/doris:latest
  1. 启动 Docker 容器
    Apache Doris 需要部署几个关键组件:

FE (Frontend): 负责查询的解析、优化等,是 Doris 的入口。
BE (Backend): 存储数据并执行查询的计算工作。
为了方便起见,我们可以通过 docker-compose 来管理这些服务。

使用 Docker Compose 配置文件
创建 docker-compose.yml 文件:

yaml

version: '3'
services:
  fe:
    image: apachedoris/doris:latest
    container_name: doris-fe
    ports:
      - "8030:8030"    # FE 服务端口
      - "9030:9030"    # FE MySQL 接口端口
      - "8040:8040"    # FE Web UI 端口
    environment:
      - DORIS_ROLE=fe
    volumes:
      - ./data/fe:/opt/apache-doris/fe/doris-meta
    networks:
      - doris-network

  be:
    image: apachedoris/doris:latest
    container_name: doris-be
    ports:
      - "8040:8040"    # BE 端口
      - "9050:9050"    # BE 服务端口
      - "9060:9060"    # BE RPC 端口
    environment:
      - DORIS_ROLE=be
    volumes:
      - ./data/be:/opt/apache-doris/be/storage
    networks:
      - doris-network

networks:
  doris-network:
    driver: bridge

该文件定义了两个服务:FE 和 BE,它们将运行在同一 Docker 网络中。
你可以自定义 volumes 路径用于数据持久化。
4. 启动 Doris 集群
在 docker-compose.yml 文件所在目录,运行以下命令启动集群:

docker-compose up -d
  1. 检查服务状态
    启动完成后,可以通过以下命令检查 FE 和 BE 的状态:
docker ps

FE 服务的 Web UI 可以通过浏览器访问 http://localhost:8040 来查看。FE 的 MySQL 接口也可通过 localhost:9030 连接。

  1. 创建 Doris 数据库
    通过 FE 的 MySQL 接口登录:
mysql -h 127.0.0.1 -P 9030 -uroot

然后可以运行 Doris 的 SQL 命令来创建数据库:

CREATE DATABASE test;
USE test;
CREATE TABLE example_table (
  id INT,
  name VARCHAR(100),
  value DOUBLE
) DISTRIBUTED BY HASH(id) BUCKETS 3
PROPERTIES("replication_num" = "1");

这将在集群中创建一个简单的分布式表。

  1. 停止 Doris
    要停止 Doris 集群,可以使用:
docker-compose down

总结
通过 Docker 部署 Apache Doris,您可以快速构建一个分布式 SQL 数据库环境。你可以根据需要扩展多个 BE 节点以提升计算和存储能力。


http://www.kler.cn/news/359732.html

相关文章:

  • iOS 回到主线程刷新UI
  • 网关Gateway作用介绍和快速入门
  • JAVA安全之命令执行研究分析
  • AWS 实现CI/CD
  • 「iOS」——AFNetworking的简单使用
  • 基于微博评论的自然语言处理情感分析
  • 《IDE 巧用法宝:使用技巧全解析与优质插件推荐》
  • Windows PowerShell 有没有类似conda的虚拟环境功能?
  • 速盾:直播cdn加速原理是什么?
  • 传奇架设GEE引擎数据库服务器提示:拒绝未授权ip连接服务器的解决办法
  • 配置websocket消息代理类AbstractBrokerRegistration
  • LeetCode 每日一题 最小差值 II
  • Vue+TypeScript+SpringBoot的WebSocket基础教学
  • 智慧城管综合管理系统源码,微服务架构,基于springboot、vue+element+uniapp技术开发,支持二次开发
  • 基于Multisim的二阶压控低通滤波器设计与仿真
  • 网络爬虫中的几种数据存储方式(上篇)
  • 体育赛事直播平台开发策略研究:为何开发过程如此艰难?
  • 如何做软件系统的成本估算?
  • Win10 IDEA远程连接HBase
  • APQP在制造行业的应用:搭上数字化项目管理平台很nice