使一个新的MySQL安装更安全

2008-02-23 07:41:06来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

在您自己安装了一个新的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连接服务器时指定口令。


标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 用gcc批量建mysql库表

下一篇: 将OICQ数据转成MYSQL数据