MySQL mysqladmin客户端的使用简介

 更新时间:2021年03月27日 14:58:16   作者:AsiaYe  
这篇文章主要介绍了MySQL mysqladmin客户端的使用简介,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下

     mysqladmin是MySQL官方提供的shell命令行工具,它的参数都需要在shell命令行里面执行,当我们使用mysqladmin的时候,必须指定两类参数,一类是连接参数,另外一类是命令参数,连接参数用来指定相应的连接信息,而命令参数用来指定命令信息,例如可以用来检查服务器的配置和当前状态、创建和删除数据库等。它的语法如下:

mysqladmin [options] command [command-options] [command [command options]] ...

除此之外,还有一些相关的参数配置(代码可以左滑哦~):

--bind-address=name 绑定远程访问主机的ip地址
-i, --sleep=#   间隔多长时间执行一次。
-c, --count=#   统计计数。与i选项配合使用。
-f, --force   强制执行,删除数据库是无需确认信息,多条语句执行时忽略其中某条语句的错误。
--default-character-set=name 设置默认字符集。
-?, --help    显示帮助信息。
-h, --host=name  指定连接主机。
-u, --user=name  登录用户。
-p, --password[=name] 登录密码,如果不写于参数后,则会提示输入。
-P, --port=#   指定数据库端口。
--protocol=name  使用的连接协议。(tcp,socket,pipe,memory)
-r, --relative   显示前后两次输出的差异。必须与i选项配合使用。
-s, --silent   静默退出。
-S, --socket=name  指定socket文件。
-v, --verbose   显示更多信息。
-V, --version   显示版本信息。
-w, --wait[=#]   如果连接断开,等待指定的时间后重试

    这么多参数,想看着比较乱,那么我们来看看它具体能够帮我们做哪些事情吧:

1.查看服务器的状态:

#每隔两秒查看一次服务器的状态
[root@dev01 ~]# mysqladmin -uroot -p -i 2 -c 2 status
Enter password: 
Uptime: 42767 Threads: 2 Questions: 533 Slow queries: 0 Opens: 346 Flush tables: Open tables: Queries per second avg: 0.012
Uptime: Threads: Questions: Slow queries: Opens: Flush tables: Open tables: Queries per second avg: 0.012

2.修改root密码:

#修改root密码
mysqladmin -u root -p原密码 password 'newpassword'

3.检查mysqlserver是否可用

#查询服务是否正常
[root@dev01 ~]# mysqladmin -uroot -p ping
Enter password: 
mysqld is alive

4.查询服务器的版本

[root@dev01 ~]# mysqladmin -uroot -p version
Enter password: 
mysqladmin Ver 8.42 Distrib 5.7.19, for linux-glibc2.12 on x86_64
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Server version  5.7.19
Protocol version 10
Connection  Localhost via UNIX socket
UNIX socket  /tmp/mysql.sock
Uptime:   12 hours 42 sec

Threads: 2 Questions: 538 Slow queries: 0 Opens: 346 Flush tables: 1 Open tables: 285 Queries per second avg: 0.012

5.查看系统当前的状态值 (省略其中的部分结果)

[root@dev01 ~]# mysqladmin -uroot -p extended-status
Enter password: 
+-----------------------------------------------+----------+
| Variable_name         | Value |
+-----------------------------------------------+----------+
| Aborted_clients        |   |
| Aborted_connects        |   |
| Innodb_num_open_files       |  |
| Innodb_truncated_status_writes    |   |            
| Uptime          |  |
| Uptime_since_flush_status      |  |
+-----------------------------------------------+----------+

6.查看服务器系统变量值

[root@dev01 ~]# mysqladmin -uroot -p variables
Enter password: 
......
| key_cache_block_size    |                                                                                         |
| key_cache_division_limit   |                                                                                             |
| large_files_support    | ON                                                                                                    |
| large_page_size     |                                                                                                     |
| large_pages      | OFF                                                                                                    |
| lc_messages      | en_US                                                                                                   |
| lc_messages_dir     | /usr/local/mysql/share/                                                                                               |
......

7.查看当前所有的进程

[root@dev01 ~]# mysqladmin -uroot -p processlist
Enter password: 
+----+------+----------------------+----------+---------+-------+----------+------------------+
| Id | User | Host     | db  | Command | Time | State | Info    |
+----+------+----------------------+----------+---------+-------+----------+------------------+
| | root | 192.168.56.102: | devopsdb | Sleep | |   |     |
| | root | localhost   |   | Query |  | starting | show processlist |
+----+------+----------------------+----------+---------+-------+----------+------------------+

8.创建数据库

[root@dev01 ~]# mysqladmin -uroot -p create db_test
Enter password: 
[root@dev01 ~]# mysql -uroot -p
Enter password: 
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 
Server version: 5.7.19 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database   |
+--------------------+
| information_schema |
| TkGrowDB_dbo  |
| TkGrowLog_dbo  |
| cydevopsdb   |
| db_test   |
| yeyz    |
+--------------------+
 rows in set (0.00 sec)

mysql> exit
Bye

从上面的命令我们可以看到,我们已经通过create命令创建了数据库db_test

9.删除特定的数据库:

[root@dev01 ~]# mysqladmin -uroot -p drop db_test
Enter password: 
Dropping the database is potentially a very bad thing to do.
Any data stored in the database will be destroyed.

Do you really want to drop the 'db_test' database [y/N] y
Database "db_test" dropped
[root@dev01 ~]# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 
Server version: 5.7.19 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database   |
+--------------------+
| information_schema |
| TkGrowDB_dbo  |
| TkGrowLog_dbo  |
| cydevopsdb   |
| yeyz    |
+--------------------+
 rows in set (0.00 sec)

    在我们日常操作中,drop操作应该谨慎一些,可以看到,mysql也友好的给出了提醒。

10.重载权限表和刷新缓存(无明显输出)

[root@dev01 ~]# mysqladmin -uroot -p reload
Enter password:
[root@dev01 ~]# mysqladmin -uroot -p refresh
Enter password:

11.启用安全模式关闭数据库

[root@dev01 ~]# ps -ef|grep mysqld
root    : ?  :: /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql --pid-file=/data/mysql/dev01.pid
mysql   : ?  :: /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/mysqld.log --pid-file=/data/mysql/dev01.pid --socket=/tmp/mysql.sock
root   : pts/ :: grep mysqld
[root@dev01 ~]# mysqladmin -uroot -p shutdown
Enter password: 
[root@dev01 ~]# ps -ef|grep mysqld
root   : pts/ :: grep mysqld

12.各种刷新命令

[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-hosts
[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-logs
[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-privileges
[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-status
[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-tables
[root@dev01 ~]# mysqladmin -u root -ptmppassword flush-threads

13.停止和启动MySQL从节点复制过程

[root@dev01 ~]# mysqladmin -u root -p stop-slave
[root@dev01 ~]# mysqladmin -u root -p start-slave

以上就是mysqladmin最常用的一些功能,标注为红色的一般在工作中应用的范围及其广泛,可以多留意下。

以上就是MySQL mysqladmin客户端的使用简介的详细内容,更多关于MySQL mysqladmin客户端的资料请关注脚本之家其它相关文章!

相关文章

  • Mysql误删除DELETE数据找回操作指南

    Mysql误删除DELETE数据找回操作指南

    如果我们在数据库中不小心执行了类似"delete from t1"这样的不带where条件的语句,那么整张表的数据就全被删除了,下面这篇文章主要给大家介绍了关于Mysql误删除DELETE数据找回操作的相关资料,需要的朋友可以参考下
    2023-05-05
  • MySQL的Flush-List和脏页的落盘机制

    MySQL的Flush-List和脏页的落盘机制

    这篇文章主要介绍了MySQL的Flush-List和脏页的落盘机制,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下
    2020-11-11
  • 浅谈MySQL中的六种日志

    浅谈MySQL中的六种日志

    MySQL中存在着6种日志,本文是对MySQL日志文件的概念及基本使用介绍,不涉及底层内容,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • percona 实用工具之pt-kill使用介绍

    percona 实用工具之pt-kill使用介绍

    一个优秀的kill MySQL连接的一个工具,是percona toolkit的一部分,在因为空闲连接较多导致超过最大连接数、某个有问题的sql导致mysql负载很高时,都需要将一些连接kill掉,这个工具主要就是这个用途
    2016-04-04
  • MySQL中的批量修改、插入操作数据库

    MySQL中的批量修改、插入操作数据库

    在平常的项目中,我们会需要批量操作数据库的时候,例如:批量修改,批量插入,那我们不应该使用 for 循环去操作数据库,这样会导致我们反复与数据库发生连接和断开连接,影响性能和增加操作时间,所以可以使用SQL 批量修改的方式去操作数据库,感兴趣的朋友一起学习下吧
    2023-09-09
  • 数据库中的SELECT语句逻辑执行顺序分析

    数据库中的SELECT语句逻辑执行顺序分析

    这篇文章主要介绍了数据库中的SELECT语句逻辑执行顺序分析,并列出了一些例子,需要的朋友可以参考下
    2014-07-07
  • MySQL DML语句整理汇总

    MySQL DML语句整理汇总

    这篇文章主要介绍了MySQL DML语句整理汇总,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • MySQL权限USAGE和ALL PRIVILEGES的用法

    MySQL权限USAGE和ALL PRIVILEGES的用法

    本文主要介绍了MySQL权限USAGE和ALL PRIVILEGES的用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-09-09
  • MySQL占用CPU过高排查过程及可能优化方案

    MySQL占用CPU过高排查过程及可能优化方案

    这篇文章主要介绍了MySQL占用CPU过高排查过程及可能优化方案,具有很好的参考价值,希望对大家的学习或工作有所帮助,感兴趣的朋友可以参考下
    2024-01-01
  • 一文教你如何使用MySQL触发器

    一文教你如何使用MySQL触发器

    触发器(TRIGGER)是MySQL的数据库对象之一,是一种特殊类型的存储过程,从5.0版本开始支持,下面这篇文章主要给大家介绍了关于如何使用MySQL触发器的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05

最新评论