MySQL数据库之MySQL数据库安全设置与注意事项小结
小标 2019-03-29 来源 : 阅读 1213 评论 0

摘要:本文主要向大家介绍了MySQL数据库之MySQL数据库安全设置与注意事项小结 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

本文主要向大家介绍了MySQL数据库之MySQL数据库安全设置与注意事项小结 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

MySQL数据库之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


本文由职坐标整理并发布,希望对同学们学习MySQL有所帮助,更多内容请关注职坐标数据库MySQL数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程