如何让新安装的MySQL数据库变得更安全

作者:小昭 时间:2009-01-04 13:19:00 

在你自己安装了一个新的MySQL服务器后,你需要为MySQL的root用户指定一个目录(缺省无口令),否则如果你忘记这点,你将你的MySQL处于极不安全的状态(至少在一段时间内)。

在Unix(Linux)上,在按照手册的指令安装好MySQL后,你必须运行mysql_install_db脚本建立包含授权表的mysql数据库和初始权限。在Windows上,运行分发中的Setup程序初始化数据目录和mysql数据库。假定服务器也在运行。

当你第一次在机器上安装MySQL时,mysql数据库中的授权表是这样初始化的:

你可以从本地主机(localhost)上以root连接而不指定口令。root用户拥有所有权限(包括管理权限)并可做任何事情。(顺便说明,MySQL超级用户与Unix超级用户有相同的名字,他们彼此毫无关系。)

匿名访问被授予用户可从本地连接名为test和任何名字以test_开始的数据库。匿名用户可对数据库做任何事情,但无管理权限。

从本地主机多服务器的连接是允许的,不管连接的用户使用一个localhost主机名或真实主机名。如:

% mysql -h localhost test

% mysql -h pit.snake.net test

你以root连接MySQL甚至不指定口令的事实只是意味着初始安装不安全,所以作为管理员的你首先要做的应该是设置root口令,然后根据你设置口令使用的方法,你也可以告诉服务器重载授权表是它知道这个改变。(在服务器启动时,它重载表到内存中而可能不知道你已经修改了它们。)

对MySQL 3.22和以上版本,你可以用mysqladmin设置口令:

% mysqladmin -u root password yourpassword

对于MySQL的任何版本,你可以用mysql程序并直接修改mysql数据库中的user授权表:

% mysql -u root mysql

mysql>UPDATE user SET password=PASSWORD("yourpassword") WHERE User="root";

如果你有MySQL的老版本,使用mysql和UPDATE。

在你设置完口令后,通过运行下列命令检查你是否需要告诉服务器重载授权表:

% mysqladmin -u root status

如果服务器仍然让你以root而不指定口令而连接服务器,重载授权表:

% mysqladmin -u root reload

在你设置了root的口令后(并且如果需要重载了授权表),你将需要在任何时候以root连接服务器时指定口令。

标签:
0
投稿

猜你喜欢

  • 一文带你解密Python可迭代对象的排序问题

    2023-11-26 00:53:13
  • Python中的super用法详解

    2022-06-29 16:43:04
  • win10下python3.5.2和tensorflow安装环境搭建教程

    2022-11-05 15:56:21
  • Python3 利用requests 库进行post携带账号密码请求数据的方法

    2023-04-03 05:37:53
  • Python封装数据库连接池详解

    2024-01-14 06:26:37
  • Python中OpenCV实现简单车牌字符切割

    2023-09-19 18:53:59
  • MySQL与PHP的基础与应用专题之数据控制

    2023-11-23 01:03:21
  • JS实现动画中的布局转换

    2023-10-14 15:58:04
  • JavaScript 扩展运算符用法实例小结【基于ES6】

    2024-04-22 13:06:03
  • Python的Flask框架中使用Flask-Migrate扩展迁移数据库的教程

    2024-01-19 06:38:45
  • vue项目中在可编辑div光标位置插入内容的实现代码

    2024-05-28 15:55:45
  • Python中文分词库jieba,pkusegwg性能准确度比较

    2021-12-17 13:05:41
  • python正则表达式re.match()匹配多个字符方法的实现

    2023-07-30 08:25:16
  • IE6/7关于 Absolute Position 、relative 的一些意外

    2008-11-27 11:34:00
  • Python图像处理之图像清晰度评价

    2021-12-22 13:58:44
  • asp获取文件md5值

    2008-10-13 09:10:00
  • python实现雨滴下落到地面效果

    2021-10-04 03:58:32
  • Python Subprocess模块原理及实例

    2022-09-29 04:37:20
  • PyCharm License Activation激活码失效问题的解决方法(图文详解)

    2021-11-20 12:52:23
  • python里面单双下划线的区别详解

    2023-03-22 12:39:22
  • asp之家 网络编程 m.aspxhome.com