MySQL数据库授权备份恢复

授权 (grant)

  • grant 权限 on 库名.表名 to ‘用户名’@‘来源地址’ identified by ‘密码’;
  • 来源地址
192.168.1.1  表示192.168.1.1这个IP 
192.168.1.%  表示整个192.168.1.0网段  
localhost    表示本机
  • 权限列表
all:表示所有权限
alter权限代表允许修改表结构的权限,但必须要求有create和insert权限配合
create权限代表允许创建新的数据库和表的权限
drop权限代表允许删除数据库、表、视图的权限,包括truncatetable命令
delete权限代表允许删除行数据的权限
select权限代表允许从表中查看数据
update权限代表允许修改表中的数据的权限
usage权限是创建一个用户之后的默认权限,其本身代表连接登录权限
  • 实例
    给库t325中biao1的haha用户对192.168.1.2这个IP授予查看与写入权限
grant select,insert on t325.biao1 to ‘haha’@’192.168.1.2’ identified by123.com’;

验证:客户端192.168.1.2 挂载安装mariadb

mysql -h 192.168.1.1 -u haha-p123.com    //远程连接加-h
  • 查看所有用户权限
show grants;
  • 查看某个用户的权限
show grants for 用户名@来源地址
  • 撤销权限
revoke 权限 on 数据库名.表名 from ‘用户名’@’来源地址’

备份

  1. 冷备份:在数据库关闭状态下进行备份操作。
  2. 热备份:在数据库处于运行状态时进行备份操作,该备份方法依赖数据库的日志文件。
  3. 温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作。
  • 开始备份:
#mkdir /backup            //创建备份目录
#/etc/rc.d/init.d/mysqld stop     //服务的路径得看自己安装时的路径
#tar -zcf /backup/mysql_all-$(date +%F).tar.gz /usr/local/mysql/data/    
           -$是指定输出格式为当前日期,F是显示出来
#ll /backup

在这里插入图片描述

  • 模拟误操作:

在这里插入图片描述

  • 恢复:
# mkdir /huifu
# cd /backup/
# tar -zxf mysql_all-2020-11-24.tar.gz -C /huifu/
# mv /huifu  /usr/local/mysql/
# /etc/rc.d/init.d/mysqld start (成功)

mysqldump命令的使用

  • mysqldump -u 用户名 -p [密码] [选项] [数据库名] [表名] > /备份路径/备份文件名
  • 备份数据库
# mysqldump -u root -p123.com --database t325 > /backup/t325.sql
  • 备份所有库
# mysqldump -u root -p123.com --all-databases > /backup/all.sql
  • 恢复
  • 恢复数据库
# mysql -u root -p123.com < /backup/t325.sql 
  • 恢复所有库
#mysql -u root -p123.com < /backup/all.sql

扩展

  • 数据库外查看数据库内容 -e命令(利用bash调用sql语句)
#mysql -u root -p123.com -e ‘show databases;’   //-e 连接(调用sql语句)
  • 查看(过滤)备份脚本中的数据库操作语句
#grep -v "^--" /backup/t325.biao1.sql |grep -v "^/"|grep -v "^$"

MySQL数据库授权备份恢复_第1张图片

学习数据库基本操作:数据库增删改查

今天分享到此为止,你的点赞关注是对作者最大的鼓励,一起努力MySQL数据库授权备份恢复_第2张图片

你可能感兴趣的:(Linux,mysql,数据库,linux,经验分享,程序人生)