安装完mysql数据库后的优化(删除多余用户和数据库)

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

1、查看数据库的版本信息:

1
2
3
4
5
6
7
MariaDB [(none)]>  select  version();
+----------------+
| version()      |
+----------------+
| 5.5.52-MariaDB |
+----------------+
1 row  in  set  (0.18 sec)

2、删除多余的账号(除root和localhost的)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
MariaDB [(none)]> use mysql
MariaDB [mysql]>  select  user,host from mysql.user;
+------+------------------------+
| user | host                   |
+------+------------------------+
| root | 127.0.0.1              |
| root | ::1                    |
|      | localhost              |
| root | localhost              |
|      | lvs-dr01.saltstack.com |
| root | lvs-dr01.saltstack.com |
+------+------------------------+
6 rows  in  set  (0.03 sec)
MariaDB [mysql]> delete from mysql.user where (user,host) not  in  ( select  'root' , 'localhost' );
Query OK, 5 rows affected (0.05 sec)
MariaDB [mysql]>  select  user,host from mysql.user;
+------+-----------+
| user | host      |
+------+-----------+
| root | localhost |
+------+-----------+
1 row  in  set  (0.05 sec)

3、修改mysql默认的mysql管理账号

修改默认的mysql管理账号(root改为mysql,并设置新密码为redhat12345)

1
2
3
4
5
6
7
8
9
MariaDB [mysql]> update user  set  user= "admin"  where user= "root" ;
MariaDB [mysql]> update mysql.user  set  user= 'admin' ,password=password( 'redhat12345' );
Query OK, 1 row affected (0.08 sec)
Rows matched: 1  Changed: 1  Warnings: 0
MariaDB [mysql]> flush privileges;
Query OK, 0 rows affected (0.03 sec)
[root@LVS-DR01 ~] # mysql -uadmin -p'redhat12345'
MariaDB [(none)]> user mysql;
MariaDB [mysql]> show tables;

继续查询:

1
2
3
4
5
6
7
MariaDB [mysql]>  select  user,host from mysql.user;
+-------+-----------+
| user  | host      |
+-------+-----------+
| admin | localhost |
+-------+-----------+
1 row  in  set  (0.00 sec)

4、删除test数据库:

1
2
3
4
5
6
7
8
9
10
11
MariaDB [mysql]> drop database  test ;
MariaDB [mysql]> flush privileges;
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows  in  set  (0.06 sec)

5、优化权限字典表mysql.db

如下所示:新建MySQL数据库后,默认创建的test数据库权限比较怪异,所有可连接的用户都能够拥有权限访问该库,并操作其中的对象,Host为%,User为空,说明了不受限制,所有能连接到MySQL的用户,全部拥有test及test开头的数据库的几乎所有权限。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
MariaDB [mysql]>  select  * from mysql.db where db like  'test%'  \G
*************************** 1. row ***************************
                  Host: %
                    Db:  test
                  User: 
           Select_priv: Y
           Insert_priv: Y
           Update_priv: Y
           Delete_priv: Y
           Create_priv: Y
             Drop_priv: Y
            Grant_priv: N
       References_priv: Y
            Index_priv: Y
            Alter_priv: Y
Create_tmp_table_priv: Y
      Lock_tables_priv: Y
      Create_view_priv: Y
        Show_view_priv: Y
   Create_routine_priv: Y
    Alter_routine_priv: N
          Execute_priv: N
            Event_priv: Y
          Trigger_priv: Y
*************************** 2. row ***************************
                  Host: %
                    Db:  test \_%
                  User: 
           Select_priv: Y
           Insert_priv: Y
           Update_priv: Y
           Delete_priv: Y
           Create_priv: Y
             Drop_priv: Y
            Grant_priv: N
       References_priv: Y
            Index_priv: Y
            Alter_priv: Y
Create_tmp_table_priv: Y
      Lock_tables_priv: Y
      Create_view_priv: Y
        Show_view_priv: Y
   Create_routine_priv: Y
    Alter_routine_priv: N
          Execute_priv: N
            Event_priv: Y
          Trigger_priv: Y
