MBTiles Validation
The original MBTiles specification does not provide any guarantees for
the content of the tile data in MBTiles. mbtiles validate
assumes a few additional conventions and uses them to ensure
that the content of the tile data is valid performing several validation steps. If the file is not valid, the command
will print an error message and exit with a non-zero exit code.
mbtiles validate src_file.mbtiles
SQLite Integrity check
The validate
command will run PRAGMA integrity_check
on the file, and will fail if the result is not ok
.
The --integrity-check
flag can be used to disable this check, or to make it more thorough with full
value. Default
is quick
.
Schema check
The validate
command will verify that the tiles
table/view exists, and that it has the expected columns and indexes.
It will also verify that the metadata
table/view exists, and that it has the expected columns and indexes.
Per-tile validation
If the .mbtiles
file uses flat_with_hash
or normalized schema, the validate
command will verify that the MD5 hash of
the tile_data
column matches the tile_hash
or tile_id
columns (depending on the schema).
A typical Normalized schema generated by tools like tilelive-copy
use MD5 hash in the tile_id
column. The Martin’s mbtiles
tool can use this hash to verify the content of each tile.
We also define a new flat-with-hash schema that stores the hash and tile data in the
same table, allowing per-tile validation without the multiple table layout.
Per-tile validation is not available for the flat
schema, and will be skipped.
Aggregate Content Validation
Per-tile validation will catch individual tile corruption, but it will not detect overall datastore corruption such as
missing tiles, tiles that should not exist, or tiles with incorrect z/x/y values. For that, the mbtiles
tool defines a
new metadata value called agg_tiles_hash
.
The value is computed by hashing the combined value for all rows in the tiles
table/view, ordered by z,x,y. The value
is computed using the following SQL expression, which uses a custom md5_concat_hex
function
from sqlite-hashes crate:
md5_concat_hex(
CAST(zoom_level AS TEXT),
CAST(tile_column AS TEXT),
CAST(tile_row AS TEXT),
tile_data)
In case there are no rows or all are NULL, the hash value of an empty string is used. Note that SQLite allows any value
type to be stored as in any column, so if tile_data
accidentally contains non-blob/text/null value, validation will
fail.
The mbtiles
tool will compute agg_tiles_hash
value when copying or validating mbtiles files. Use --agg-hash update
to force the value to be updated, even if it is incorrect or does not exist.