infobright创建表时指定存储目录无效的解决方法


  infobright是一个基于MySQL数据库的列存储数据库,有收费版和免费版。
  在使用infobright创建表时,如果存储引擎为BRIGHTHOUSE,那么指定DATA DIRECTORY='/data/myib' 是无效的--但如果存储引擎为MyISAM,DATA DIRECTORY有效。不知道是不是因为使用免费版的缘故。
  举例:
  1. 存储引擎为BRIGHTHOUSE: mysql> create table e(id varchar(10)) ENGINE=BRIGHTHOUSE DATA DIRECTORY='/data/myib'; Query OK, 0 rows affected (7.91 sec) mysql> show create table e; +-------+----------------------------------------- --------------------------------------------------- ----+ | Table | Create Table | +-------+----------------------------------------- --------------------------------------------------- ----+ | e | CREATE TABLE `e` ( `id` varchar(10) DEFAULT NULL ) ENGINE=BRIGHTHOUSE DEFAULT CHARSET=latin1 | +-------+----------------------------------------- --------------------------------------------------- ----+ 1 row in set (0.00 sec)  可以看到使用show create table查看建表SQL时,DATA DIRECTORY未出现,而且/data/myib/下也没有e.MYD
  2. 存储引擎为MyISAM: mysql> create table f(id varchar(10)) ENGINE=MyISAM DATA DIRECTORY='/data/myib'; Query OK, 0 rows affected (3.90 sec) mysql> show create table f; +-------+----------------------------------------- --------------------------------------------------- ----------------------------+ | Table | Create Table | +-------+----------------------------------------- --------------------------------------------------- ----------------------------+ | f | CREATE TABLE `f` ( `id` varchar(10) DEFAULT NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 DATA DIRECTORY='/data/myib/' | +-------+----------------------------------------- --------------------------------------------------- ----------------------------+  此时/data/myib/下有f.MYD这个文件
  解决方法:
  有如下两种方法:
  1. 修改infobright的配置文件
  通过修改infobright的配置文件来实现,但这会影响到这个数据库实例的其它数据库的存储目录。
  修改配置文件的datadir选项,如下: vi /etc/my-ib.cnf [mysqld] basedir = /usr/local/infobright datadir = /data/myib 停止数据库实例,移动/usr/local/infobright/data下的所有文件和目录到/data/myib下即可
  2. 在datadir下创建符号链接
  这个方式是目录操作,只会影响要改动的数据库。
  如果我们要把名为'probe'的数据库的存储目录改为/data/myib,执行下列shell命令即可:
  #移动原数据库目录到新目录下
  mv /usr/local/infobright/data/probe/ /data/myib/
  #在datadir下创建到新存储目录的符号链接
  ln -s /data/myib/probe/ /usr/local/infobright/data/probe

猜你喜欢

转载自bndis.iteye.com/blog/1572175