MySQL Shell的简单介绍(r12笔记第95天)
MySQL Shell是在官方版本5.7.12推出,工具的初衷本身都是为了解决一类问题,想必官方从很多方面了解到工具的使用情况,支持的开发语言太多,众口难调,所以这么个命令行工具就出来了,从它的推出,足以看到MySQL的格局,它是把很多能做不能做得都揽过来自己做了。根据官方的shell,python,原生SQL,Javascript等,格式都是清一色的JSON.
如果对这个工具还是有一些疑惑的话,在最新版本的InnoDB Cluster可以作为其中的一个标准组件,如果你想搭建这个环境,里面的标准步骤是按照MySQL Shell的操作来的,再加上MySQL Router,MGR,这一套算是全了。
这个工具本身是一个可选组件,如果平时用起来也是一个蛮不错的选择。最新版本是1.0.9,可以通过如下的方式来下载二进制版本。
wget https://dev.mysql.com/get/Downloads/MySQL-Shell/mysql-shell-1.0.9-linux-glibc2.12-x86-64bit.tar.gz --no-check-certificate
mysqlsh命令是这个工具的核心部分,如果查看这个mysqlsh命令的情况如下:
# file mysqlsh
mysqlsh: ELF 64-bit LSB executable, x86-64, version 1 (GNU/Linux), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, stripped
假设你连接MySQL是通过如下的方式来连接。
# mysql -uroot -h127.0.0.1 --port=3308 -pmysql
那么在mysqlsh里面就很容易了。
mysql-js> connect root:mysql@127.0.0.1:3308
Creating a Session to 'root@127.0.0.1:3308'
Classic Session successfully established. No default schema selected.
如果查看MySQL服务的状态,就是一个很简单的status
mysql-js> status
MySQL Shell Version 1.0.9
Session type: Classic
Connection Id: 1571
Default schema:
Current schema:
Current user: root@localhost
SSL: Cipher in use: null
Server version: MySQL Community Server (GPL)
Server info: 5.7.17-log
Protocol version: 10
Connection: 127.0.0.1 via TCP/IP
Server characterset: latin1
Schema characterset: latin1
Client characterset: latin1
Conn. characterset: latin1
Up time: 47 days, 22 hours, 40 minutes, 57 sec
Threads: 3 Questions: 691328 Slow queries: 0 Opens: 10336 Flush tables: 35 Open tables: 69 Queries per second avg: 0.166
mysql-js>
总体来说,用法和MongoDB很相似,风格和PG也蛮相似。
比如切换到sql模式。
mysql-js> sql
Switching to SQL mode... Commands end with ;
mysql-sql> select @@port;
+--------+
| @@port |
+--------+
| 3308 |
+--------+
MySQL Shell的连接还支持uri的方式,使用mysqlsh -uri的形式即可。
当然里面的很多信息可以通过API的方式来调用得到。
比如检查状态等。
mysql-js> dba.configureLocalInstance('root@127.0.0.1:3308')
Please provide the password for 'root@127.0.0.1:3308':
Please fix these issues and try again.
{
"errors": [],
"restart_required": false,
"status": "error"
}
- Android 之dragger使用
- Android图像处理 - 高斯模糊的原理及实现
- 走进科学:银行ATM机真的安全吗?
- 漏洞科普:对于XSS和CSRF你究竟了解多少
- 巧用Live Template,不仅能提升AS开发效率,还能装逼
- 黑了前男友网站:从找SQL注入到后台权限
- 扩展CakePHP的CacheHelper以使用缓存引擎
- 走进科学:酒店保险箱真的保险么?
- 利用xmlrpc.php对WordPress进行暴力破解攻击
- .Net中如何操作IIS
- Havex:以工控设备为狩猎目标的恶意软件
- 大规模异常滥用检测:基于局部敏感哈希算法——来自Uber Engineering的实践
- 浅谈php安全
- 在统一的分析平台上构建复杂的数据管道
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- SpringMVC全局异常处理机制
- centos su sudo wheel
- List集合的坑
- NIO从入门到踹门
- GitHub CLI 1.0.0 正式发布!
- 【Flink】从零搭建实时数据分析系统
- Android模拟面试,解锁大厂——从Activity创建到View呈现中间发生了什么?
- 问你一个简单的问题:IP是怎么来的,又是怎么没的?
- 进击的NIO!Reactor模式!
- 交换机与VLAN:以办公室为例趣讲一波!
- 超详细Netty入门,看这篇就够了!
- Netty进阶之粘包和拆包问题
- 用侦察兵的故事趣讲ICMP和Ping,看完想忘都难!
- Kubernetes 使用 ceph-csi 消费 RBD 作为持久化存储
- ZooKeeper入门,看这篇就够了