[容器化技术] 使用docker-compose搭建doris本地测试环境

环境概述

系统 : mac os
芯片 : m2
芯片架构 : arm64 (可以通过uname -a 来查看)
doris版本 : 1.2.2
docker集群的分布

名称 ip
doris-fe1-01 172.20.80.2
doris-fe1-02 172.20.80.3
doris-fe1-03 172.20.80.4
doris-be1-01 172.20.80.5
doris-fe1-02 172.20.80.6
doris-fe1-03 172.20.80.7

端口
[容器化技术] 使用docker-compose搭建doris本地测试环境_第1张图片

编写docker compose文件

mkdir -p ~/docker/doris_3fe_3be
cd ~/docker/doris_3fe_3be
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License.  You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied.  See the License for the
# specific language governing permissions and limitations
# under the License.
version: '3'
services:
  docker-fe-01:
    image: "apache/doris:1.2.2-fe-arm"
    container_name: "doris-fe-01"
    hostname: "fe-01"
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - FE_ID=1
    ports:
      - 8031:8030
      - 9031:9030
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-01/doris-meta:/opt/apache-doris/fe/doris-meta
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-01/conf:/opt/apache-doris/fe/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-01/log:/opt/apache-doris/fe/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.2
  docker-fe-02:
    image: "apache/doris:1.2.2-fe-arm"
    container_name: "doris-fe-02"
    hostname: "fe-02"
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - FE_ID=2
    ports:
      - 8032:8030
      - 9032:9030
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-02/doris-meta:/opt/apache-doris/fe/doris-meta
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-02/conf:/opt/apache-doris/fe/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-02/log:/opt/apache-doris/fe/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.3
  docker-fe-03:
    image: "apache/doris:1.2.2-fe-arm"
    container_name: "doris-fe-03"
    hostname: "fe-03"
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - FE_ID=3
    ports:
      - 8033:8030
      - 9033:9030
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-03/doris-meta:/opt/apache-doris/fe/doris-meta
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-03/conf:/opt/apache-doris/fe/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/fe-03/log:/opt/apache-doris/fe/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.4
  docker-be-01:
    image: "apache/doris:1.2.2-be-arm"
    container_name: "doris-be-01"
    hostname: "be-01"
    depends_on:
      - docker-fe-01
      - docker-fe-02
      - docker-fe-03
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - BE_ADDR=172.20.80.5:9050
    ports:
      - 8041:8040
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-01/storage:/opt/apache-doris/be/storage
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-01/conf:/opt/apache-doris/be/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-01/script:/docker-entrypoint-initdb.d
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-01/log:/opt/apache-doris/be/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.5
  docker-be-02:
    image: "apache/doris:1.2.2-be-arm"
    container_name: "doris-be-02"
    hostname: "be-02"
    depends_on:
      - docker-fe-01
      - docker-fe-02
      - docker-fe-03
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - BE_ADDR=172.20.80.6:9050
    ports:
      - 8042:8040
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-02/storage:/opt/apache-doris/be/storage
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-02/conf:/opt/apache-doris/be/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-02/script:/docker-entrypoint-initdb.d
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-02/log:/opt/apache-doris/be/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.6
  docker-be-03:
    image: "apache/doris:1.2.2-be-arm"
    container_name: "doris-be-03"
    hostname: "be-03"
    depends_on:
      - docker-fe-01
      - docker-fe-02
      - docker-fe-03
    environment:
      - FE_SERVERS=fe1:172.20.80.2:9010,fe2:172.20.80.3:9010,fe3:172.20.80.4:9010
      - BE_ADDR=172.20.80.7:9050
    ports:
      - 8043:8040
    volumes:
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-03/storage:/opt/apache-doris/be/storage
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-03/conf:/opt/apache-doris/be/conf
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-03/script:/docker-entrypoint-initdb.d
      - /Users/fujunhua/docker/doris_3fe_3be/data/be-03/log:/opt/apache-doris/be/log
    networks:
      doris_net:
        ipv4_address: 172.20.80.7
networks:
  doris_net:
    ipam:
      config:
        - subnet: 172.20.80.0/16

使用

在docker-compose.yaml同级目录下使用命令启动容器

docker-compose up -d

通过浏览器访问 : 127.0.0.1:9031 账号root 密码为空直接回车即可
以下是容器对宿主机映射出来的端口,通过这些端口可以访问到容器内
[容器化技术] 使用docker-compose搭建doris本地测试环境_第2张图片
也可以使用命令行访问,such as

mysql -h 127.0.0.1 -P 9031 -uroot

注意

MacOS 由于内部实现容器的方式不同,在部署时宿主机直接修改 max_map_count 值可能无法成功,需要先创建以下容器:

docker run -it --privileged --pid=host --name=change_count debian nsenter -t 1 -m -u -n -i sh

容器创建成功执行以下命令:
sysctl -w vm.max_map_count=2000000
然后 exit 退出,创建 Doris Docker 集群。
这里是官网的描述 : https://doris.apache.org/zh-CN/docs/dev/install/construct-docker/run-docker-cluster

参考文章

doris 官网 : https://doris.apache.org/


欢迎大家添加我的个人微信,有关大数据的问题群内一起讨论(加微信,备注入群)
微信号:AntgCode

你可能感兴趣的:(docker,doris,docker,doris,arm架构,m2芯片)