• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >运营技巧 > MySQL安全输入密码的一些操作介绍

MySQL安全输入密码的一些操作介绍

作者:查字典编辑 字体:[增加 减小] 来源:互联网 时间:2022-05-05

查字典编辑向大家介绍了MySQL安全输入密码的一些操作介绍,自学教程,网站运营教程等相关知识,希望对您有所帮助

这篇文章主要介绍了MySQL安全输入密码的一些操作,示例基于Linux操作系统,需要的朋友可以参考下

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

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

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

举例:

?

1 shell mysql -u ksharpdabu -pksharppassword db_name

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

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

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

?

1 2 3 4 5 6 7 8 9 [root@EVA ~]# 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 选项(后面不指定密码),在这种情况下,客户端程序请求来自终端的密码:

?

1 shellmysql -u ksharp -p da_name

?

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

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

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

举例:

?

1 2 3 [client] password=your_pass

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

使用如下命令:

?

1 shellchmod 600 f

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

MySQL安全输入密码的一些操作介绍1

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

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

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

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

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

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

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

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

MySQL安全输入密码的一些操作介绍2

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

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

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

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

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

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL安全输入密码的一些操作介绍

相关文章

  • 2022-05-05推荐稳定的国外免费DNS he.net DNS操作图文教程
  • 2022-05-05超低价+支持支付宝:美国BudgetVM的VPS主机购买及使用教程
  • 2022-05-05网站建设如何网页布局?
  • 2022-05-05直通车烧钱?淘宝直通车操作技巧
  • 2022-05-05网站SEO优化站内链接的作用及其优化?
  • 2022-05-05如何一个月内把两个网站关键词做到搜索引擎前两页
  • 2022-05-05我是如何用两个月将新词做到首页第三的
  • 2022-05-05新站两个月如何将网站排名提升到首页
  • 2022-05-05ALEXA数据的参考价值有多大?
  • 2022-05-05软文营销怎么做?软文推广营销操作步骤四步法

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • 使用模板前需要注意什么?模板建站不可不防的三大陷阱
    • 微信营销如何创造价值?
    • 互联网大时代数据究竟是什么?有什么用?
    • 怎么提高网站浏览量?网站点击量大大增加方法介绍
    • 地方网站路在何方
    • SEO是什么?为什么要学习SEO?
    • 为什么认为自助建站不适合SEO?自助建站工具搭建出来的网站对SEO的支持如何?
    • 浅谈网站大数据管理的可视化及可视化优秀项目推荐
    • 网站优化需要注意哪些方面?
    • 说说搜索引擎营销推广技巧及搜索排名优化

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有