跳转至

Docker Compose部署NebulaGraphGraph

有多种方式可以部署NebulaGraph,但是使用Docker Compose通常是最快的方式。

阅读指南Graph

如果是带着如下问题阅读本文,可以直接单击问题跳转查看对应的说明。

  • Graph
  • Graph
  • Graph
  • Graph
  • Graph
  • Graph

前提条件Graph

  • 主机上安装如下应用程序。
    应用程序 推荐版本 官方安装参考
    Docker 最新版本 Graph
    Docker Compose 最新版本 Graph
    Git 最新版本 Graph
  • 如果使用非root用户部署NebulaGraph,请授权该用户Docker相关的权限。详细信息,请参见Graph。
  • 启动主机上的Docker服务。
  • 如果已经通过Docker Compose在主机上部署了另一个版本的NebulaGraph,为避免兼容性问题,需要删除目录nebula-docker-compose/data

Note

如果需要备份服务数据,请参见Graph TODO: 未和v2.0.1一起发布。

部署和连接NebulaGraphGraph

  1. 通过Git克隆nebula-docker-compose仓库的v2.0.0分支到主机。

    Danger

    master分支包含最新的NebulaGraph开发版本的Docker Compose解决方案。请不要在生产环境使用此版本。

    $ git clone -b v2.0.0 https://github.com/vesoft-inc/nebula-docker-compose.git
    
  2. 切换至目录nebula-docker-compose

    $ cd nebula-docker-compose/
    
  3. 执行如下命令启动NebulaGraph服务。

    Note

    如果长期未更新镜像,请先更新Graph。

    nebula-docker-compose]$ docker-compose up -d
    Creating nebula-docker-compose_metad0_1 ... done
    Creating nebula-docker-compose_metad2_1 ... done
    Creating nebula-docker-compose_metad1_1 ... done
    Creating nebula-docker-compose_graphd2_1   ... done
    Creating nebula-docker-compose_graphd_1    ... done
    Creating nebula-docker-compose_graphd1_1   ... done
    Creating nebula-docker-compose_storaged0_1 ... done
    Creating nebula-docker-compose_storaged2_1 ... done
    Creating nebula-docker-compose_storaged1_1 ... done
    

    Note

    上述服务的更多信息,请参见Graph。

  4. 连接NebulaGraph。

    1. 使用Nebula Console镜像启动一个容器,并连接到NebulaGraph服务所在的网络(nebula-docker-compose_nebula-net)中。

      $ docker run --rm -ti --network nebula-docker-compose_nebula-net --entrypoint=/bin/sh vesoft/nebula-console:v2-nightly
      

      Note

      本地网络可能和示例中的nebula-docker-compose_nebula-net不同,请使用如下命令查看。

      $ docker network  ls
      NETWORK ID          NAME                               DRIVER              SCOPE
      a74c312b1d16        bridge                             bridge              local
      dbfa82505f0e        host                               host                local
      ed55ccf356ae        nebula-docker-compose_nebula-net   bridge              local
      93ba48b4b288        none                               null                local
      
    2. 通过Nebula Console连接NebulaGraph。

      docker> nebula-console -u user -p password --address=graphd --port=9669
      

      Note

      默认情况下,身份认证功能是关闭的,可以使用任意用户名和密码登录。如果想使用身份认证,请参见Graph。

    3. 执行如下命令检查nebula-storaged进程状态。

      nebula> SHOW HOSTS;
      +-------------+------+----------+--------------+----------------------+------------------------+
      | Host        | Port | Status   | Leader count | Leader distribution  | Partition distribution |
      +-------------+------+----------+--------------+----------------------+------------------------+
      | "storaged0" | 9779 | "ONLINE" | 0            | "No valid partition" | "No valid partition"   |
      +-------------+------+----------+--------------+----------------------+------------------------+
      | "storaged1" | 9779 | "ONLINE" | 0            | "No valid partition" | "No valid partition"   |
      +-------------+------+----------+--------------+----------------------+------------------------+
      | "storaged2" | 9779 | "ONLINE" | 0            | "No valid partition" | "No valid partition"   |
      +-------------+------+----------+--------------+----------------------+------------------------+
      | "Total"     |      |          | 0            |                      |                        |
      +-------------+------+----------+--------------+----------------------+------------------------+
      
  5. 执行两次exit 可以退出容器。

