MySQL高级知识之 架构介绍

mysql视频教程栏目介绍mysql高级知识的架构

MySQL高级知识之 架构介绍

推荐(免费):mysql视频教程

1、MySQL 简介

概述

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。

MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

Mysql是开源的,所以你不需要支付额外的费用。

Mysql支持大型的数据库。可以处理拥有上千万条记录的大型数据库。

MySQL使用标准的SQL数据语言形式。

Mysql可以允许于多个系统上,并且支持多种语言。这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。

Mysql对PHP有很好的支持,PHP是目前最流行的Web开发语言。

MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB。

Mysql是可以定制的,采用了GPL协议,你可以修改源码来开发自己的Mysql系统。

高级MySQL涉及到知识

mysql内核sql优化攻城狮mysql服务器的优化各种参数常量设定查询语句优化主从复制软硬件升级容灾备份sql编程

完整的mysql优化需要很深的功底,大公司甚至有专门的DBA写上述

2、MySQL Linux版的安装

此次安装的是 MySQL 5.5, 安装环境 CentOS 6.5版本下载地址 官网下载地址下载 MySQL-ClientMySQL-Serverhttp://downloads.skysql.com/archives/mysql-5.5/MySQL-server-5.5.16-1.rhel4.i386.rpmhttp://downloads.skysql.com/archives/mysql-5.5/MySQL-client-5.5.16-1.rhel4.i386.rpmhttp://downloads.skysql.com/archives/mysql-5.5/MySQL-devel-5.5.16-1.rhel4.i386.rpm检查当前系统是否安装过MySQL查询命令:  rpm -qa|grep -i mysql删除命令:  rpm -e --nodeps RPM包全名安装mysql服务端(注意提示)

a7eab4311d56b6235cff53a21be6916.pngMySQL高级知识之 架构介绍

设置密码提示

安装mysql客户端查看MySQL安装时创建的mysql用户和mysql组# cat /etc/passwd | grep mysql# cat /etc/group | grep mysqlmysql服务的启+停查看MySQL启停状态:  # ps -ef | grep mysql启停操作:# /etc/init.d/mysql start# /etc/init.d/mysql stop或者#service mysql start#service mysql stop设置MySQL 自启服务#chkconfig mysql on   设置自动启动# chkconfig --list | grep mysql   检查是否设置了自动启动修改配置文件位置拷贝当前5.5版本cp /usr/share/mysql/my-huge.cnf /etc/my.cnf5.6版本  cp /usr/share/mysql/my-default.cnf /etc/my.cnf修改字符集和数据存储路径查看字符集show variables like 'character%';show variables like '%char%';

4b8e2a7d7a50e5f4cbbdbb5509ed551.png

MySQL高级知识之 架构介绍

字符集

默认的是客户端和服务器都用了latin1,所以会乱码。修改字符集,修改之前copy 的配置文件。(详细后续代码)MySQL的安装位置在linux下查看安装目录 ps -ef|grep mysql

路径 解释 备注

/var/lib/mysql/mysql数据库文件的存放路径/var/lib/mysql/atguigu.cloud.pid/usr/share/mysql配置文件目录mysql.server命令及配置文件/usr/bin相关命令目录mysqladmin mysqldump等命令/etc/init.d/mysql启停相关脚本

64d811dc7a4450c64657e423eb4ad72.png

MySQL安装位置

[client]#password = your_passwordport = 3306socket = /var/lib/mysql/mysql.sock# 这一行需要设置字符集default-character-set=utf8 # The MySQL server[mysqld]port = 3306# 还有这三行character_set_server=utf8character_set_client=utf8collation-server=utf8_general_cisocket = /var/lib/mysql/mysql.sockskip-external-lockingkey_buffer_size = 384Mmax_allowed_packet = 1Mtable_open_cache = 512sort_buffer_size = 2Mread_buffer_size = 2Mread_rnd_buffer_size = 8Mmyisam_sort_buffer_size = 64Mthread_cache_size = 8query_cache_size = 32M# Try number of CPU's*2 for thread_concurrencythread_concurrency = 8 [mysql]no-auto-rehash# 还有这一行default-character-set=utf8

3、Mysql配置文件

主要配置文件

二进制日志log-bin主从复制

d53c3865e38a1914f4bc70eaf6350e2.png

