MySQL数据库安全设置与注意事项_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1987 | 回复: 0   主题: MySQL数据库安全设置与注意事项        下一篇 
jian.chen
注册用户
等级:上尉
经验:781
发帖:17
精华:0
注册:1970-1-1
状态:离线
发送短消息息给jian.chen 加好友    发送短消息息给jian.chen 发消息
发表于: IP:您无权察看 2015-11-11 16:44:29 | [全部帖] [楼主帖] 楼主

       当你第一次在机器上安装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的口令后(并且如果需要重载了授权表),你将需要在任何时候以root连接服务器时指定

下面是我整理的一些方法
首先让mysql以普通用户权限运行mysql。类似sqlserver的设置方法,如果不会的朋友可以使用工具实现。

1.设置或修改Mysql root密码:
默认安装后空密码,以mysqladmin命令设置密码:

 代码如下:
            登陆mysql:
              mysqladmin -uroot password "password";
           Mysql命令设置密码:
             mysql> set password for root@localhost=password('password);
           更改密码:
             update mysql.user set password=password('password') where user='root';
             flush privileges;
2.删除默认的数据库和用户

  代码如下:
              drop database test;
              use mysql;
             delete from db;
             delete from user where not(host="localhost" and user="root");
            flush privileges;

3. 更改默认root账号名称:

  代码如下:

            update mysql.user set user="admin" where user="root";
            flush privileges;

4. 本地文件安全:

 代码如下:

             set-variable=local-infile=0

5. 禁止远程连接mysql,远程管理可通过phpmyadmin,编辑my.cnf在[mysqld]添加:

 代码如下:

            skip-networking

6.最小权限用户:

 代码如下:

            create database db1;
           grant select,insert,update,delete,create,drop privileges on database.* to user@localhost identified by 'passwd';

7. 限制普通用户浏览其它数据库,编辑my.cnf在[mysqld]添加:

 代码如下:

           skip-show-database8
8.快速修复MySQL数据库

修复数据库
            mysqlcheck -A -o -r -p修复指定的数据库

  代码如下:

            mysqlcheck  -o -r database -p

9.跟据内存的大小选择MySQL的配置文件:

 代码如下:
           my-small.cnf # > my-medium.cnf # 32M - 64M
            my-large.cnf # memory = 512M
            my-huge.cnf # 1G-2G
            my-innodb-heavy-4G.cnf # 4GB





赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论