博客
关于我
MySQL隐藏文件.mysql_history风险
阅读量:382 次
发布时间:2019-03-05

本文共 806 字,大约阅读时间需要 2 分钟。

1.1 MySQL历史记录的隐私问题

在用户的家目录下,MySQL会默认生成一个隐藏文件`.mysql_history`,用来记录所有与MySQL相关的操作记录。这些记录包括用户的创建、修改以及明文密码的操作。如果恶意分子能够访问这一文件,他们就能获取到重要的账号信息,这对系统安全是一个潜在的风险。为了保护服务器的安全,了解并解决这一问题显得尤为重要。

1.2 解决方案

方法一:创建软链接

ln -s /dev/null ~/.mysql_history
通过创建一个软链接,将`.mysql_history`指向一个空文件(/dev/null),可以有效避免文件被记录。这样一来,MySQL就无法再将操作日志写入实际存在的文件中。

方法二:指定记录路径

如果需要记录操作日志,可以通过修改`MYSQL_HISTFILE`环境变量来指定日志文件的路径。默认情况下,这个变量值为当前用户的家目录,修改方法如下:

cat >> /etc/profile << EOF    export MYSQL_HISTFILE=/home/mysql/.my_history    EOF    source /etc/profile
通过上述方法,可以将日志文件移动到指定目录,避免重要信息泄露。然而,如果你希望完全禁止日志记录,最好选择方法一。

方法三:使用tee命令

如果需要对某些特定的操作记录下来,可以使用MySQL的tee命令。例如:

mysql -u root -p -e "SHOW DATABASES;" tee /tmp/mysql_history
使用完后,记得注释掉tee命令以防被恶意利用:
# [client] tee=/tmp/mysql_history

需要注意的是,以上方法仅能部分限制日志记录,完全阻止记录的最有效方式仍然是通过创建软链接来实现。因此,在实际应用中,建议优先选择方法一。

转载地址:http://ibrwz.baihongyu.com/

你可能感兴趣的文章
基于Vue2.0+Vue-router构建一个简单的单页应用
查看>>
基于vue2.0实现仿百度前端分页效果(二)
查看>>
JS魔法堂:函数重载 之 获取变量的数据类型
查看>>
时间序列神器之争:Prophet VS LSTM
查看>>
SpringBoot中关于Mybatis使用的三个问题
查看>>
MapReduce实验
查看>>
Leaflet 带箭头轨迹以及沿轨迹带方向的动态marker
查看>>
java大数据最全课程学习笔记(1)--Hadoop简介和安装及伪分布式
查看>>
java大数据最全课程学习笔记(2)--Hadoop完全分布式运行模式
查看>>
大部分程序员还不知道的 Servelt3 异步请求,原来这么简单?
查看>>
[apue] popen/pclose 疑点解惑
查看>>
[apue] getopt 可能重排参数
查看>>
移动互联网恶意软件命名及分类
查看>>
adb shell am 的用法
查看>>
PySide图形界面开发(一)
查看>>
Android如果有一个任意写入的漏洞,如何将写权限转成执行权限
查看>>
三角网格体积计算
查看>>
现代3D图形编程学习-基础简介(2) (译)
查看>>
Github教程(3)
查看>>
vue实现简单的点击切换颜色
查看>>