查看NebulaGraph服务的状态和端口Graph

执行命令docker-compose ps可以列出NebulaGraph服务的状态和端口。

$ docker-compose ps
Name                     Command                       State                                                   Ports
-------------------------------------------------------------------------------------------------------------------------------------------------------------------
nebula-docker-compose_graphd1_1     ./bin/nebula-graphd --flag ...   Up (health: starting)   13000/tcp, 13002/tcp, 0.0.0.0:33295->19669/tcp, 0.0.0.0:33291->19670/tcp,
                                                                                             3699/tcp, 0.0.0.0:33298->9669/tcp
nebula-docker-compose_graphd2_1     ./bin/nebula-graphd --flag ...   Up (health: starting)   13000/tcp, 13002/tcp, 0.0.0.0:33285->19669/tcp, 0.0.0.0:33284->19670/tcp,
                                                                                             3699/tcp, 0.0.0.0:33286->9669/tcp
nebula-docker-compose_graphd_1      ./bin/nebula-graphd --flag ...   Up (health: starting)   13000/tcp, 13002/tcp, 0.0.0.0:33288->19669/tcp, 0.0.0.0:33287->19670/tcp,
                                                                                             3699/tcp, 0.0.0.0:9669->9669/tcp
nebula-docker-compose_metad0_1      ./bin/nebula-metad --flagf ...   Up (health: starting)   11000/tcp, 11002/tcp, 0.0.0.0:33276->19559/tcp, 0.0.0.0:33275->19560/tcp,
                                                                                             45500/tcp, 45501/tcp, 0.0.0.0:33278->9559/tcp
nebula-docker-compose_metad1_1      ./bin/nebula-metad --flagf ...   Up (health: starting)   11000/tcp, 11002/tcp, 0.0.0.0:33279->19559/tcp, 0.0.0.0:33277->19560/tcp,
                                                                                             45500/tcp, 45501/tcp, 0.0.0.0:33281->9559/tcp
nebula-docker-compose_metad2_1      ./bin/nebula-metad --flagf ...   Up (health: starting)   11000/tcp, 11002/tcp, 0.0.0.0:33282->19559/tcp, 0.0.0.0:33280->19560/tcp,
                                                                                             45500/tcp, 45501/tcp, 0.0.0.0:33283->9559/tcp
nebula-docker-compose_storaged0_1   ./bin/nebula-storaged --fl ...   Up (health: starting)   12000/tcp, 12002/tcp, 0.0.0.0:33290->19779/tcp, 0.0.0.0:33289->19780/tcp,
                                                                                             44500/tcp, 44501/tcp, 0.0.0.0:33294->9779/tcp
nebula-docker-compose_storaged1_1   ./bin/nebula-storaged --fl ...   Up (health: starting)   12000/tcp, 12002/tcp, 0.0.0.0:33296->19779/tcp, 0.0.0.0:33292->19780/tcp,
                                                                                             44500/tcp, 44501/tcp, 0.0.0.0:33299->9779/tcp
nebula-docker-compose_storaged2_1   ./bin/nebula-storaged --fl ...   Up (health: starting)   12000/tcp, 12002/tcp, 0.0.0.0:33297->19779/tcp, 0.0.0.0:33293->19780/tcp,
                                                                                             44500/tcp, 44501/tcp, 0.0.0.0:33300->9779/tcp

NebulaGraph默认使用9669端口为客户端提供服务,如果需要修改端口,请修改目录nebula-docker-compose内的文件docker-compose.yaml,然后重启NebulaGraph服务。

查看NebulaGraph服务的数据和日志Graph

NebulaGraph的所有数据和日志都持久化存储在nebula-docker-compose/datanebula-docker-compose/logs目录中。

目录的结构如下:

nebula-docker-compose/
  |-- docker-compose.yaml
  ├── data
  │   ├── meta0
  │   ├── meta1
  │   ├── meta2
  │   ├── storage0
  │   ├── storage1
  │   └── storage2
  └── logs
      ├── graph
      ├── graph1
      ├── graph2
      ├── meta0
      ├── meta1
      ├── meta2
      ├── storage0
      ├── storage1
      └── storage2

