服务器更换,需要把hive使用的mysql库迁移到其他服务器上.

整个过程很简单,就是数据库导出导入

1.在原服务器将数据库导出

$ mysqldump -h ip -u username -p metadata4ad > metadata4ad.sql
Enter password: 
tty:[4] jobs:[0] cwd:[/home/ad]
$ ll metadata4ad.sql 
-rw-rw-r-- 1 ad ad 62317790 10-27 10:10 metadata4ad.sql

2.在目标服务器上新建数据库,用户,权限设置

mysql> create database metadata4ad;
Query OK, 1 row affected (0.01 sec)

mysql> create user 'user'@'%' identified by 'password';
Query OK, 0 rows affected (0.02 sec)

mysql> grant ALL privileges on metadata4ad.* to 'user'@'%' with grant option;
Query OK, 0 rows affected (0.02 sec)
mysql>  FLUSH privileges;

3.复制数据库文件到目标服务器

$scp metadata4ad.sql  dst_ip:~/

4.目标服务器上,把数据库文件导入数据库

到sql存放目录,进入数据库

$mysql -uad -p
mysql>use metadata4ad
mysql> source metadata4ad.sql
mysql> show tables;
+---------------------------+
| Tables_in_metadata4ad     |
+---------------------------+
| BUCKETING_COLS            |
| CDS                       |
| COLUMNS_V2                |
| DATABASE_PARAMS           |
| DBS                       |
| DELEGATION_TOKENS         |
| IDXS                      |
| INDEX_PARAMS              |
| MASTER_KEYS               |
| PARTITIONS                |
| PARTITION_KEYS            |
| PARTITION_KEY_VALS        |
| PARTITION_PARAMS          |
| PART_COL_PRIVS            |
| PART_COL_STATS            |
| PART_PRIVS                |
| SDS                       |
| SD_PARAMS                 |
| SEQUENCE_TABLE            |
| SERDES                    |
| SERDE_PARAMS              |
| SKEWED_COL_NAMES          |
| SKEWED_COL_VALUE_LOC_MAP  |
| SKEWED_STRING_LIST        |
| SKEWED_STRING_LIST_VALUES |
| SKEWED_VALUES             |
| SORT_COLS                 |
| TABLE_PARAMS              |
| TAB_COL_STATS             |
| TBLS                      |
| TBL_COL_PRIVS             |
| TBL_PRIVS                 |
| VERSION                   |
+---------------------------+

5.如果hive中配置了权限验证,还需要在hive中给用户配置权限

 比如给 hadoop 用户配置所有权限

hive> grant all to user hadoop;
OK
Time taken: 0.389 seconds

   只配置操作某个数据的权限

hive> grant create on database dbname to user hadoop;  //只给了在数据库dbname中创建表的权限

hive> grant all on database dbname to user hadoop;  //在数据库dbname中有所有权限

权限:

       HIVE支持以下权限:

权限名称

含义

ALL

所有权限

ALTER

允许修改元数据(modify metadata data of object)---表信息数据

UPDATE

允许修改物理数据(modify physical data of object)---实际数据

CREATE

允许进行Create操作

DROP

允许进行DROP操作

INDEX

允许建索引(目前还没有实现)

LOCK

当出现并发的使用允许用户进行LOCK和UNLOCK操作

SELECT

允许用户进行SELECT操作

SHOW_DATABASE

允许用户查看可用的数据库

 

迁移完成.