sele 发表于 2018-10-10 12:09:15

mysql的历史命令记录,~/.mysql_history

  ~/.mysql_history文件中记录每个用户使用数据库的操作命令
  root用户的mysql操作,~/.mysql_history
  transfor用户的mysql操作,/home/transfor/.mysql_history
  # tail -20 /root/.mysql_history
  show variables like '%resolve%';
  show variables like '%connection%';
  show global status like ‘Max_used_connections;
  show global status like ‘Max_used_connections';
  show global status like 'max_user_connections';
  show global status like 'max_used_connections';
  show global variables like 'max_user_connections';
  show global status like '%open%table%';
  show variables like 'table%cache%';
  show global status like 'thread%';
  show variables like 'thread_cache_size';
  show global status like 'qcache%';
  show variables like 'query_cache%';
  select count(id) from mop_bet_order_history;
  use lottery;
  select count(id) from mop_bet_order_history;
  不过这个文件会把所有操作记录下来,包括创建用户和修改用户的明文密码。万一被人***,获取该文件内容,非常危险。
  这个文件是mysql编译安装时默认配置好的,不容易修改。但是最好不要保存,仅仅删除是不行的,要直接将其软连接到垃圾箱:
  rm ~/.mysql_history
  ln -s /dev/null ~/.mysql_history
  如果确实想将一些操作记录下来,可以在/etc/my.cnf配置文件的组临时添加:
  
  tee=/tmp/mysql.history
  tee命令添加完成后,无需重启mysql服务,所以仅对当前打开的客户端记录mysql操作命令
  等操作使用完成后,注释
  ~/.mysql_history文件产生原理
  因为mysql本身就是一个shell,每次mysql连接退出后,都会把此次操作信息记录到~/.mysql_history文件中
  如果该文件不存在,会先创建再记录(像rm,或者刚安装的mysql)
  此文件的名字和路径,是根据MYSQL_HISTFILE这个环境变量来设置的,默认是~/.mysql_history,修改文件名和路径:
  vim ~/.bash_profile
  export MYSQL_HISTFILE=/home/jason/.my_history
  ./etc/profile重新初始化后,生效

页: [1]
查看完整版本: mysql的历史命令记录,~/.mysql_history