Migrate Data from Parquet Files to TiDB
This document describes how to generate parquet files from Apache Hive and how to migrate data from parquet files to TiDB using TiDB Lightning.
If you export parquet files from Amazon Aurora, refer to Migrate data from Amazon Aurora to TiDB.
Prerequisites
Step 1. Prepare the parquet files
This section describes how to export parquet files from Hive that can be read by TiDB Lightning.
Each table in Hive can be exported to parquet files by annotating STORED AS PARQUET LOCATION '/path/in/hdfs'
. Therefore, if you need to export a table named test
, perform the following steps:
Run the following SQL statement in Hive:
CREATE TABLE temp STORED AS PARQUET LOCATION '/path/in/hdfs'
AS SELECT * FROM test;
After executing the preceding statement, the table data is successfully exported to the HDFS system.
Export the parquet files to the local file system using the
hdfs dfs -get
command:hdfs dfs -get /path/in/hdfs /path/in/local
After the export is complete, if you need to delete the exported parquet files in HDFS, you can directly delete the temporary table (
temp
):DROP TABLE temp;
The parquet files exported from Hive might not have the
.parquet
suffix and cannot be correctly identified by TiDB Lightning. Therefore, before importing the files, you need to rename the exported files and add the.parquet
suffix to change the full filename to a format that TiDB Lightning recognizes, for example,${db_name}. ${table_name}.parquet
. For more information about file types and patterns, see TiDB Lightning Data Sources. You can also match data files by setting correct customized expressions.Put all the parquet files in a unified directory, for example,
/data/my_datasource/
ors3://my-bucket/sql-backup
. TiDB Lightning will recursively search for all.parquet
files in this directory and its subdirectories.
Step 2. Create the target table schema
Before importing data from parquet files into TiDB, you need to create the target table schema. You can create the target table schema by either of the following two methods:
Method 1: create the target table schema using TiDB Lightning.
Create SQL files that contain the required DDL statements:
- Add
CREATE DATABASE
statements in the${db_name}-schema-create.sql
files. - Add
CREATE TABLE
statements in the${db_name}.${table_name}-schema.sql
files.
- Add
- Method 2: create the target table schema manually.
Step 3. Create the configuration file
Create a tidb-lightning.toml
file with the following content:
[lightning]
# Log
level = "info"
file = "tidb-lightning.log"
[tikv-importer]
# "local": Default backend. The local backend is recommended to import large volumes of data (1 TiB or more). During the import, the target TiDB cluster cannot provide any service.
backend = "local"
# "tidb": The "tidb" backend is recommended to import data less than 1 TiB. During the import, the target TiDB cluster can provide service normally.
# For more information on import mode, refer to <https://docs.pingcap.com/tidb/stable/tidb-lightning-overview#tidb-lightning-architecture>
# Set the temporary storage directory for the sorted Key-Value files. The directory must be empty, and the storage space must be greater than the size of the dataset to be imported. For better import performance, it is recommended to use a directory different from `data-source-dir` and use flash storage, which can use I/O exclusively.
sorted-kv-dir = "${sorted-kv-dir}"
[mydumper]
# Directory of the data source.
data-source-dir = "${data-path}" # A local path or S3 path. For example, 's3://my-bucket/sql-backup'.
[tidb]
# The target cluster.
host = ${host} # e.g.: 172.16.32.1
port = ${port} # e.g.: 4000
user = "${user_name}" # e.g.: "root"
password = "${password}" # e.g.: "rootroot"
status-port = ${status-port} # During the import, TiDB Lightning needs to obtain the table schema information from the TiDB status port. e.g.: 10080
pd-addr = "${ip}:${port}" # The address of the PD cluster, e.g.: 172.16.31.3:2379. TiDB Lightning obtains some information from PD. When backend = "local", you must specify status-port and pd-addr correctly. Otherwise, the import will be abnormal.
For more information on the configuration file, refer to TiDB Lightning configuration.
Step 4. Import the data
Run
tidb-lightning
.If you import data from Amazon S3, you need to set the SecretKey and AccessKey of the account that has permission to access the S3 backend storage as environment variables before running TiDB Lightning.
export AWS_ACCESS_KEY_ID=${access_key}
export AWS_SECRET_ACCESS_KEY=${secret_key}
In addition to the preceding method, TiDB Lightning also supports reading the credential file from
~/.aws/credentials
.If you launch the program in the command line, the process might exit unexpectedly after receiving a
SIGHUP
signal. In this case, it is recommended to run the program using anohup
orscreen
tool. For example:nohup tiup tidb-lightning -config tidb-lightning.toml > nohup.out 2>&1 &
After the import starts, you can check the progress of the import by either of the following methods:
- Search for the keyword
progress
in the log usinggrep
. The progress is updated every 5 minutes by default. - Check progress in the monitoring dashboard.
- Check progress in TiDB Lightning web interface.
After TiDB Lightning completes the import, it exits automatically.
- Search for the keyword
Check if the import is successful.
Check whether
tidb-lightning.log
containsthe whole procedure completed
in the last lines. If yes, the import is successful. If no, the import encounters an error. Address the error as instructed in the error message.Note
Whether the import is successful or not, the last line of the log shows
tidb lightning exit
. It means that TiDB Lightning exits normally, but does not necessarily mean that the import is successful.
If the import fails, refer to TiDB Lightning FAQ for troubleshooting.