OnlineSchemaChange is a tool for making schema changes for MySQL tables in a non-blocking way
OSC
must be run on the same host as MySQL server.
copy
modeSay we have an existing table named my_table
under database
test
:
CREATE TABLE `my_table` (
`id` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
Now if we want to run
ALTER TABLE `my_table` add column `data` varchar(10);
against
it. Instead of feed the ALTER TABLE
statement to OSC, we just need
to put a CREATE TABLE
statement representing the desired schema into
a file /tmp/foo.sql
like below:
CREATE TABLE `my_table` (
`id` int(11) NOT NULL,
`data` varchar(10) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1
Then run the following command:
osc_cli copy --ddl-file-list=foo.sql --socket=/tmp/mysql.socket --database=test
cleanup
modeTo cleanup the table left behind by last run of OSC
osc_cli cleanup --socket=/tmp/mysql.socket --database=test
To terminate a currently running OSC
process on certain MySQL
Instance:
osc_cli cleanup
direct
modeThis mode is reserved for utilizing MySQL's native online ddl for schema
change, and help DBA manage all the schema related operation into this
one tool. For now, if you plan to use OSC
for all your schema
management, this mode is here for you to create a empty new table.
Following command will create an empty table into database test
osc_cli direct --ddl-file-list=foo.sql --socket=/tmp/mysql.socket --database=test
OnlineSchemaChange requires
System packages
For Python2
sudo apt-get install python-dev libmysqlclient-dev # Debian / Ubuntu
sudo yum install python-devel mysql-devel # Red Hat / CentOS
For Python3
sudo apt-get install python3-dev # debian / Ubuntu
sudo yum install python3-devel # Red Hat / CentOS
Python requirements * python >= 2.7 * python module: six, pyparsing, MySQLdb
Run following command to install dependency
python setup.py install --install-scripts=/usr/local/bin
If you have multiple python version available in your environment, or
you don't want mess up with system's default python, you can use
pyenv
and virtualenv
Check wiki page for more detail, and some advanced usage.
Check this wiki page if you want to contribute to this project.
OnlineSchemaChange is BSD-licensed. We also provide an additional patent grant.
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。