≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

MySQL数据库安全设置与注意事项小结

人气:325 时间:2020-07-09

这篇文章主要为大家详细介绍了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连接服务器时指定

下面是我整理的一些方法
首先让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 

.快速修复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

 

本文来自:http://www.q1010.com/177/9711-0.html

注:关于MySQL数据库安全设置与注意事项小结的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:MYSQL

您可能感兴趣的文章

  • master and slave have equal MySQL server ids
  • MySQL中使用自定义变量 编写偷懒的UNION示例
  • MySQL使用inner join 进行 查询/删除/修改示例
  • MySQL 关键词相关度排序方法详细示例分析
  • 在Python安装MySQL支持模块的方法
  • INSERT INTO .. ON DUPLICATE KEY更新多行记录
  • 浅析SQL语句行列转换的两种方法 case...when与pivot函数的应用
  • MySQL避免重复插入记录的几种方法
  • 快速增加MySQL数据库连接数负载能力的方法分享
  • MySQL 选择插入数据(包含不存在列)具体实现
上一篇:MySQL高级查询之与Group By集合使用介绍
下一篇:在Python安装MySQL支持模块的方法
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。