错误日志log-error默认是关闭的,记录严重的警告和错误信息,每次启动和关闭的详细信息等。查询日志log默认关闭,记录查询的sql语句,如果开启会减低mysql的整体性能,因为记录日志也是需要消耗系统资源的数据文件两系统windowsD:devSoftMySQLServer5.5data目录下可以挑选很多库Linux:默认路径 #cd /var/lib/mysql/看看当前系统中的全部库后再进去 #ls -1F | grep ^dfrm文件: 存放表结构**myd文件: ** 存放表数据**myi文件: ** 存放表索引如何配置Windows: my.ini文件Linux:  /etc/my.cnf文件

4、Mysql逻辑架构介绍

总体概览

和其它数据库相比,MySQL有点与众不同,它的架构可以在多种不同场景中应用并发挥良好作用。主要体现在存储引擎的架构上,插件式的存储引擎架构将查询处理和其它的系统任务以及数据的存储提取相分离。这种架构可以根据业务的需求和实际需要选择合适的存储引擎。

bf8cfeecfa27d07dab97dc778cfc29a.png

1、连接层最上层是一些客户端和连接服务,包含本地sock通信和大多数基于客户端/服务端工具实现的类似于tcp/ip的通信。主要完成一些类似于连接处理、授权认证、及相关的安全方案。在该层上引入了线程池的概念,为通过认证安全接入的客户端提供线程。同样在该层上可以实现基于SSL的安全链接。服务器也会为安全接入的每个客户端验证它所具有的操作权限。2、服务层第二层架构主要完成大多少的核心服务功能,如SQL接口,并完成缓存的查询,SQL的分析和优化及部分内置函数的执行。所有跨存储引擎的功能也在这一层实现,如过程、函数等。在该层,服务器会解析查询并创建相应的内部解析树,并对其完成相应的优化如确定查询表的顺序,是否利用索引等,最后生成相应的执行操作。如果是select语句,服务器还会查询内部的缓存。如果缓存空间足够大,这样在解决大量读操作的环境中能够很好的提升系统的性能。3、引擎层存储引擎层,存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。不同的存储引擎具有的功能不同,这样我们可以根据自己的实际需要进行选取。后面介绍MyISAM和InnoDB4、存储层数据存储层,主要是将数据存储在运行于裸设备的文件系统之上,并完成与存储引擎的交互。

查询说明

首先,mysql的查询流程大致是:mysql客户端通过协议与mysql服务器建连接,发送查询语句,先检查查询缓存,如果命中,直接返回结果,否则进行语句解析有一系列预处理,比如检查语句是否写正确了,然后是查询优化(比如是否使用索引扫描,如果是一个不可能的条件,则提前终止),生成查询计划,然后查询引擎启动,开始执行查询,从底层存储引擎调用API获取数据,最后返回给客户端。怎么存数据、怎么取数据,都与存储引擎有关。然后,mysql默认使用的BTREE索引,并且一个大方向是,无论怎么折腾sql,至少在目前来说,mysql最多只用到表中的一个索引。

5、Mysql存储引擎

查看命令查看当前的MySQL 提供什么存储引擎mysql> show engines;看你的 MySQL 当前默认的存储引擎:show variables like '%storage_engine%';

默认的存储引擎

MyISAMInnoDB

MySQL高级知识之 架构介绍b679e1edb459e67f802dabd9bccd941.png

两种引擎对比

阿里巴巴、淘宝用哪个Percona 为 MySQL 数据库服务器进行了改进,在功能和性能上较 MySQL 有着很显著的提升。该版本提升了在高负载情况下的 InnoDB 的性能、为 DBA 提供一些非常有用的性能诊断工具;另外有更多的参数和命令来控制服务器行为。该公司新建了一款存储引擎叫xtradb完全可以替代innodb,并且在性能和并发上做得更好,阿里巴巴大部分mysql数据库其实使用的percona的原型加以修

以上就是MySQL高级知识之 架构介绍的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/190091.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月1日 12:42:35
下一篇 2025年11月1日 12:43:48