停止NebulaGraph服务Graph

用户可以执行如下命令停止NebulaGraph服务:

$ docker-compose down

如果返回如下信息,表示已经成功停止服务。

Stopping nebula-docker-compose_storaged0_1 ... done
Stopping nebula-docker-compose_graphd1_1   ... done
Stopping nebula-docker-compose_graphd_1    ... done
Stopping nebula-docker-compose_storaged1_1 ... done
Stopping nebula-docker-compose_graphd2_1   ... done
Stopping nebula-docker-compose_storaged2_1 ... done
Stopping nebula-docker-compose_metad0_1    ... done
Stopping nebula-docker-compose_metad2_1    ... done
Stopping nebula-docker-compose_metad1_1    ... done
Removing nebula-docker-compose_storaged0_1 ... done
Removing nebula-docker-compose_graphd1_1   ... done
Removing nebula-docker-compose_graphd_1    ... done
Removing nebula-docker-compose_storaged1_1 ... done
Removing nebula-docker-compose_graphd2_1   ... done
Removing nebula-docker-compose_storaged2_1 ... done
Removing nebula-docker-compose_metad0_1    ... done
Removing nebula-docker-compose_metad2_1    ... done
Removing nebula-docker-compose_metad1_1    ... done
Removing network nebula-docker-compose_nebula-net

Note

命令docker-compose down -v将会删除所有本地NebulaGraph的数据。如果使用的是developing或nightly版本,并且有一些兼容性问题,请尝试这个命令。

常见问题Graph

如何固定Docker映射到外部的端口?Graph

在目录nebula-docker-compose内修改文件docker-compose.yaml,将对应服务的ports设置为固定映射,例如:

graphd:
    image: vesoft/nebula-graphd:v2-nightly
    ...
    ports:
      - 9669:9669
      - 19669
      - 19670

9669:9669表示内部的9669映射到外部的端口也是9669,下方的19669表示内部的19669映射到外部的端口是随机的。

如何更新NebulaGraph服务的Docker镜像?Graph

在目录nebula-docker-compose内执行命令docker-compose pull,可以更新Graph服务、Storage服务和Meta服务的镜像。

执行命令docker-compose pull报错ERROR: toomanyrequestsGraph

可能遇到如下错误:

ERROR: toomanyrequests: You have reached your pull rate limit. You may increase the limit by authenticating and upgrading: https://www.docker.com/increase-rate-limit

以上错误表示已达到Docker Hub的速率限制。解决方案请参见Graph。

如何更新Nebula Console?Graph

执行如下命令可以更新Nebula Console客户端镜像。

docker pull vesoft/nebula-console:v2-nightly

如何升级NebulaGraph?Graph

更新NebulaGraph的Docker镜像并重启服务:

  1. 在目录nebula-docker-compose内,执行命令docker-compose pull更新NebulaGraph的Docker镜像。

  2. 执行命令docker-compose down停止NebulaGraph服务。

  3. 执行命令docker-compose up -d启动NebulaGraph服务。

为什么更新nebula-docker-compose仓库(NebulaGraph 2.0.0-RC)后,无法通过端口3699连接NebulaGraph?Graph

在NebulaGraph 2.0.1-RC版本,默认端口从3699改为9669。请使用9669端口连接,或修改配置文件docker-compose.yaml内的端口。

为什么更新nebula-docker-compose仓库后,无法访问数据?(2021年01月04日)Graph

如果在2021年01月04日后更新过nebula-docker-compose仓库,而且之前已经有数据,请修改文件docker-compose.yaml,将端口修改为之前使用的端口。详情请参见Graph。

为什么更新nebula-docker-compose仓库后,无法访问数据?(2021年01月27日)Graph

2021年01月27日修改了数据格式,无法兼容之前的数据,请执行命令docker-compose down -v删除所有本地数据。

相关文档Graph

  • Graph
  • Graph
  • Graph

最后更新: 2021年7月2日
Back to top