MySQL初识-架构-安装-初始化-连接-管理工具-数据文件

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

MySQL架构和结构分析

官方架构图

wKioL1NLJNiRnPzbAAn45ZsJsuY067.jpg

内部组件结构图

wKiom1NLJSDxkZwaAALzdV2IEfA203.jpg

MySQL安装方式

wKioL1NLJRjSdsIXAAfglSdvzi8965.jpg


MySQL初始化

wKiom1NLJV2zwKazAAsmeOpZnBI736.jpg


MySQL工作模式及常用命令

交互式模式:mysql>

1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 交互式模式下的客户端命令
    mysql> help  # 获取命令帮助
    mysql> \?  # 同上
    mysql> \c  # 取消命令执行
    mysql> \g  # 发送命令至服务器端
    mysql> \G  # 发送命令至服务器端,垂直显示结果
    mysql> \q  # 退出
    mysql> \!  # 执行系统shell命令
    mysql> \s  # 显示服务器端状态信息
    mysql> \.  /path/to/mysql_script .sql  # 批量执行sql
    mysql> \u  # 切换数据库
# 交互式模式下的服务器端命令(需要命令提示符,默认为分号)
    mysql> help contents 能够获取帮助的分类信息
    mysql> help keyword 获取关键字的帮助信息,如help  select

脚本模式:mysql < /path/to/mysql_script.sql

注:常用于主从复制批量导入数据时


连接MySQL

连接类型

本地通信:客户端与服务器端位于同一主机,而且还要基于127.0.0.1(localhost)地址或lo接口进行通信

   基于sock文件通信:如mysql -hlocalhost -uroot -p --socket=/tmp/mysql.sock

远程通信:客户端与服务器端位于不同的主机,或在同一主机使用非回环地址通信

   基于 TCP socket通信

mysql客户端选项

实例

1
2
3
4
5
6
7
8
9
10
11
12
-u,--user  # 指定连接用户
-h,--host  # 指定连接主机
-p,--password  # 指定连接密码
--protocol={tcp|socket|memory|pipe}  # 指定连接协议
-P,--port  # 指定连接端口,默认监听端口:tcp/3306
--socket  # 指定本地连接的sock文件
--compress  # 数据传输采用压缩格式
-D,--database  # 指定连接后默认使用的数据库
-H,--html  # 指定产生html输出
-X,--xml  # 指定产生xml输出
--safe-updates  # 拒绝使用无where子句的update或delete命令
# 使用实例:mysql -hlocalhost -uroot -p

mysql命令提示符

