MySQL数据库安全设置与注意事项小结
2013-08-20 06:37
691 查看
分享下有关mysql的安全设置方法。
例如需要将mysql以普通用户权限运行,就算出问题了有了root也不能控制系统。
当你第一次在机器上安装MySQL时,mysql数据库中的授权表是这样初始化的:
你可以从本地主机(localhost)上以root连接而不指定口令。root用户拥有所有权限(包括管理权限)
并可做任何事情。(顺便说明,MySQL超级用户与Unix超级用户有相同的名字,他们彼此毫无关系。)
匿名访问被授予用户可从本地连接名为test和任何名字以test_开始的数据库。匿名用户可对数据库做任
何事情,但无管理权限。
从本地主机多服务器的连接是允许的,不管连接的用户使用一个localhost主机名或真实主机名。如:
你以root连接MySQL甚至不指定口令的事实只是意味着初始安装不安全,所以作为管理员的你首先要做的
应该是设置root口令,然后根据你设置口令使用的方法,你也可以告诉服务器重载授权表是它知道这个改
变。(在服务器启动时,它重载表到内存中而可能不知道你已经修改了它们。)
对MySQL 3.22和以上版本,你可以用mysqladmin设置口令:
对于MySQL的任何版本,你可以用mysql程序并直接修改mysql数据库中的user授权表:
在你设置完口令后,通过运行下列命令检查你是否需要告诉服务器重载授权表:
如果服务器仍然让你以root而不指定口令而连接服务器,重载授权表:
在你设置了root的口令后(并且如果需要重载了授权表),你将需要在任何时候以root连接服务器时指定
下面是我整理的一些方法
首先让mysql以普通用户权限运行mysql。类似sqlserver的设置方法,如果不会的朋友可以使用工具实现。
1.设置或修改Mysql root密码:
默认安装后空密码,以mysqladmin命令设置密码:
2.删除默认的数据库和用户
3. 更改默认root账号名称:
4. 本地文件安全:
5. 禁止远程连接mysql,远程管理可通过phpmyadmin,编辑my.cnf在[mysqld]添加:
6.最小权限用户:
7. 限制普通用户浏览其它数据库,编辑my.cnf在[mysqld]添加:
.快速修复MySQL数据库
修复数据库
mysqlcheck -A -o -r -p修复指定的数据库
mysqlcheck -o -r database -p
9.跟据内存的大小选择MySQL的配置文件:
例如需要将mysql以普通用户权限运行,就算出问题了有了root也不能控制系统。
当你第一次在机器上安装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; -- www.jbxue.com
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
相关文章推荐
- MySQL数据库安全设置与注意事项小结
- MySQL数据库安全设置与注意事项小结
- 项目开发中的一些注意事项以及技巧总结 基于Repository模式设计项目架构—你可以参考的项目架构设计 Asp.Net Core中使用RSA加密 EF Core中的多对多映射如何实现? asp.net core下的如何给网站做安全设置 获取服务端https证书 Js异常捕获
- mysql数据库密码设置注意事项
- Android 用Google Service定位设置注意事项
- 转:squid做反向代理时,要注意的安全设置
- VS2015中设置D3D12根签名HLSL文件自动编译属性时的注意事项
- 【转】一个交警肺腑之言:高速公路行车的安全注意事项
- Qt中设置widget背景颜色背景图片的注意事项
- LX5设置拍摄基本技巧、入手注意事项与摄影基本术语的概念
- 远程连接mysql数据库注意事项记录(远程连接慢skip-name-resolve)
- JavaScript函数定义的常见注意事项小结
- Python简单实现产生随机位数的密码及注意事项小结
- Android Studio 快捷键、插件、基本设置、注意事项
- 开发环境中biztalk项目设置注意事项
- mysql设置数据库注意事项
- 修改orcle数据库为mysql数据库时注意事项
- 注意阿里云服务器的安全组设置情况