IginX is is a new-generation highly scalable time series database distributed middleware, designed to meet industrial Internet scenarios. It was launched by Tsinghua University's National Engineering Laboratory of Big Data System Software. It currently supports IoTDB,InfluxDB as data backends.
Since ZooKeeper, IginX and IoTDB are all developed using Java, Java needs to be installed first. If a running environment of JDK >= 1.8 has been installed locally, skip this step entirely.
-
First, visit the [official Java website] (https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html) to download the JDK package for your current system.
-
Installation
$ cd ~/Downloads
$ tar -zxf jdk-8u181-linux-x64.gz # unzip files
$ mkdir /opt/jdk
$ mv jdk-1.8.0_181 /opt/jdk/
- Set the path
Edit the ~/.bashrc file and add the following two lines at the end of the file:
export JAVA_HOME = /usr/jdk/jdk-1.8.0_181
export PATH=$PATH:$JAVA_HOME/bin
Load the file with the changed configuration (into shell scripts):
$ source ~/.bashrc
- Use java -version to determine whether JDK installed successfully.
$ java -version
java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)
If the words above are displayed, it means the installation was successful.
Maven is a build automation tool used primarily to build and managa Java projects. If you need to compile from the source code, you also need to install a Maven environment >= 3.6. Otherwise, skip this step entirely.
- Visit the official websiteto download and unzip Maven
$ wget http://mirrors.hust.edu.cn/apache/maven/maven-3/3.3.9/binaries/apache-maven-3.3.9-bin.tar.gz
$ tar -xvf apache-maven-3.3.9-bin.tar.gz
$ sudo mv -f apache-maven-3.3.9 /usr/local/
- Set the path
Edit the ~/.bashrc file and add the following two lines at the end of the file:
export MAVEN_HOME=/usr/local/apache-maven-3.3.9
export PATH=${PATH}:${MAVEN_HOME}/bin
Load the file with the changed configuration (into shell scripts):
$ source ~/.bashrc
- Type mvn -v to determine whether Maven installed successfully.
$ mvn -v
Apache Maven 3.6.1 (d66c9c0b3152b2e69ee9bac180bb8fcc8e6af555; 2019-04-05T03:00:29+08:00)
If the words above are displayed, that means the installation was successful.
Docker provides an official installation script that allows users to automatically install it by entering the command:
$ curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
You can also use the internal daocloud one-click installation command:
$ curl -sSL https://get.daocloud.io/docker | sh
Run this command to start the docker engine and check the docker version:
$ systemctl start docker
$ docker version
If the words above are displayed, it means the installation was successful:
Client: Docker Engine - Community
Version: 20.10.8
API version: 1.41
Go version: go1.16.6
Git commit: 3967b7d
Built: Fri Jul 30 19:55:49 2021
OS/Arch: linux/amd64
Context: default
Experimental: true
Server: Docker Engine - Community
Engine:
Version: 20.10.8
API version: 1.41 (minimum version 1.12)
Go version: go1.16.6
Git commit: 75249d8
Built: Fri Jul 30 19:54:13 2021
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: 1.4.9
GitCommit: e25210fe30a0a703442421b0f60afac609f950a3
runc:
Version: 1.0.1
GitCommit: v1.0.1-0-g4144b63
docker-init:
Version: 0.19.0
GitCommit: de40ad0
Currently, the docker image of IginX needs to be manually installed locally. First, you need to download the Iginx source code and compile it:
$ cd ~
$ git clone [email protected]:thulab/IginX.git # Pull the latest IginX code
$ cd IginX
$ mvn clean install -Dmaven.test.skip=true # Compile IginX
If the words above are displayed, it means the installation was successful:
[INFO] --------------------------------------------------------- -------------------------
[INFO] Reactor Summary for IginX 0.3.0:
[INFO]
[INFO] IginX ................................................ SUCCESS [0.274s]
[INFO] IginX Thrift ............................................... SUCCESS [ 6.484 s]
[INFO] IginX Shared ............................................... SUCCESS [ 1.015 s]
[INFO] IginX Session ............................................... SUCCESS [ 0.713 s]
[INFO] IginX Antlr ............................................... SUCCESS [ 1.654 s]
[INFO] IginX Core ............................................... SUCCESS [ 9.471 s ]
[INFO] IginX IoTDB ................................................ SUCCESS [ 1.234 s]
[INFO] IginX InfluxDB ............................................... SUCCESS [ 0.823 s]
[INFO] IginX Client ............................................... SUCCESS [ 3.045 s]
[INFO] IginX JDBC ............................................... SUCCESS [ 0.802 s ]
[INFO] IginX Example ............................................... SUCCESS [ 0.606 s]
[INFO] IginX Test ............................................... SUCCESS [ 0.116 s ]
[INFO] --------------------------------------------------------- -------------------------
[INFO] BUILD SUCCESS
[INFO] --------------------------------------------------------- -------------------------
[INFO] Total time: 26.432 s
[INFO] Finished at: 2021-08-19T11:06:12+08:00
[INFO] --------------------------------------------------------- -------------------------
Then use the maven plugin to build the IginX image:
$ mvn package shade:shade -pl core -DskipTests docker:build
The following words are displayed to indicate that the image was built successfully:
Successfully tagged iginx:latest
[INFO] Built iginx
[INFO] --------------------------------------------------------- -------------------------
[INFO] BUILD SUCCESS
[INFO] --------------------------------------------------------- -------------------------
[INFO] Total time: 21.268 s
[INFO] Finished at: 2021-08-19T11:08:46+08:00
[INFO] --------------------------------------------------------- -------------------------
You can use the docker command to view the IginX image that has been installed locally:
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
iginx latest 7f00b2b9510b 36 seconds ago 702MB
First you need to pull the IoTDB image from DockerHub:
$ docker pull apache/iotdb:0.11.4
0.11.4: Pulling from apache/iotdb
a076a628af6f: Pull complete
943d8acaac04: Downloading
b9998d19c116: Download complete
8162353a3d61: Waiting
af85646a1131: Waiting
0.11.4: Pulling from apache/iotdb
a076a628af6f: Pull complete
943d8acaac04: Pull complete
b9998d19c116: Pull complete
8162353a3d61: Pull complete
af85646a1131: Pull complete
Digest: sha256:a29a48297e6785ac13abe63b4d06bdf77d50203c13be98b773b2cfb07b76d135
Status: Downloaded newer image for apache/iotdb:0.11.4
docker.io/apache/iotdb:0.11.4
Considering that IginX and IoTDB communicated through the network before, it is necessary to establish a Docker network to allow them to be interconnected through the network. Here we create a bridge network called iot:
$ docker network create -d bridge iot
Now start an IoTDB instance:
$ docker run -d --name iotdb --network iot apache/iotdb:0.11.4
Finally, start IginX, choose to use a local file as the metadata storage backend, and set the backend storage as the IoTDB instance just started to complete the startup of the entire system:
$ docker run -e "metaStorage=file" -e "storageEngineList=iotdb#6667#iotdb#sessionPoolSize=20" -p 6888:6888 --network iot -it iginx
This command will expose the local 6888 port as the communication port to interface with the IginX cluster.
After the system is started, you can run the cn.edu.tsinghua.iginx.session.IoTDBSessionExample class in the example directory of the IginX source code, and try to insert/read data into it.
Parameter settings for the IginX docker version:
Normally, IginX uses a local file as the source of configuration parameters. However, in the latest version of the main branch, environment variables are supported to configure parameters.
For example, the parameter port in the configuration file represents the startup port of the system, which is specified as 6888 in the configuration file. Meaning the port exposed by IginX to the outside world is 6888.
port=6888You can set the environment variable port to other values, such as 6889. In that case, IginX's startup port will be changed to 6889.
export port=6889
Parameters set in environment variables override parameters in the configuration file.
In the Docker environment, the way to change the configuration file is cumbersome, so it is recommended to use the method of setting the Docker container environment variable to configure the system parameters.