当我们运行mysql客户端连接mysql服务器的时候,以一种暴露的可被其他用户发现的方式指定我们的密码是不妥的。我们输入密码的方式有四种,其中每一种都有一定风险。下面就分别说下这四种方式:

MySQL密码输入的安全操作(翻译)

第一种:直接在命令行后使用  -pyour_pass 或者r --password=your_pass 这两种选项。

举例:

shell> mysql -u ksharpdabu -pksharppassword db_name

这种方式很方便,但是不安全,因为在某些系统里,通过这种方式输入的密码对于一些系统状态程序,比如ps命令变得可见,可以让其他用户调用来显示你的命令。一般mysql客户端通常会在初始化序列期间用零覆盖命令行参数,但是仍然有一个短暂间隔时间内参数值可见的。

比如,你使用shell> mysql -u ksharpdabu -pksharppassword    db_name &

将命令挂起,用shell >ps –f  命令产看,就会发现结果如下:

[[email protected] ~]# ps -f

UID PID PPID C STIME TTY TIME CMD

root 11594 11591 0 19:54 pts/0 00:00:00 -bash

root 11614 11594 0 19:54 pts/0 00:00:00 mysql –uksharpdabu -px xxxxx

root 11616 11594 0 19:54 pts/0 00:00:00 ps -f

密码参数值变成了星号,不可见,但是,如果你kill的时候,还是能看到你的密码参数值。

第二种:使用一个 -p 或者 --password 选项(后面不指定密码),在这种情况下,客户端程序请求来自终端的密码:

shell>mysql -u ksharp -p da_name

Enter password:*********

因为它对其他用户不可见,与在命令行指定相比,这样登陆mysql服务器会更加安全。但是,这个只能用于交互式运行程序,我们大部分情况下都是非交互的运行一个脚本调用客户端,就不能使用这种方法了。在某些系统中,甚至会发现脚本的第一行被错误地读并解释为我们的mysql登陆密码。

第三种:在一个配置文件中存储你的密码,例如,在Unix中,可以在主目录的“.my.cnf”文件中[client]节列出你的密码。

举例:

[client]

password=your_pass

当然,如果你在“.my.cnf”里存储了密码,就一定要保管好这个文件,除了自己本人,绝不能让其他人能访问该文件。保证文件的访问模式是:400或600。

使用如下命令:

shell>chmod 600 .my.cnf

附上在Unix中,MySQL程序读取启动选项的文件列表:

MYSQL_HOME是一个环境变量,包含服务器相关的my.cnf文件驻留的目录路径。

如果未设置MYSQL_HOME,并且DATADIR中有一个my.cnf文件,BASEDIR中没有my.cnf文件,mysqld_safe将MYSQL_HOME设置为DATADIR。否则,如果未设置MYSQL_HOME并且在DATADIR中没有my.cnf,则mysqld_safe将MYSQL_HOME设置为BASEDIR。

典型情况二进制安装的目录为/usr/local/mysql/data或源代码安装的目录为/usr/local/var。请注意这是配置时指定的数据目录的位置,而不是 mysqld启动时用--datadir指定的。运行时使用--datadir对寻找选项文件的服务器没有效果,因为服务器在处理命令行参量之前寻找这些选项。

MySQL按照上述顺序寻找选项文件,并读存在的选项文件。如果你想要使用的某个选项文件不存在,则用明文文本编辑器创建。如果存在多个选项文件,文件中指定的后读取的选项要优先文件中指定的先读取的选项。

注释:在Unix平台上,MySQL忽略人人可写的配置文件。这是故意的,是一个安全措施。

任何可以在运行MySQL程序时在命令行给出的长选项也可以在选项文件中给出。要想列出程序的适用选项,用--help选项运行程序。

其他系统下的配置文件列表如下,

在Windows中,MySQL程序从以下文件读取启动选项:

第四种:在MYSQL_PWD环境变量中存储密码

但是这种指定MySQL密码的方法是极不安全的,不应该使用。ps的某些版本包括显示运行进程的环境的选

项;如果你设定MYSQL_PWD,你的密码将被运行ps的所有人看见,甚至在没有这样一个版本的ps的系统上,也可能被观察到。

在Unix上,mysql的客户端会将执行的命令保存在历史记录文件里。在默认情况下,这个文件被命名为 .mysql_history ,创建在你的home目录下。密码作为纯文本记录在如 CREATE USER, GRANT, 和 SET PASSWORD 这些语句里面。所以如果使用了这些语句,他们就被记录在这个历史文件里。为了保证安全,应该严格显示这个文件的访问模式,就和对刚才说的 .my.cnf 文件一样。

如果你的命令解释器配置为保持历史,这些历史记录文件,其中将包含在命令行中输入MySQL的密码。例如,bash中使用?/.bash_history的。任何这样的文件应该有一个严格的访问模式。