相关推荐

  • Golang初级项目完整指南 从零到上线

    对于初学者来说,从零开始搭建并成功上线一个Go语言项目,关键在于理解其简洁高效的特性,并遵循一套从概念到部署的实践路径。这不仅仅是写几行代码,更是一次系统性思考和解决问题的过程,涵盖了从项目初始化、依赖管理、核心逻辑开发、测试到最终部署上线的全链路。 解决方案 要将一个Go语言初级项目从零带到线上,…

    2025年12月15日
    000
  • Golang如何集成数据库开发环境 常见数据库驱动配置

    首先引入database/sql标准库和对应数据库驱动,如MySQL的github.com/go-sql-driver/mysql;通过sql.Open()使用DSN连接数据库,需正确配置用户名、密码、地址等信息;导入驱动时使用下划线表示仅执行初始化注册;成功获取*sql.DB实例后,应设置连接池参…

    2025年12月15日
    000
  • Golang网络编程中的连接池管理 对比不同连接池实现方案

    连接池能显著提升性能和资源利用率。在没有连接池时,每次请求需新建并关闭tcp连接,耗时且易导致资源限制问题;使用连接池后可复用连接,减少开销,并控制最大连接数防止资源耗尽。常见连接池库包括database/sql(适合数据库场景但配置有限)、net/http transport(内置http连接复用…

    2025年12月15日 好文分享
    000
  • Golang实现云原生数据库代理 分库分表中间件开发

    答案:基于Golang构建云原生数据库代理需集成SQL解析、路由引擎、连接池与结果合并模块,选用vitess或TiDB解析器,支持分库分表路由策略,结合Kubernetes实现服务发现与弹性伸缩,通过Prometheus监控保障稳定性。 要用 Golang 实现云原生数据库代理,并支持分库分表,核心…

    2025年12月15日
    000
  • Golang模块如何支持多数据库驱动 讲解database/sql解耦设计实践

    golang项目支持多数据库驱动的关键在于利用database/sql标准库的解耦设计。其核心方法包括:1. 接口抽象,通过统一接口实现业务逻辑与具体数据库解耦;2. 驱动注册机制,通过匿名导入驱动包并在运行时动态选择数据库类型;3. 项目结构分层,定义统一dao接口、为不同数据库编写适配器并根据配…

    2025年12月15日 好文分享
    000
  • Golang连接MySQL数据库 database/sql使用指南

    答案:使用database/sql包和go-sql-driver/mysql驱动连接MySQL,需正确配置DSN(含charset、parseTime、loc等参数)以避免乱码和时间处理错误,合理设置连接池参数(MaxOpenConns、MaxIdleConns、ConnMaxLifetime)提升…

    2025年12月15日
    000
  • Golang多租户实现 数据库隔离方案

    独立数据库提供最高安全性,适合高合规场景但成本高;2. 共享数据库独立Schema平衡隔离与运维,适用于中等规模租户;3. 共享表通过tenant_id区分数据,资源高效但依赖代码严谨;4. 混合方案按租户等级灵活选择,结合中间件解析租户、GORM回调注入条件、上下文传递租户ID,确保数据隔离贯穿调…

    2025年12月15日
    000
  • 怎样用Golang实现工厂模式 对比简单工厂与抽象工厂区别

    简单工厂模式适用于创建单一类型的不同对象,通过一个工厂函数根据参数返回具体实现,适合产品种类少且变化不频繁的场景;抽象工厂模式则用于创建一组相关或依赖的对象家族,通过定义抽象工厂接口和多个具体工厂来保证产品间的一致性,适合需要整体切换产品族的复杂系统。两者核心区别在于简单工厂关注单个对象创建,抽象工…

    2025年12月15日
    000
  • Golang Web项目架构 分层设计最佳实践

    分层设计通过职责分离提升Go Web项目的可维护性与可测试性,典型模式为Handler→Service→Repository→Model四层架构,各层通过接口解耦并依赖注入实现低耦合,便于测试、协作与扩展。 在构建Golang Web项目时,采用分层设计是确保项目可维护、可扩展和易于测试的关键。它本…

    2025年12月15日
    000
  • 如何在Golang中处理CSV大文件 介绍csv.Reader流式处理与内存管理

    在golang中处理csv大文件应使用流式处理,通过csv.reader逐行读取以避免内存暴涨。具体步骤包括:1. 使用csv.newreader配合os.open按行读取文件;2. 避免累积数据、及时释放引用、使用指针传递结构体、合理设置缓冲区以控制内存;3. 推荐边读边写或分批处理,如每读100…

    2025年12月15日 好文分享
    000
  • 怎样测试Golang的数据库操作 使用测试容器与mock方案

    测试Golang数据库操作需隔离外部依赖,常用测试容器和Mock框架。2. 测试容器如Testcontainers启动真实数据库做集成测试,验证SQL、事务等真实行为。3. 示例使用testcontainers-go启动PostgreSQL,初始化表结构,执行CRUD并验证结果。4. Mock框架如…

    2025年12月15日
    000
  • Golang云原生数据库代理 分片中间件

    基于Golang的云原生数据库分片中间件通过SQL解析与路由、连接池管理、结果合并、读写分离及高可用机制,实现数据库水平拆分;利用Golang高性能网络编程、丰富SQL解析库和云原生集成优势,结合协议解析层、路由引擎、元数据管理、执行引擎和监控组件,构建高效可扩展架构,参考Vitess等开源项目,支…

    2025年12月15日
    000
  • Go语言中SQL数据库访问:database/sql 包与驱动生态

    Go语言通过其标准库中的database/sql包提供了一套统一的SQL数据库访问接口。该包定义了通用的数据库操作规范,而具体的数据库连接与操作则由遵循其driver接口的第三方驱动实现。这种设计模式确保了Go在数据库操作上的灵活性、可扩展性和高性能,使其能够广泛应用于各类任务关键型应用,而非仅限于…

    2025年12月15日
    000
  • Golang构建云原生监控工具 Prometheus Exporter开发

    云原生环境中,监控是保障系统稳定运行的关键环节。Prometheus 作为主流的开源监控系统,通过拉取模式采集指标数据,广泛应用于 Kubernetes、微服务架构等场景。而 Go 语言(Golang)凭借其高并发、低延迟和静态编译的特性,成为开发 Prometheus Exporter 的理想选择…

    2025年12月15日
    000
  • Golang构建RSS阅读器 网络Feed解析

    答案是使用Go的net/http库获取Feed并结合gofeed解析,通过设置超时、重试机制和SQLite存储实现高效RSS阅读器。 构建一个Golang的RSS阅读器,核心在于有效地从网络获取并解析不同格式的Feed数据。这通常涉及HTTP请求、XML/Atom解析库的选择与使用,以及如何处理网络…

    2025年12月15日
    000
  • Go语言数据库操作:深入理解database/sql包与生态系统

    本文旨在全面解析Go语言中SQL数据库的连接与管理机制。我们将重点探讨标准库database/sql包如何提供一个统一、高效的数据库操作接口,以及第三方驱动如何在此框架下实现对各类SQL数据库的支持。通过理解其设计哲学、核心功能及使用示例,读者将能够自信地在Go项目中集成和管理关系型数据库,打消对官…

    2025年12月15日
    000
  • Go语言数据库连接:深入理解database/sql包与驱动生态

    Go语言通过其内置的database/sql包提供了一套统一的数据库访问接口,该包定义了与数据库交互的标准抽象。具体的数据库连接功能则由遵循driver接口的第三方驱动实现。这种设计模式确保了Go语言在数据库操作上的灵活性与可扩展性,允许开发者根据需求选择合适的数据库驱动,而非依赖单一的官方实现,从…

    2025年12月15日
    000
  • Golang工厂模式应用场景 简单工厂与抽象工厂对比

    简单工厂通过参数创建具体对象,适用于类型少、逻辑集中的场景,如日志记录器;抽象工厂创建相关对象族,适用于多维度变化,如数据库驱动。 在Go语言开发中,工厂模式是一种常用的创建型设计模式,主要用于解耦对象的创建过程。它通过提供一个统一的接口来创建不同类型的对象,避免在代码中直接使用具体的构造函数。常见…

    2025年12月15日
    000
  • Golang SQL注入防护 预处理参数化查询

    使用预处理和参数化查询可有效防御SQL注入,Golang中通过database/sql包的Prepare和Query方法实现,确保用户输入作为数据而非代码执行,从根本上隔离风险。 Golang中防御SQL注入的核心策略是使用预处理(Prepared Statements)和参数化查询,它能有效区分代…

    2025年12月15日
    000
  • 如何用Golang构建全栈Web应用 介绍模板渲染与前端资源整合

    构建golang全栈web应用需关注后端框架选择、数据库交互、api设计、模板渲染、前端资源整合及部署等核心步骤。1. 后端框架推荐使用gin、echo或beego,其中gin适合小型项目和api服务;2. 数据库交互可选用database/sql配合驱动或orm框架如gorm;3. api设计应遵…

    2025年12月15日 好文分享
    000

发表回复

登录后才能评论
关注微信