1
2
3
4
5
6
mysql>  # 等待输入命令
->  # 等待继续输入
‘>  # 等待结束单引号
“>  # 等待结束双引号
`>  # 等待结束反引号
/*>  # 注释,不执行,需以*/结束注释

mysql的快捷键

1
2
3
4
5
ctrl+w: # 删除光标之前的单词
ctrl+u: # 删除光标之前至命令行首的所有内容
ctrl+y: # 粘贴所有ctrl+w或ctrl+u删除的内容
ctrl+a: # 移动光标至行首
ctrl+e: # 移动光标至行尾


MySQL管理工具mysqladmin

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# 使用格式:mysqladmin [options] command [arg] [,command [arg]] …
# 常用的command包括:
create DB_Name: # 创建数据库
drop DB_Name: # 删除数据库
debug: # 打开调试日志并记录于error log中
status: # 显示简要状态信息
-- sleep  #:设置间隔时长
--count  #:设置显示的批次
extended-status: # 显示扩展信息,输出mysqld的各状态变量及赋值,相当于执行“mysql> show global status”
variables: # 输出mysqld的各服务器变量
flush-hosts: # 清空主机相关的缓存:DNS解析缓存;此前因为连接错误次数过多而被拒绝访问mysqld的主机列表
flush-logs: # 日志滚动,只能滚动二进制日志和中继日志
refresh: # 相当于同时使用flush-hosts和flush-logs
flush-privileges: # 通知mysqld重读授权表
reload: # 功能同“flush-privileges”
flush-status: # 重置状态变量的值
flush-tables: # 关闭当前打开的表文件句柄
flush-threads: # 清空线程缓存
kill # 杀死指定的线程,需指定线程ID;可以一次杀死多个线程,以逗号分隔,但不能有多余空格
password: # 修改当前用户的密码
ping # 模拟ping操作,检测mysqld是否在线
processlist: # 显示mysqld线程列表
shutdown # 关闭mysqld进程
start-slave,stop-slave: # 启动/关闭从服务器线程


MySQL数据文件解析

MyISAM表:每表有3个文件,都位于数据库目录中

1
2
3
tb_name.frm: # 表结构定义文件
tb_name.MYD: # 数据文件
tb_name.MYI: # 索引文件

InnoDB表:有2种存储方式

默认方式:每表有1个独立文件和一个多表共享的文件

1
2
tb_name.frm: # 表结构定义文件,位于数据库目录中
ibdata #:# 共享的表空间文件,默认位于数据目录(datadir指向的目录)中,如ibdata1

自定义方式:独立的表空间

1
2
3
4
5
6
tb_name.frm: #表结构定义文件
tb_name.ibd: # 独有的表空间文件
# 在MySQL初始化中打开独立表空间功能的方法:
vi  /etc/my .cnf (在[mysqld]段下添加)
innodb_file_per_table = ON
# 注:表空间:table space,是由InnoDB管理的特有格式的数据文件,内部可同时存储数据和索引









本文转自 xxrenzhe11 51CTO博客,原文链接:http://blog.51cto.com/xxrenzhe/1395061,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
20天前
|
关系型数据库 MySQL
elasticsearch对比mysql以及使用工具同步mysql数据全量增量
elasticsearch对比mysql以及使用工具同步mysql数据全量增量
19 0
|
1月前
|
关系型数据库 MySQL 数据库连接
关于MySQL-ODBC的zip包安装方法
关于MySQL-ODBC的zip包安装方法
|
26天前
|
关系型数据库 MySQL 数据库
rds安装数据库客户端工具
安装阿里云RDS的数据库客户端涉及在本地安装对应类型(如MySQL、PostgreSQL)的客户端工具。对于MySQL,可选择MySQL Command-Line Client或图形化工具如Navicat,安装后输入RDS实例的连接参数进行连接。对于PostgreSQL,可以使用`psql`命令行工具或图形化客户端如PgAdmin。首先从阿里云控制台获取连接信息,然后按照官方文档安装客户端,最后配置客户端连接以确保遵循安全指引。
78 1
|
21天前
|
Ubuntu 关系型数据库 MySQL
Ubuntu 中apt 安装MySQL数据库
Ubuntu 中apt 安装MySQL数据库
65 0
|
4天前
|
关系型数据库 MySQL 数据安全/隐私保护
MySQL 安装及连接
MySQL 安装及连接
22 0
|
7天前
|
关系型数据库 MySQL 数据库
docker自定义安装mysql 5.7
docker自定义安装mysql 5.7
15 0
|
7天前
|
关系型数据库 MySQL Linux
CentOS 7 下使用yum安装MySQL5.7.20 最简单 图文详解
CentOS 7 下使用yum安装MySQL5.7.20 最简单 图文详解
32 0
|
7天前
|
关系型数据库 MySQL Linux
win安装mysql5.7 和安装出现的问题
win安装mysql5.7 和安装出现的问题
10 0
|
18天前
|
canal 消息中间件 关系型数据库
【分布式技术专题】「分布式技术架构」MySQL数据同步到Elasticsearch之N种方案解析,实现高效数据同步
【分布式技术专题】「分布式技术架构」MySQL数据同步到Elasticsearch之N种方案解析,实现高效数据同步
66 0

推荐镜像

更多