You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@iotdb.apache.org by hx...@apache.org on 2020/06/17 04:29:08 UTC

svn commit: r40055 - /dev/incubator/iotdb/0.10.0/rc3/

Author: hxd
Date: Wed Jun 17 04:29:07 2020
New Revision: 40055

Log:
preparing rc3 of 0.10.0 of IoTDB

Added:
    dev/incubator/iotdb/0.10.0/rc3/
    dev/incubator/iotdb/0.10.0/rc3/README.md
    dev/incubator/iotdb/0.10.0/rc3/RELEASE_NOTES.md
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip   (with props)
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.asc
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.sha512
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip   (with props)
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.asc
    dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.sha512

Added: dev/incubator/iotdb/0.10.0/rc3/README.md
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/README.md (added)
+++ dev/incubator/iotdb/0.10.0/rc3/README.md Wed Jun 17 04:29:07 2020
@@ -0,0 +1,382 @@
+<!--
+
+    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.
+
+-->
+[English](./README.md) | [中文](./README_ZH.md)
+
+# IoTDB
+[![Build Status](https://www.travis-ci.org/apache/incubator-iotdb.svg?branch=master)](https://www.travis-ci.org/apache/incubator-iotdb)
+[![coveralls](https://coveralls.io/repos/github/apache/incubator-iotdb/badge.svg?branch=master)](https://coveralls.io/repos/github/apache/incubator-iotdb/badge.svg?branch=master)
+[![GitHub release](https://img.shields.io/github/release/apache/incubator-iotdb.svg)](https://github.com/apache/incubator-iotdb/releases)
+[![License](https://img.shields.io/badge/license-Apache%202-4EB1BA.svg)](https://www.apache.org/licenses/LICENSE-2.0.html)
+![](https://github-size-badge.herokuapp.com/apache/incubator-iotdb.svg)
+![](https://img.shields.io/github/downloads/apache/incubator-iotdb/total.svg)
+![](https://img.shields.io/badge/platform-win10%20%7C%20macox%20%7C%20linux-yellow.svg)
+![](https://img.shields.io/badge/java--language-1.8-blue.svg)
+[![IoTDB Website](https://img.shields.io/website-up-down-green-red/https/shields.io.svg?label=iotdb-website)](https://iotdb.apache.org/)
+[![Maven Version](https://maven-badges.herokuapp.com/maven-central/org.apache.iotdb/iotdb-parent/badge.svg)](http://search.maven.org/#search|gav|1|g:"org.apache.iotdb")
+[![Gitpod Ready-to-Code](https://img.shields.io/badge/Gitpod-Ready--to--Code-blue?logo=gitpod)](https://gitpod.io/#https://github.com/apache/incubator-iotdb) 
+
+# Overview
+
+IoTDB (Internet of Things Database) is a data management system for time series data, which can provide users specific services, such as, data collection, storage and analysis. Due to its light weight structure, high performance and usable features together with its seamless integration with the Hadoop and Spark ecology, IoTDB meets the requirements of massive dataset storage, high throughput data input, and complex data analysis in the industrial IoT field.
+
+# Main Features
+
+Main features of IoTDB are as follows:
+
+1. Flexible deployment strategy. IoTDB provides users a one-click installation tool on either the cloud platform or the terminal devices, and a data synchronization tool bridging the data on cloud platform and terminals.
+2. Low cost on hardware. IoTDB can reach a high compression ratio of disk storage.
+3. Efficient directory structure. IoTDB supports efficient organization for complex time series data structure from intelligent networking devices, organization for time series data from devices of the same type, fuzzy searching strategy for massive and complex directory of time series data.
+4. High-throughput read and write. IoTDB supports millions of low-power devices' strong connection data access, high-speed data read and write for intelligent networking devices and mixed devices mentioned above.
+5. Rich query semantics. IoTDB supports time alignment for time series data across devices and measurements, computation in time series field (frequency domain transformation) and rich aggregation function support in time dimension.
+6. Easy to get started. IoTDB supports SQL-Like language, JDBC standard API and import/export tools which is easy to use.
+7. Seamless integration with state-of-the-practice Open Source Ecosystem. IoTDB supports analysis ecosystems such as, Hadoop, Spark, and visualization tool, such as, Grafana.
+
+For the latest information about IoTDB, please visit [IoTDB official website](https://iotdb.apache.org/). If you encounter any problems or identify any bugs while using IoTDB, please report an issue in [jira](https://issues.apache.org/jira/projects/IOTDB/issues).
+
+<!-- TOC -->
+
+## Outline
+
+- Quick Start
+ - Prerequisites
+ - Installation
+    - Build from source
+       - Configurations
+ - Start
+    - Start IoTDB
+    - Use IoTDB
+       - Use Cli
+       - Basic commands for IoTDB
+    - Stop IoTDB
+ - Only build server
+ - Only build cli
+ - Usage of import-csv.sh
+    - Create metadata
+    - An Example of import csv file
+    - Run import shell
+    - Error data file
+ - Usage of export-csv.sh
+    - Run export shell
+    - Input query
+
+<!-- /TOC -->
+
+# Quick Start
+
+This short guide will walk you through the basic process of using IoTDB. For a more detailed introduction, please visit our website's [User Guide](https://iotdb.apache.org/UserGuide/Master/Get%20Started/QuickStart.html).
+
+## Prerequisites
+
+To use IoTDB, you need to have:
+
+1. Java >= 1.8 (1.8, 11, and 13 are verified. Please make sure the environment path has been set accordingly).
+2. Maven >= 3.1 (If you want to compile and install IoTDB from source code).
+3. Set the max open files num as 65535 to avoid "too many open files" error.
+
+## Installation
+
+IoTDB provides three installation methods, you can refer to the following suggestions, choose the one fits you best:
+
+* Installation from source code. If you need to modify the code yourself, you can use this method.
+* Installation from binary files. Download the binary files from the official website. This is the recommended method, in which you will get a binary released package which is out-of-the-box.(Comming Soon...)
+* Using Docker:The path to the dockerfile is https://github.com/apache/incubator-iotdb/tree/master/docker/src/main
+
+
+Here in the Quick Start, we give a brief introduction of using source code to install IoTDB. For further information, please refer to Chapter 3 of the User Guide.
+
+## Build from source
+
+You can download the source code from:
+
+```
+git clone https://github.com/apache/incubator-iotdb.git
+```
+
+The default master branch is the dev branch, If you want to use a released version x.x.x:
+
+```
+git checkout release/x.x.x
+```
+
+
+Under the root path of incubator-iotdb:
+
+```
+> mvn clean package -DskipTests
+```
+
+Then the binary version (including both server and cli) can be found at **distribution/target/apache-iotdb-{project.version}-incubating-bin.zip**
+
+> NOTE: Directories "service-rpc/target/generated-sources/thrift" and "server/target/generated-sources/antlr4" need to be added to sources roots to avoid compilation errors in the IDE.
+
+### Configurations
+
+configuration files are under "conf" folder
+
+  * environment config module (`iotdb-env.bat`, `iotdb-env.sh`),
+  * system config module (`iotdb-engine.properties`)
+  * log config module (`logback.xml`).
+
+For more information, please see [Chapter3: Server](https://iotdb.apache.org/#/Documents/progress/chap3/sec1) and [Chapter4: Client](https://iotdb.apache.org/#/Documents/progress/chap4/sec1) in detail.
+
+## Start
+
+You can go through the following steps to test the installation, if there is no error returned after execution, the installation is completed.
+
+### Start IoTDB
+
+Users can start IoTDB by the start-server script under the sbin folder.
+
+```
+# Unix/OS X
+> nohup sbin/start-server.sh >/dev/null 2>&1 &
+or
+> nohup sbin/start-server.sh -c <conf_path> -rpc_port <rpc_port> >/dev/null 2>&1 &
+
+# Windows
+> sbin\start-server.bat -c <conf_path> -rpc_port <rpc_port>
+```
+
+- "-c" and "-rpc_port" are optional.
+- option "-c" specifies the system configuration file directory.
+- option "-rpc_port" specifies the rpc port.
+- if both option specified, the *rpc_port* will overrides the rpc_port in *conf_path*.
+
+
+### Use IoTDB
+
+#### Use Cli
+
+IoTDB offers different ways to interact with server, here we introduce the basic steps of using Cli tool to insert and query data.
+
+After installing IoTDB, there is a default user 'root', its default password is also 'root'. Users can use this
+default user to login Cli to use IoTDB. The startup script of Cli is the start-cli script in the folder sbin. When executing the script, user should assign
+IP, PORT, USER_NAME and PASSWORD. The default parameters are "-h 127.0.0.1 -p 6667 -u root -pw -root".
+
+Here is the command for starting the Cli:
+
+```
+# Unix/OS X
+> sbin/start-cli.sh -h 127.0.0.1 -p 6667 -u root -pw root
+
+# Windows
+> sbin\start-cli.bat -h 127.0.0.1 -p 6667 -u root -pw root
+```
+
+The command line cli is interactive, so you should see the welcome logo and statements if everything is ready:
+
+```
+ _____       _________  ______   ______
+|_   _|     |  _   _  ||_   _ `.|_   _ \
+  | |   .--.|_/ | | \_|  | | `. \ | |_) |
+  | | / .'`\ \  | |      | |  | | |  __'.
+ _| |_| \__. | _| |_    _| |_.' /_| |__) |
+|_____|'.__.' |_____|  |______.'|_______/  version x.x.x
+
+
+IoTDB> login successfully
+IoTDB>
+```
+
+#### Basic commands for IoTDB
+
+Now, let us introduce the way of creating timeseries, inserting data and querying data.
+
+The data in IoTDB is organized as timeseries. Each timeseries includes multiple data-time pairs, and is owned by a storage group. Before defining a timeseries, we should define a storage group using SET STORAGE GROUP first, and here is an example:
+
+```
+IoTDB> SET STORAGE GROUP TO root.ln
+```
+
+We can also use SHOW STORAGE GROUP to check the storage group being created:
+
+```
+IoTDB> SHOW STORAGE GROUP
++-----------------------------------+
+|                      Storage Group|
++-----------------------------------+
+|                            root.ln|
++-----------------------------------+
+storage group number = 1
+```
+
+After the storage group is set, we can use CREATE TIMESERIES to create a new timeseries. When creating a timeseries, we should define its data type and the encoding scheme. Here We create two timeseries:
+
+```
+IoTDB> CREATE TIMESERIES root.ln.wf01.wt01.status WITH DATATYPE=BOOLEAN, ENCODING=PLAIN
+IoTDB> CREATE TIMESERIES root.ln.wf01.wt01.temperature WITH DATATYPE=FLOAT, ENCODING=RLE
+```
+
+In order to query the specific timeseries, we can use SHOW TIMESERIES <Path>. <Path> represent the location of the timeseries. The default value is "null", which queries all the timeseries in the system(the same as using "SHOW TIMESERIES root"). Here are some examples:
+
+1. Querying all timeseries in the system:
+
+```
+IoTDB> SHOW TIMESERIES
++-------------------------------+---------------+--------+--------+
+|                     Timeseries|  Storage Group|DataType|Encoding|
++-------------------------------+---------------+--------+--------+
+|       root.ln.wf01.wt01.status|        root.ln| BOOLEAN|   PLAIN|
+|  root.ln.wf01.wt01.temperature|        root.ln|   FLOAT|     RLE|
++-------------------------------+---------------+--------+--------+
+Total timeseries number = 2
+```
+
+2. Querying a specific timeseries(root.ln.wf01.wt01.status):
+
+```
+IoTDB> SHOW TIMESERIES root.ln.wf01.wt01.status
++------------------------------+--------------+--------+--------+
+|                    Timeseries| Storage Group|DataType|Encoding|
++------------------------------+--------------+--------+--------+
+|      root.ln.wf01.wt01.status|       root.ln| BOOLEAN|   PLAIN|
++------------------------------+--------------+--------+--------+
+Total timeseries number = 1
+```
+
+Insert timeseries data is a basic operation of IoTDB, you can use ‘INSERT’ command to finish this. Before insertion, you should assign the timestamp and the suffix path name:
+
+```
+IoTDB> INSERT INTO root.ln.wf01.wt01(timestamp,status) values(100,true);
+IoTDB> INSERT INTO root.ln.wf01.wt01(timestamp,status,temperature) values(200,false,20.71)
+```
+
+The data that you have just inserted will display as follows:
+
+```
+IoTDB> SELECT status FROM root.ln.wf01.wt01
++-----------------------+------------------------+
+|                   Time|root.ln.wf01.wt01.status|
++-----------------------+------------------------+
+|1970-01-01T08:00:00.100|                    true|
+|1970-01-01T08:00:00.200|                   false|
++-----------------------+------------------------+
+Total line number = 2
+```
+
+You can also query several timeseries data using one SQL statement:
+
+```
+IoTDB> SELECT * FROM root.ln.wf01.wt01
++-----------------------+--------------------------+-----------------------------+
+|                   Time|  root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
++-----------------------+--------------------------+-----------------------------+
+|1970-01-01T08:00:00.100|                      true|                         null|
+|1970-01-01T08:00:00.200|                     false|                        20.71|
++-----------------------+--------------------------+-----------------------------+
+Total line number = 2
+```
+
+The commands to exit the Cli are:
+
+```
+IoTDB> quit
+or
+IoTDB> exit
+```
+
+For more information about the commands supported by IoTDB SQL, please see [Chapter 5: IoTDB SQL Documentation](https://iotdb.apache.org/#/Documents/0.10.0/chap5/sec1).
+
+### Stop IoTDB
+
+The server can be stopped with "ctrl-C" or the following script:
+
+```
+# Unix/OS X
+> sbin/stop-server.sh
+
+# Windows
+> sbin\stop-server.bat
+```
+
+## Only build server
+
+Under the root path of incubator-iotdb:
+
+```
+> mvn clean package -pl server -am -DskipTests
+```
+
+After being built, the IoTDB server is located at the folder: "server/target/iotdb-server-{project.version}".
+
+
+## Only build cli
+
+Under the root path of incubator-iotdb:
+
+```
+> mvn clean package -pl cli -am -DskipTests
+```
+
+After being built, the IoTDB cli is located at the folder "cli/target/iotdb-cli-{project.version}".
+
+## Usage of import-csv.sh
+
+### Create metadata
+```
+SET STORAGE GROUP TO root.fit.d1;
+SET STORAGE GROUP TO root.fit.d2;
+SET STORAGE GROUP TO root.fit.p;
+CREATE TIMESERIES root.fit.d1.s1 WITH DATATYPE=INT32,ENCODING=RLE;
+CREATE TIMESERIES root.fit.d1.s2 WITH DATATYPE=TEXT,ENCODING=PLAIN;
+CREATE TIMESERIES root.fit.d2.s1 WITH DATATYPE=INT32,ENCODING=RLE;
+CREATE TIMESERIES root.fit.d2.s3 WITH DATATYPE=INT32,ENCODING=RLE;
+CREATE TIMESERIES root.fit.p.s1 WITH DATATYPE=INT32,ENCODING=RLE;
+```
+
+### An example of import csv file
+
+```
+Time,root.fit.d1.s1,root.fit.d1.s2,root.fit.d2.s1,root.fit.d2.s3,root.fit.p.s1
+1,100,'hello',200,300,400
+2,500,'world',600,700,800
+3,900,'IoTDB',1000,1100,1200
+```
+
+### Run import shell
+```
+# Unix/OS X
+> tools/import-csv.sh -h <ip> -p <port> -u <username> -pw <password> -f <xxx.csv>
+
+# Windows
+> tools\import-csv.bat -h <ip> -p <port> -u <username> -pw <password> -f <xxx.csv>
+```
+
+### Error data file
+
+`csvInsertError.error`
+
+## Usage of export-csv.sh
+
+### Run export shell
+```
+# Unix/OS X
+> tools/export-csv.sh -h <ip> -p <port> -u <username> -pw <password> -td <directory> [-tf <time-format>]
+
+# Windows
+> tools\export-csv.bat -h <ip> -p <port> -u <username> -pw <password> -td <directory> [-tf <time-format>]
+```
+
+### Input query
+
+```
+select * from root.fit.d1
+```

Added: dev/incubator/iotdb/0.10.0/rc3/RELEASE_NOTES.md
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/RELEASE_NOTES.md (added)
+++ dev/incubator/iotdb/0.10.0/rc3/RELEASE_NOTES.md Wed Jun 17 04:29:07 2020
@@ -0,0 +1,475 @@
+<!--
+
+    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.
+
+-->
+
+# Apache IoTDB (incubating) 0.10.0
+
+## New Features
+
+* IOTDB-217 A new GROUPBY syntax, e.g., select avg(s1) from root.sg.d1.s1 GROUP BY ([1, 50), 5ms)
+* IOTDB-220 Add hot-load configuration function
+* IOTDB-275 allow using user defined JAVA_HOME and allow blank space in the JAVA_HOME
+* IOTDB-287 Allow domain in JDBC URL
+* IOTDB-292 Add load external tsfile feature
+* IOTDB-297 Support "show flush task info"
+* IOTDB-298 Support new Last point query. e.g, select last * from root
+* IOTDB-305 Add value filter function while executing align by device
+* IOTDB-309 add Dockerfiles for 0.8.1, 0.9.0, and 0.9.1
+* IOTDB-313 Add RandomOnDiskUsableSpaceStrategy
+* IOTDB-323 Support insertRecords in session
+* IOTDB-337 Add timestamp precision properties for grafana
+* IOTDB-343 Add test method in session
+* IOTDB-396 Support new query clause: disable align, e.g., select * from root disable align
+* IOTDB-447 Support querying non-existing measurement and constant measurement
+* IOTDB-448 Add IN operation, e.g., where time in (1,2,3)
+* IOTDB-456 Support GroupByFill Query, e.g., select last_value(s1) from root.sg.d1 GROUP BY ([1, 10), 2ms) FILL(int32[previousUntilLast])
+* IOTDB-467 The CLI displays query results in a batch manner
+* IOTDB-497 Support Apache Flink Connector with IoTDB
+* IOTDB-558 add text support for grafana
+* IOTDB-560 Support Apache Flink connecter with TsFile
+* IOTDB-565 MQTT Protocol Support, disabled by default, open in iotdb-engine.properties
+* IOTDB-574 Specify configuration when start iotdb
+* IOTDB-588 Add tags and attributes management
+* IOTDB-607 add batch create timeseries in native interface
+* IOTDB-612 add limit&offset to show timeseries
+* IOTDB-615 Use TsDataType + Binary to replace String in insert plan
+* IOTDB-617 Support alter one time series's tag/attribute
+* IOTDB-630 Add a jdbc-like way to fetch data in session
+* IOTDB-640 Enable system admin sql (flush/merge) in JDBC or Other API
+* IOTDB-671 Add clear cache command
+* Support open and close time range in group by, e.g, [), (]
+* Online upgrade from 0.9.x
+* Support speical characters in path: -/+&%$#@
+* IOTDB-446 Support path start with a digit, e.g., root.sg.12a
+* enable rpc compression in session pool
+* Make JDBC OSGi usable and added a feature file
+* add printing one resource file tool
+* Allow count timeseries group by level=x using default path
+* IOTDB-700 Add OpenID Connect based JWT Access as alternative to Username / Password
+* IOTDB-701 Set heap size by percentage of system total memory when starts
+* IOTDB-708 add config for inferring data type from string value
+* IOTDB-715 Support previous time range in previousuntillast
+* IOTDB-719 add avg_series_point_number_threshold in config
+* IOTDB-731 Continue write inside InsertPlan 
+* IOTDB-734 Add Support for NaN in Double / Floats in SQL Syntax.
+* IOTDB-744 Support upsert alias 
+
+
+## Incompatible changes
+
+* IOTDB-138 Move All metadata query to usual query
+* IOTDB-322 upgrade to thrift 0.12.0-0.13.0
+* IOTDB-325 Refactor Statistics in TsFile
+* IOTDB-419 Refactor the 'last' and 'first' aggregators to 'last_value' and 'first_value'
+* IOTDB-506 upgrade the rpc protocol to v2 to reject clients or servers that version < 0.10
+* IOTDB-587 TsFile is upgraded to version 2
+* IOTDB-593 add metaOffset in TsFileMetadata
+* IOTDB-597 Rename methods in Session: insertBatch to insertTablet, insertInBatch to insertRecords, insert to insertRecord
+* RPC is incompatible, you can not use client-v0.9 to connect with server-v0.10
+* TsFile format is incompatible, will be upgraded when starting 0.10
+* Refine exception code in native api
+
+## Miscellaneous changes
+
+* IOTDB-190 upgrade from antlr3 to antlr4
+* IOTDB-418 new query engine
+* IOTDB-429 return empty dataset instead of throw exception, e.g., show child paths root.*
+* IOTDB-445 Unify the keyword of "timestamp" and "time"
+* IOTDB-450 Add design documents
+* IOTDB-498 Support date format "2020-02-10"
+* IOTDB-503 Add checkTimeseriesExists in java native api
+* IOTDB-605 Add more levels of index in TsFileMetadata for handling too many series in one device
+* IOTDB-625 Change default level number: root is level 0
+* IOTDB-628 rename client to cli
+* IOTDB-621 Add Check isNull in Field for querying using session
+* IOTDB-632 Performance improve for PreviousFill/LinearFill
+* IOTDB-695 Accelerate the count timeseries query 
+* IOTDB-707 Optimize TsFileResource memory usage  
+* IOTDB-730 continue write in MQTT when some events are failed
+* IOTDB-729 shutdown uncessary threadpool 
+* IOTDB-733 Enable setting for mqtt max length 
+* IOTDB-732 Upgrade fastjson version to 1.2.70
+* Allow "count timeseries" without a prefix path
+* Add max backup log file number
+* add rpc compression api in client and session module
+* Continue writing the last unclosed file
+* Move the vulnera-checks section into the apache-release profile to accelerate compile
+* Add metaquery in python example
+* Set inferType of MQTT InsertPlan to true
+
+
+
+## Bug Fixes
+
+* IOTDB-125 Potential Concurrency bug while deleting and inserting happen together
+* IOTDB-185 fix start-client failed on WinOS if there is blank space in the file path; let start-server.bat suport jdk12,13 etc
+* IOTDB-304 Fix bug of incomplete HDFS URI
+* IOTDB-341 Fix data type bug in grafana
+* IOTDB-346 Fix a bug of renaming tsfile in loading function
+* IOTDB-370 fix a concurrent problem in parsing sql
+* IOTDB-376 fix metric to show executeQuery
+* IOTDB-392 fix export CSV
+* IOTDB-393 Fix unclear error message for no privilege users
+* IOTDB-401 Correct the calculation of a chunk if there is no data in the chunk, do not flush empty chunk
+* IOTDB-412 Paths are not correctly deduplicated
+* IOTDB-420 Avoid encoding task dying silently
+* IOTDB-425 fix can't change the root password.
+* IOTDB-459 Fix calmem tool bug
+* IOTDB-470fix IllegalArgumentException when there exists 0 byte TsFile
+* IOTDB-529 Relative times and NOW() operator cannot be used in Group By
+* IOTDB-531 fix issue when grafana visualize boolean data
+* IOTDB-546 Fix show child paths statement doesn't show quotation marks
+* IOTDB-643 Concurrent queries cause BufferUnderflowException when storage in HDFS
+* IOTDB-663 Fix query cache OOM while executing query
+* IOTDB-664 Win -e option
+* IOTDB-669 fix getting two columns bug while "show devices" in session
+* IOTDB-692 merge behaves incorrectly
+* IOTDB-712 Meet BufferUnderflowException and can not recover
+* IOTDB-718 Fix wrong time precision of NOW()
+* IOTDB-735 Fix Concurrent error for MNode when creating time series automatically 
+* IOTDB-738 Fix measurements has blank 
+
+* fix concurrent auto create schema conflict bug
+* fix meet incompatible file error in restart
+* Fix bugs of set core-site.xml and hdfs-site.xml paths in HDFS storage
+* fix execute flush command while inserting bug
+* Fix sync schema pos bug
+* Fix batch execution bug, the following sqls will all fail after one error sql
+* Fix recover endTime set bug
+
+
+# Apache IoTDB (incubating) 0.9.3
+
+## Bug Fixes
+- IOTDB-531 Fix that JDBC URL does not support domain issue
+- IOTDB-563 Fix pentaho cannot be downloaded because of spring.io address
+- IOTDB-608 Skip error Mlog
+- IOTDB-634 Fix merge caused errors for TsFile storage in HDFS
+- IOTDB-636 Fix Grafana connector does not use correct time unit
+
+## Miscellaneous changes
+- IOTDB-528 Modify grafana group by
+- IOTDB-635 Add workaround when doing Aggregation over boolean Series
+- Remove docs of Load External Tsfile
+- Add Grafana IoTDB Bridge Artifact to distribution in tools/grafana folder
+
+
+# Apache IoTDB (incubating) 0.9.2
+
+## Bug Fixes
+- IOTDB-553 Fix Return Empty ResultSet when queried series doesn't exist
+- IOTDB-575 add default jmx user and password; fix issues that jmx can't be accessed remotely
+- IOTDB-584 Fix InitializerError when recovering files on HDFS
+- Fix batch insert once an illegal sql occurs all the sqls after that will not succeed
+- Fix concurrent modification exception when iterator TsFileResourceList 
+- Fix some HDFS config issues 
+- Fix runtime exception not catched and sync schema pos was nullpointer bug in DataTransferManager
+- Fix python rpc grammar mistakes
+- Fix upgrade ConcurrentModificationException
+
+## Miscellaneous changes
+- IOTDB-332 support Chinese characters in path
+- IOTDB-316 add AVG function to 4-SQL Reference.md and modify style 
+- improve start-server.bat by using quotes to protect against empty entries
+- Add Chinese documents for chapter 4.2
+- change download-maven-plugin to 1.3.0
+- add session pool 
+- add insertInBatch in Session
+- add insertInBatch to SessionPool
+- modify 0.9 docs to fit website
+- remove tsfile-format.properties
+- add bloom filter in iotdb-engien.properties
+- update server download doc
+- typos fix in Rel/0.9 docs
+- support 0.12.0 and 0.13.0 thrift
+
+# Apache IoTDB (incubating) 0.9.1
+
+## Bug Fixes
+
+- IOTDB-159 Fix NullPointerException in SeqTsFileRecoverTest and UnseqTsFileRecoverTest
+- IOTDB-317 Fix a bug that "flush + wrong aggregation query" causes the following queries to fail
+- IOTDB-324 Fix inaccurate statistics when writing in batch
+- IOTDB-327 Fix a groupBy-without-value-filter query bug caused by the wrong page skipping logic
+- IOTDB-331 Fix a groupBy query bug when axisOrigin-startTimeOfWindow is an integral multiple of interval
+- IOTDB-357 Fix NullPointerException in ActiveTimeSeriesCounter
+- IOTDB-359 Fix a wrong-data-type bug in TsFileSketchTool
+- IOTDB-360 Fix bug of a deadlock in CompressionRatio
+- IOTDB-363 Fix link errors in Development-Contributing.md and add Development-Document.md
+- IOTDB-392 Fix a bug in CSV export tool
+- Fix apache rat header format error in some files
+
+## Miscellaneous changes
+
+- IOTDB-321 Add definitions of time expression and LEVEL in related documents
+- Support pypi distribution for Python client
+
+# Apache IoTDB (incubating) 0.9.0
+
+## New Features
+
+* IOTDB-143 Compaction of data file
+* IOTDB-151 Support number format in timeseries path
+* IOTDB-158 Add metrics web service
+* IOTDB-173 Add batch write interface in session
+* IoTDB-174 Add interfaces for querying device or timeseries number
+* IOTDB-187 Enable to choose storage in local file system or HDFS
+* IOTDB-188 Delete storage group
+* IOTDB-193 Create schema automatically when inserting
+* IOTDB-198 Add sync module (Sync TsFiles between IoTDB instances)
+* IOTDB-199 Add a log visualization tool 
+* IOTDB-203 Add "group by device" function for narrow table display
+* IOTDB-205 Support storage-group-level Time To Live (TTL)
+* IOTDB-208 Add Bloom filter in TsFile
+* IOTDB-223 Add a TsFile sketch tool
+* IoTDB-226 Hive-TsFile connector
+* IOTDB-239 Add interface for showing devices
+* IOTDB-241 Add query and non query interface in session
+* IOTDB-249 Enable lowercase in create_timeseries sql
+* IOTDB-253 Support time expression 
+* IOTDB-259 Level query of path
+* IOTDB-282 Add "show version"
+* IOTDB-294 Online upgrade from 0.8.0 to 0.9.0
+* Spark-iotdb-connector
+* Support quoted measurement name
+* Generate cpp, go, and python thrift files under service-rpc
+* Display cache hit rate through jconsole
+* Support inserting data that time < 0
+* Add interface (Delete timeseries) in session 
+* Add a tool to print tsfileResources (each device's start and end time)
+* Support watermark feature
+* Add micro and nano timestamp precision
+
+## Incompatible changes
+
+* RPC is incompatible, you can not use client-0.8.0 to connect with server-0.9.0 or use client-0.9.0 to connect with server-0.8.0.
+* Server is backward compatible, server-0.9.0 could run on data folder of 0.8.0. The data file will be upgraded background.
+* Change map key in TsDigest from String to enum data type
+
+## Miscellaneous changes
+
+* IOTDB-144 Meta data cache for query
+* IOTDB-153 Further limit fetchSize to speed up LIMIT&OFFSET query
+* IOTDB-160 External sort
+* IOTDB-161 Add ErrorCode of different response errors
+* IOTDB-180 Get rid of JSON format in "show timeseries"
+* IOTDB-192 Improvement for LRUCache
+* IOTDB-210 One else if branch will never be reached in the method optimize of ExpressionOptimizer
+* IOTDB-215 Update TsFile sketch tool and TsFile docs for v0.9.0
+* IOTDB-221 Add a python client example
+* IOTDB-233 keep metadata plan clear
+* IOTDB-251 Improve TSQueryDataSet structure in RPC
+* IOTDB-257 Makes the client stop fetch when dataSize equals maxPrintRowCount and change client fetchSize less than maxPrintRowCount
+* IOTDB-258 Add documents for Query History Visualization Tool and Shared Storage Architecture
+* IOTDB-265 Re-adjust the threshold size of memtable
+* IOTDB-267 Reduce IO operations in deserializing chunk header
+* IOTDB-273 Parallel recovery
+* IOTDB-276 Fix inconsistent ways of judging whether a Field is null
+* IOTDB-285 Duplicate fields in EngineDataSetWithoutValueFilter.java
+* IOTDB-287 Restrict users to only use domain names and IP addresses.
+* IOTDB-293 Variable naming convention
+* IOTDB-295 Refactor db.exception
+* Reconstruct Antlr3 grammar to improve performance
+* Tooling for release
+* Modified Decoder and SequenceReader to support old version of TsFile 
+* Remove jdk constrain of jdk8 and 11
+* Modify print function in AbstractClient
+* Avoid second execution of parseSQLToPhysicalPlan in executeStatement
+
+## Known Issues
+
+* IOTDB-20 Need to support UPDATE
+
+## Bug Fixes
+
+* IOTDB-168&169 Fix a bug in export-csv tool and fix compatibility of timestamp formats in exportCsv, client display and sql
+* IOTDB-174 Fix querying timeseries interface cannot make a query by the specified path prefix
+* IOTDB-195 Using String.getBytes(utf-9).length to replace string.length() in ChunkGroupMetadata for supporting Chinese
+* IOTDB-211 Use "%IOTDB_HOME%\lib\*" to refers to all .jar files in the directory in start-server.bat
+* IOTDB-240 Fix unknown time series in where clause
+* IOTDB-244 Fix bug when querying with duplicated columns
+* IOTDB-252 Add/fix shell and bat for TsFileSketchTool/TsFileResourcePrinter
+* IOTDB-266 NullPoint exception when reading not existed devices using ReadOnlyTsFile
+* IOTDB-264 Restart failure due to WAL replay error
+* IOTDB-290 Bug about threadlocal field in TSServiceImpl.java
+* IOTDB-291 Statement close operation may cause the whole connection's resource to be released
+* IOTDB-296 Fix error when skip page data in sequence reader
+* IOTDB-301 Bug Fix: executing "count nodes root" in client gets "Msg:3"
+* Fix Dynamic Config when Creating Existing SG or Time-series
+* Fix start-walchecker scripts for letting user define the wal folder
+* Fix start script to set JAVA_HOME
+
+# Apache IoTDB (incubating) 0.8.2
+
+ This is a bug-fix version of 0.8.1 
+
+-  IOTDB-264 lack checking datatype before writing WAL 
+-  IOTDB-317 Fix "flush + wrong aggregation" causes failed query in v0.8.x 
+-  NOTICE and LICENSE file update 
+
+# Apache IoTDB (incubating) 0.8.1
+
+This is a bug-fix version of 0.8.0
+
+* IOTDB-172 Bug in updating startTime and endTime in TsFileResource
+* IOTDB-195 Bug about 'serializedSize' in ChunkGroupMetaData.java (for Chinese string)
+* IOTDB-202 fix tsfile example data type
+* IOTDB-242 fix mvn integration-test failed because the files in the target folder changes
+* Abnormal publishing of sequence and unsequence data folders in DirectoryManager
+* Fix a bug in TimeRange's intersects function
+
+
+# Apache IoTDB (incubating) 0.8.0
+
+This is the first official release of Apache IoTDB after joining the Incubator.
+
+## New Features
+
+* IOTDB-1 Add Aggregation query
+* IOTDB-4 Asynchronously force sync WAL periodically
+* IOTDB-5 Support data deletion
+* IOTDB-11 Support start script for jdk 11 on Windows OS
+* IOTDB-18 Improve startup script compatible for jdk11
+* IOTDB-36 [TsFile] Enable recover data from a incomplete TsFile and continue to write
+* IOTDB-37 Add WAL check tool script
+* IOTDB-51 Update post-back module to synchronization module
+* IOTDB-59 Support GroupBy query
+* IOTDB-60 Support Fill function when query
+* IOTDB-73 Add REGULAR encoding method for data with fixed frequency
+* IOTDB-80 Support custom export file name
+* IOTDB-81 Update travis for supporting JDK11 on Windows
+* IOTDB-83 Add process bar for import script and show how many rows have been exported
+* IOTDB-91 Improve tsfile-spark-connector to support spark-2.4.3
+* IOTDB-93 IoTDB Calcite integration
+* IOTDB-109 Support appending data at the end of a completed TsFile
+* IOTDB-122 Add prepared statement in JDBC
+* IOTDB-123 Add documents in Chinese
+* IOTDB-130 Dynamic parameters adapter
+* IOTDB-134 Add default parameter for client starting script
+* Add read-only mode of IoTDB
+* New storage engine with asynchronously flush and close data file
+* Adding english documents
+* Supporting travis + window + jdk8
+* Add skipping all UTs: maven integration-test -DskipUTS=true
+* Enable users define the location of their thrift compiler
+* Add example module
+* Add a log appender: put info, warn, error log into one file and disable log_info by default
+* Recover when resource file does not exist while tsfile is complete
+
+## Incompatible changes
+
+If you use the previous unofficial version 0.7.0. It is incompatible with 0.8.0.
+
+## Miscellaneous changes
+
+* IOTDB-21 Add ChunkGroup offset information in ChunkGroupMetaData
+* IOTDB-25 Add some introduction for JMX MBean Monitor in user guide
+* IOTDB-29 Multiple Exceptions when reading empty measurements from TsFileSequenceReader
+* IOTDB-39 Add auto repair functionality for RestorableTsFileIOWriter
+* IOTDB-45 Update the license in IoTDB
+* IOTDB-56 Faster getSortedTimeValuePairList() of Memtable
+* IOTDB-62 Change log level from error to debug in SQL parser
+* IoTDB-63 Use TsFileInput instead of FileChannel as the input parameter of some functions
+* IOTDB-76 Reformat MManager.getMetadataInString() in JSON format
+* IOTDB-78 Make unsequence file format more similar with TsFile
+* IOTDB-95 Keep stack trace when logging or throwing an exception
+* IOTDB-117 Add sync documents
+* Modify ASF header for each file and add related maven plugin
+* Add IoTDB env script test
+* Add sync function for jdbc server to close
+* Add cache directories for download jars and sonar plugin of maven in travis
+* Add partition start and end offset constraints when loading ChunkGroupMetaData
+* Check when creating Storage group
+* Try to release memory asap in ReadOnlyMemChunk
+* Add more physical plan serializer
+* Move all generated tsfiles for test into the target folder
+* Make TsFileWriter as AutoClosable
+* Print apache-rat violation result on console
+* Update multi dir avoid disk is full
+* Simplify Path construction
+* Separate documents into different chapter folders
+* Suppress mvn log in travis
+* Add mvn -B in travis
+
+## Known Issues
+
+* IOTDB-20 Need to support UPDATE
+* IOTDB-124 Lost timeseries info after restart IoTDB
+* IOTDB-125 [potential] a concurrency conflict may occur when a delete command and insertion command appears concurrently
+* IOTDB-126 IoTDB will not be closed immediately after run 'stop-server.sh' script
+* IOTDB-127 Chinese version documents problems
+
+## Bug Fixes
+
+* IOTDB-2 Maven Test failed before run mvn package -Dmaven.test.skip=true
+* IOTDB-7 OpenFileNumUtilTest failed
+* IOTDB-15 Fail to install IoTDB on Ubuntu 14.04
+* IOTDB-16 Invalid link on https://iotdb.apache.org/#/Documents/Quick Start
+* IOTDB-17 Need to update chapter Start of https://iotdb.apache.org/#/Documents/Quick Start
+* IOTDB-18 IoTDB startup script does not work on openjdk11
+* IOTDB-19 Fail to start start-server.sh script on Ubuntu 14.04/Ubuntu 16.04
+* IOTDB-22 BUG in TsFileSequenceReader when reading tsfile
+* IOTDB-24 DELETION error after restart a server
+* IOTDB-26 Return error when quit client
+* IOTDB-27 Delete error message
+* IOTDB-30 Flush timeseries cause select to returns "Msg:null"
+* IOTDB-31 Cannot set float number precision
+* IOTDB-34 Invalid message for show storage group
+* IOTDB-44 Error message in server log when select timeseries
+* IOTDB-49 Authorizer module outputs too many debug log info
+* IOTDB-50 DataSetWithoutTimeGenerator's initHeap behaves wrongly
+* IOTDB-52 Cli doesn't support aggregate
+* IOTDB-54 Predicates doesn't take effect
+* IOTDB-67 ValueDecoder reading new page bug
+* IOTDB-70 Disconnect from server when logging in fails
+* IOTDB-71 Improve readPositionInfo
+* IOTDB-74 THe damaged log will be skipped if it is the only log
+* IOTDB-79 Long term test failed because of the version control of deletion function
+* IOTDB-81 Fix Windows OS environment for Travis-CI
+* IOTDB-82 File not closed in PageHeaderTest and cause UT on Windows fails
+* IOTDB-84 Out-of-memory bug
+* IOTDB-94 IoTDB failed to start client since the required jars are not in the right folder
+* IOTDB-96 The JDBC interface throws an exception when executing the SQL statement "list user"
+* IOTDB-99 List privileges User <username> on <path> cannot be used properly
+* IOTDB-100 Return error message while executing sum aggregation query
+* IOTDB-103 Does not give a hint when encountering unsupported data types
+* IOTDB-104 MManager is incorrectly recovered when system reboots
+* IOTDB-108 Mistakes in documents
+* IOTDB-110 Cli inserts data normally even if there is no space left on the disk
+* IOTDB-118 When the disk space is full, the storage group is created successfully
+* IOTDB-121 A bug of query on value columns
+* IOTDB-128 Probably a bug in iotdb official website
+* IOTDB-129 A bug in restoring incomplete tsfile when system restart
+* IOTDB-131 IoTDB-Grafana module error when getting the timeseries list from Grafana
+* IOTDB-133 Some content is mistaken for links
+* System memory check failure in iotdb-env.sh
+* Time zone bug in different region
+* DateTimeUtilsTest UT bug
+* Problem discovered by Sonar
+* Openjdk11 + linux11 does not work on travis
+* Start JDBC service too slowly
+* JDBC cannot be closed
+* Close bug in sync thread
+* Bug in MManager to get all file names of a path
+* Version files of different storage groups are placed into the same place
+* Import/export csv script bug
+* Log level and stack print in test
+* Bug in TsFile-Spark-Connector
+* A doc bug of QuickStart.md
\ No newline at end of file

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip
==============================================================================
Binary file - no diff available.

Propchange: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.asc
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.asc (added)
+++ dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.asc Wed Jun 17 04:29:07 2020
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEEukXNu4fosUaoH1u+Igbvj2TDWIkFAl7pgiAACgkQIgbvj2TD
+WImfYA/9Fp4MGPb9tPd1nMvCrnYHBHnbr/Ewb1BIUNa/GYMofA4gq41HMye8QKGt
+nJ3Qi6vrLzw9a6nKIISps0Xl7Dey/+Cr/DDhDqQocnJrOD4qN9AXUjrIuWlbRo1Q
+hyKwpdnSpJVFUVb6c4Gz4pcc6W6/Vuqjr055iLE/+mCruYu0qk+X5gurXnwXxnmd
+YaPJOdYQ7SFY81e0kHWmvA9a4/e1PH7cdMBVzDPiz6P2cRli1KlISQYLazRML+Vu
+XJU/W30MYe61Eih95D+J3l6UPeBnm/8Ivo7upZkdpKK4Iiwfu8w+MuXjF8gTzFnX
+u9I3x9o9umnMFlNGnxSMMRuGazw0UkA73bP9qZQGHA29cMi4gAqAcAShnyWxq+PS
+pp+J2naQUk+n56GpvJhPLw7wlBdPdf/8sbX9mKQQrXlN/EfTDC77pTnHE4Ukn51H
+sPCRP3q8py/t2xv9FbNSqBHYWPmOJoBIkaJSVyEnNBK8xna/xS3zrUMKU6gfj5y0
+eweB2G3XDIxi4NDAJeoDORL6beVO3elKoNDf3exidn/Vw3fvz7fW5AgYn1WKkx+M
+c1i8fb7bquPcbAT4D+mafIQ4XFwdBAenykSRWjz9FuLQUkJ8we00tnS/QHMnvGjA
+CdempYv8fUx49smR2IXC0YWbzMUz5ANMMFjfkO1qquVd+jnTXX8=
+=TpYx
+-----END PGP SIGNATURE-----

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.sha512
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.sha512 (added)
+++ dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-bin.zip.sha512 Wed Jun 17 04:29:07 2020
@@ -0,0 +1 @@
+dff89a8b9481c6729c178cdeaeceb812b865c7387a5c637b21df4f9e9cd80daa3622254bdfc582dddc1860e642765b99b196b69c8763f62345e7b4e5df55974d
\ No newline at end of file

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip
==============================================================================
Binary file - no diff available.

Propchange: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.asc
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.asc (added)
+++ dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.asc Wed Jun 17 04:29:07 2020
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEEukXNu4fosUaoH1u+Igbvj2TDWIkFAl7pfdcACgkQIgbvj2TD
+WInhrRAAh2AKw9x6qhhegVeBAyTZWEBSBo+4Tff64rFMO2KEPu13u+WMIcdWe8nt
+hDxCkdMPsc090qWO39rIbHSwJhlMQeN6crD31w7DIHsctiCkSZcLEK7oXoqSWbf7
+kcy5txEOCtZ8tKSFn1nnNZGUFpTTb8yq1Mu1wN7eVbceeonfAZS/7fSrRcwhMSmN
+349pT+rZVlppROS7T+Nh6DtgLLg63HOVzivemJissFxYsTHlhkIPj1M8KFDD5WxB
+YPLs8zRQ57uppWw1UpYq0C5LFhxjLt1QArQxDL39hJB7HK1sBNUbyWGHDF8JJy8l
+6xQ7J+MPbUlY8BqeMuGRttD6HzLOAijtc8Z47bAszGCFtpufVtVY+QcurRKsUxOP
+N/NqWVTx4dsGAQ5qFXUJ8Eq7KrAwPqpRyFlere16T8AUW6D8f1WHGgVc7tLcj24u
+4jvo5+gEiE5e22gEf7El1C5SoUOZrYtW1TNcWRA42fkh9Nn9JQ6Yk4+wwc/dXFHR
+mwKt6ysv5+lLwThhLyuaAm+gPR8Ct+gRPRcpPsHhEVFFWmo8S7qp+6Vy0ILmGD/6
+bktX4Tm+Z/G6yAqqxoQiDUPR7fZd4I6kPc+uR8NNbItmt+9G5Js22OSnWTO6/snj
+icfvQI9No/01Hhrx4Mz4uPInLbdSGZsfFwuIA+IY46DYeOQU7dc=
+=NbeN
+-----END PGP SIGNATURE-----

Added: dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.sha512
==============================================================================
--- dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.sha512 (added)
+++ dev/incubator/iotdb/0.10.0/rc3/apache-iotdb-0.10.0-incubating-source-release.zip.sha512 Wed Jun 17 04:29:07 2020
@@ -0,0 +1 @@
+74ba57fa0eb218e81efab122357879ffca68da5e115ceaed7eebdd8bca54e55bea82d34c86b6d2e1987a1de049ad8f1bc4da2446511569dd5be5e4324f181a28
\ No newline at end of file