通过Dockerfile构建和使用IoTDB

现在,已在分支enable_docker_image上的ROOT / docker / Dockerfile处写入了Dockerfile。

  1. 您可以通过以下方式构建docker映像:
  1. $ docker build -t iotdb:base git://github.com/apache/incubator-iotdb#master:docker

或者:

  1. $ git clone https://github.com/apache/incubator-iotdb
  2. $ cd incubator-iotdb
  3. $ cd docker
  4. $ docker build -t iotdb:base .

一旦在本地构建了docker映像(在此示例中,标签为iotdb:base),您就快完成了!

  1. 为数据文件和日志创建docker卷:
  1. $ docker volume create mydata
  2. $ docker volume create mylogs
  1. 运行一个Docker容器:
  1. $ docker run -p 6667:6667 -v mydata:/iotdb/data -v mylogs:/iotdb/logs -d iotdb:base /iotdb/bin/start-server.sh

如果成功, 你可以跑 docker ps, 并得到如下内容:

  1. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  2. 2a68b6944cb5 iotdb:base "/iotdb/bin/start-se…" 4 minutes ago Up 5 minutes 0.0.0.0:6667->6667/tcp laughing_meitner

您可以使用上面的命令来获取容器ID:

  1. $ docker container ls

假设ID为

并通过以下方式获取docker IP:

  1. $ docker inspect --format='{{.NetworkSettings.IPAddress}}' <C_ID>

假设IP为

  1. 如果您只想尝试使用iotdb-cli,则可以:
  1. $ docker exec -it /bin/bash <C_ID>
  2. $ (now you have enter the container): /cli/sbin/start-client.sh -h localhost -p 6667 -u root -pw root

或者,运行一个新的Docker容器作为客户端:

  1. $ docker run -it iotdb:base /cli/sbin/start-client.sh -h <C_IP> -p 6667 -u root -pw root

或者, 如果您在本地有一个iotdb-cli (e.g., 您已经通过mvn package方式编译了源代码 ), 并假设您的work_dir是cli / bin,那么您可以运行:

  1. $ start-client.sh -h localhost -p 6667 -u root -pw root
  1. 如果要编写代码以插入数据和查询数据,请添加以下依赖项:
  1. <dependency>
  2. <groupId>org.apache.iotdb</groupId>
  3. <artifactId>iotdb-jdbc</artifactId>
  4. <version>0.8.2</version>
  5. </dependency>

可以在以下位置找到有关如何将IoTDB与IoTDB-JDBC一起使用的示例:

示例通过Dockerfile构建和使用IoTDB - 图1

  1. 现在享受吧!