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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介:

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,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
11月前
|
存储 BI Shell
Doris基础-架构、数据模型、数据划分
Apache Doris 是一款高性能、实时分析型数据库,基于MPP架构,支持高并发查询与复杂分析。其前身是百度的Palo项目,现为Apache顶级项目。Doris适用于报表分析、数据仓库构建、日志检索等场景,具备存算一体与存算分离两种架构,灵活适应不同业务需求。它提供主键、明细和聚合三种数据模型,便于高效处理更新、存储与统计汇总操作,广泛应用于大数据分析领域。
1189 2
|
11月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
565 0
|
11月前
|
SQL 缓存 前端开发
如何开发进销存系统中的基础数据板块?(附架构图+流程图+代码参考)
进销存系统是企业管理采购、销售与库存的核心工具,能有效提升运营效率。其中,“基础数据板块”作为系统基石,决定了后续业务的准确性与扩展性。本文详解产品与仓库模块的设计实现,涵盖功能概述、表结构设计、前后端代码示例及数据流架构,助力企业构建高效稳定的数字化管理体系。
|
10月前
|
数据采集 缓存 前端开发
如何开发门店业绩上报管理系统中的商品数据板块?(附架构图+流程图+代码参考)
本文深入讲解门店业绩上报系统中商品数据板块的设计与实现,涵盖商品类别、信息、档案等内容,详细阐述技术架构、业务流程、数据库设计及开发技巧,并提供完整代码示例,助力企业构建稳定、可扩展的商品数据系统。
|
9月前
|
数据采集 机器学习/深度学习 搜索推荐
MIT新论文:数据即上限,扩散模型的关键能力来自图像统计规律,而非复杂架构
MIT与丰田研究院研究发现,扩散模型的“局部性”并非源于网络架构的精巧设计,而是自然图像统计规律的产物。通过线性模型仅学习像素相关性,即可复现U-Net般的局部敏感模式,揭示数据本身蕴含生成“魔法”。
379 3
MIT新论文:数据即上限,扩散模型的关键能力来自图像统计规律,而非复杂架构
|
8月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
713 2
|
9月前
|
JSON 供应链 监控
1688商品详情API技术深度解析:从接口架构到数据融合实战
1688商品详情API(item_get接口)可通过商品ID获取标题、价格、库存、SKU等核心数据,适用于价格监控、供应链管理等场景。支持JSON格式返回,需企业认证。Python示例展示如何调用接口获取商品信息。
|
10月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
758 10
|
11月前
|
数据采集 存储 分布式计算
一文读懂数据中台架构,高效构建企业数据价值
在数字化时代,企业面临数据分散、难以统一管理的问题。数据中台架构通过整合、清洗和管理数据,打破信息孤岛,提升决策效率。本文详解其核心组成、搭建步骤及常见挑战,助力企业高效用数。
2448 24
|
10月前
|
数据采集 监控 数据可视化
数据量暴涨时,抓取架构该如何应对?——豆瓣电影案例调研
本案例讲述了在豆瓣电影数据采集过程中,面对数据量激增和限制机制带来的挑战,如何通过引入爬虫代理、分布式架构与异步IO等技术手段,实现采集系统的优化与扩展,最终支撑起百万级请求的稳定抓取。
572 0
数据量暴涨时,抓取架构该如何应对?——豆瓣电影案例调研

推荐镜像

更多