mysql的在线模式更改

online-schema-change的Python项目详细描述


onlineschemachange是一个为mysql表进行模式更改的工具 以非阻塞方式

示例

OSC必须与mysql服务器在同一主机上运行。

copy模式

< P>数据库下面有一个现有的表名为{TT3}$ test

CREATETABLE`my_table`(`id`int(11)NOTNULL,PRIMARYKEY(`id`))ENGINE=InnoDBDEFAULTCHARSET=latin1

如果我们想逃跑 ALTER TABLE ``my_table添加列datavarchar(10);``针对 它。我们不需要将ALTER TABLE语句提供给osc,只需要 将表示所需架构的CREATE TABLE语句放入 文件/tmp/foo.sql如下:

CREATETABLE`my_table`(`id`int(11)NOTNULL,`data`varchar(10)DEFAULTNULL,PRIMARYKEY(`id`))ENGINE=InnoDBDEFAULTCHARSET=latin1

然后运行以下命令:

osc_cli copy --ddl-file-list=foo.sql --socket=/tmp/mysql.socket --database=test

cleanup模式

清理上次运行OSC留下的表

osc_cli cleanup --socket=/tmp/mysql.socket --database=test

终止某些mysql上当前运行的OSC进程 实例:

osc_cli cleanup

direct模式

此模式是为将mysql的本地联机ddl用于模式而保留的。 更改,并帮助dba管理所有与模式相关的操作 一个工具。现在,如果您计划对所有架构使用OSC。 管理,此模式用于创建空的新表。 下面的命令将在数据库中创建一个空表test

osc_cli direct --ddl-file-list=foo.sql --socket=/tmp/mysql.socket --database=test

要求

OnlineSchemaChange需要

系统包

对于python2

sudo apt-get install python-dev libmysqlclient-dev # Debian / Ubuntu
sudo yum install python-devel mysql-devel # Red Hat / CentOS

对于Python3

sudo apt-get install python3-dev # debian / Ubuntu
sudo yum install python3-devel # Red Hat / CentOS

python需求*python>;=2.7*python模块:6, pyparsingMySQLdb

安装Online SchemaChange

运行以下命令安装依赖项

python setup.py install --install-scripts=/usr/local/bin

如果您的环境中有多个可用的python版本,或者 您不想弄乱系统的默认python,可以使用 pyenvvirtualenv

联机SchemaChange的工作原理

查看wiki页面了解更多详细信息和一些高级用法。

如何贡献

检查这个wiki page 如果你想为这个项目做贡献。

许可证

OnlineSchemaChange已获得BSD许可。我们还提供了一项附加专利 格兰特。

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java如何强制用户在允许访问活动之前处理对话框?我的许可证代码怎么了?   java ArraysList作为JSON   mysql如何在java中创建包含多个可选where子句的搜索语句?   java如何让Apache Camel在“直接”路径的末尾删除文件?   使用socket在两个Androids之间进行java实时数据传输。IO(websocket)和4G   如何在java中实现两个CORBA服务器之间的通信   会话树xml表示为java对象   java Skype4Java编号swtwin323325   java RecyclerView getAdapterPosition()不工作:第一次单击返回正确位置,第二次单击返回1   java在$TOMCAT/conf/context上为JNDI设置资源。xml   java为什么第二个矩形冲突在第一个矩形冲突时不起作用?   JScrollPane上的java JTextArea未出现在JPanel上   java如何将实现的PriorityQueue打印为字符串?   jpa使用Jersey更新用户角色RESTJava(JAXRS)