原文:http://www.jb51.net/article/68697.htm

mysql安全输入密码设置,MySQL安全输入密码的一些操作介绍相关推荐

  1. 怎么配置mysql的ip_设置MYSQL允许用IP访问

    设置MYSQL允许用IP访问 2012-01-10 14:43 55人阅读 评论(0) 收藏 举报 SQL Error (1130): Host '192.168.1.100' is not allo ...

  2. tomcat 7 mysql,Tomcat 七设置mysql数据源

    Tomcat 7设置mysql数据源 将mysql-connector放入Tomcat\lib中. 修改conf目录下的Tomcat\context.xml. WEB-INF/web.xml maxA ...

  3. mysql 编码格式_设置MySQL的字符编码

    前言 这里我已经将MySQL的数据库编码设置为UTF-8,所以下面现实的都是UTF-8. 设置MySQL数据库的编码方式有三种,分别是基于session会话的.基于全局gloable的.永久性改变的. ...

  4. mysql列宽设置,mysql – 从.csv文件确定最佳列宽

    我想将.CSV文件导入MySQL表.我想根据CSV文件中包含的实际数据确定要使用的最佳列宽.是否有任何脚本或实用程序来完成此任务? 解决方法: 如果可能,最好避免尝试猜测适当的列长度 – 如果您可以获 ...

  5. mac mysql 自动启动_Mac设置Mysql开机启动

    Mac和linux略有不同,有的功能封闭起来了. Mac实现自启动,可以用Launchctl功能来实现,Launchctl实际上是写*.plist文件,和linux中的Crontab功能一样.然后将创 ...

  6. php设置mysql查询编码,php连接mysql时怎么设置编码方式

    php连接mysql时怎么设置编码方式 php连接mysql数据库时,也就是在mysql_connect()语句之后添加"mysql_query("set names utf8&q ...

  7. ubuntu mysql 编译_Ubuntu下mysql编译安装

    安装必备工具 编译安装需要其他安装程序支持,推荐采用编译安装各种所需包,此处为了方便,使用ubuntu提供的apt-get install方法安装所需工具 sudo apt-get install c ...

  8. 4. MySQL数据库管理系统(MySQL的下载安装、配置、补丁 一站式)

    文章目录 MySQL数据库管理系统 1. MySQL下载 2. MySQL安装 3. 创建配置文件 4. 初始化 5. 启动MySQL 6. 使用MySQL 7. MySQL测试 MySQL数据库管理 ...

  9. centos mysql部署_CentOS下MySQL 8.0安装部署,超详细!

    MySQL 8正式版8.0.11已发布,官方表示MySQL8要比MySQL 5.7快2倍,还带来了大量的改进和更快的性能!到底谁最牛呢?请看:MySQL 5.7 vs 8.0,哪个性能更牛? Mysq ...

最新文章

  1. eclipse常用快捷键Get;set;
  2. C++中的yield和fork
  3. spring context 初始化两次导致dubbo端口被占用
  4. Python——文本进度条
  5. OpenCASCADE:绘制演示脚本
  6. wxWidgets:构建wxWidgets程序的第一步
  7. 《C++ Primer》7.1.3节练习
  8. 课时47.datalist标签(了解)
  9. MySQL时间戳与日期格式的相互转换
  10. pytorch1.7教程实验——DCGAN生成对抗网络
  11. [Unity] 战斗系统学习 8:构建 TPS 框架 3:mono 组件
  12. 线程5-生产者消费者模式(线程通信)
  13. 线性表:3.链表,单链表详解与C语言实现
  14. Windows Server 2003 来配置网络地址转换 (NAT
  15. C语言:error C2084 函数“”已有主体
  16. 如何在uni-app中引入iconfont图标
  17. 血污夜之仪式秘密巫师实验室收集策略
  18. axure下移固定地方_axure固定元件位置 教程:使用axure动态面板制作一个返回顶部的按钮...
  19. ZbxTable 2.1 重磅发布!周四直播分享
  20. Mojave下修复搜狗输入法斗图和标点配对不生效的问题?

热门文章

  1. 小啾带你开天眼 之 人脸检测与识别(以及华强、皇叔、高祖配墨镜特效)【Python-Open_CV系列(十三)】
  2. 用c语言输出倒直角梯形,编程题(C/C++程序设计,同济大学mooc)
  3. mindmanager2022如何设置切换中文?
  4. 《可以量化的经济学》,一本挑战诺…
  5. 干货分享 | 这个软件一秒钟就可以知道你电脑有什么
  6. 基于Python web框架Django+Bootstrap的房源推荐系统
  7. 2021年N1叉车司机考试题库
  8. shell通过邮件服务器发送邮件,shell脚本通过sendEmail25端口发送邮件
  9. 语音识别中的傅里叶变化
  10. Golang 中的 Goroutine 调度原理与 Chanel 通信