2 rows  in  set  (0.31 sec)
优化的操作:
MariaDB [mysql]> truncate table mysql.db;
Query OK, 0 rows affected (0.01 sec)
MariaDB [mysql]>  select  * from mysql.db where db like  'test%'  \G
Empty  set  (0.00 sec)

6、如何优化/root/.mysql_history文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[root@LVS-DR01 ~] # tail -20 ~/.mysql_history 
flush privileges;
select  user,host from mysql.user;
delete from mysql.user where user= "'molewan1'@'10.10.10.%'" ;
delete from mysql.db where user= 'molewan1' @ '10.10.10.%' ;
select  user,host from mysql.user;
delete from mysql.user where user=molewan1;
delete from mysql.user where user= 'molewan1@10.10.10.%' ;
flush privileges;
select  user,host from mysql.user;
delete from mysql.user where user= "molewan1"  and host = "10.10.10.%" ;
flush privileges;
select  user,host from mysql.user;
delete from mysql.user where user= "molewan"  and host= "10.10.10.%" ;
flush privileges;
create user molewan@ '10.10.10.%'  identified by  'molewan' ;
select  user,host from mysql.user;
desc mysql.user;
update mysql.user  set  password=password( 'admin' ) where user= 'admin'  and host= 'localhost' ;
flush privileges;
\q

说明:在Linux/Unix系统下,使用mysql命令行工具执行的所有操作,都会被记录到一个名为.mysql_history的文件中,该文件默认保存在当前用户的根目录下

这个设定原本是为了提升mysql命令行操作体验,在mysql中操作命令就可以上下翻动了,但某些情况下缺会造成隐患。

如何消除隐患:

1
2
3
4
5
6
7
8
方法1:基于DB层的操作
修改MYSQL_HISTFILE环境变量,将其值改为 /dev/null ,这样所有的操作都会被输出到空,操作的历史
自然不会被保留。
方法2:基于系统层操作
仍旧保留这个文件,但是改文件实际上未 /dev/null 的软链接,这样所有的操作都会被输出到空,操作的历史自然不会被保留。
ln  -f -s  /dev/null  ~/.mysql_history
[root@LVS-DR01 ~] # tail -20 ~/.mysql_history 
这时候就没有输出了

到此,安装完成后的基本优化已经完成










本文转自 冰冻vs西瓜 51CTO博客,原文链接:http://blog.51cto.com/molewan/1940496,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
关系型数据库 MySQL Linux
CentOS7环境下安装MySQL5.6
CentOS7环境下安装MySQL5.6
|
3天前
|
SQL 存储 关系型数据库
MySQL数据库:数据库基本认识
【2月更文挑战第6天】
42 2
|
3天前
|
SQL NoSQL 关系型数据库
关系型数据库管理系统Mysql
关系型数据库管理系统Mysql
|
1天前
|
SQL 关系型数据库 MySQL
MySQL查询语句优化的十个小技巧!
查询语句的优化是SQL效率优化的一个方式,可以通过优化sql语句来尽量使用已有的索引,避免全表扫描,从而提高查询效率。最近在对项目中的一些sql进行优化,总结整理了一些方法。
7 1
|
1天前
|
SQL 关系型数据库 MySQL
MySQL数据库学习(小白一文掌握Mysql)
MySQL数据库学习(小白一文掌握Mysql)
13 0
|
1天前
|
SQL 关系型数据库 MySQL
|
2天前
|
存储 监控 数据库
《优化数据库性能的六大技巧》
数据库作为后端开发中至关重要的一环,在实际应用中经常遇到性能瓶颈问题。本文将分享六大实用技巧,帮助开发者优化数据库性能,提升系统响应速度。
|
2天前
|
存储 监控 关系型数据库
Mysql内部在索引层面的优化
Mysql内部在索引层面的优化
|
2天前
|
SQL 算法 关系型数据库
MySQL索引优化实战二
MySQL索引优化实战二

推荐镜像

更多