Skip to content

Instantly share code, notes, and snippets.

@Ernillew
Created May 23, 2017 21:50
Show Gist options
  • Star 3 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Ernillew/894e5a6c04047144003018f9af6164c8 to your computer and use it in GitHub Desktop.
Save Ernillew/894e5a6c04047144003018f9af6164c8 to your computer and use it in GitHub Desktop.
Converting InnoDB tables to RocksDB(for MariaDB 10.2)
#!/bin/bash
# Converts all InnoDB tables in all databases to ROCKSDB
#DATABASES="db1 db2" # Convert databases db1 and db2 only
DATABASES="ALL" # Convert all databases
MYSQL_USER=user
# Uncomment if you're not using ~/.my.cnf file (will receive "Warning: Using a password on the command line interface can be insecure" warnings)
#MYSQL_PASS='some-secret-password'
MYSQL_HOST=localhost
### no need to change anything below
# bail out on undefined variables
set -u
# mysql command we will use
MYSQL_COMMAND="mysql -s -u "$MYSQL_USER" -h $MYSQL_HOST"
# Uncomment if you're not using ~/.my.cnf file (will receive "Warning: Using a password on the command line interface can be insecure" warnings)
#MYSQL_COMMAND="mysql -s -u "$MYSQL_USER" --password="$MYSQL_PASS" -h $MYSQL_HOST"
# get a list of databases if we want to convert all databases
if [ "$DATABASES" == "ALL" ] ; then
DATABASES=$(echo "SHOW DATABASES" | $MYSQL_COMMAND | egrep -v '(performance_schema|information_schema|mysql)')
fi
for DATABASE in $DATABASES ; do
echo Converting $DATABASE
# Check if the table is InnoDB (we don't want to convert ROCKSDB tables over and over again)
TABLES=$(echo "SELECT TABLE_NAME FROM information_schema.TABLES where TABLE_SCHEMA = '$DATABASE' and ENGINE = 'InnoDB'" | $MYSQL_COMMAND)
for TABLE in $TABLES ; do
echo Converting InnoDB $TABLE to ROCKSDB
echo "ALTER TABLE $TABLE ENGINE = ROCKSDB" | $MYSQL_COMMAND $DATABASE
done
if [ "x$TABLES" = "x" ] ; then
echo No InnoDB tables found in $DATABASE database
fi
echo
done
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment