在Windows系统中,MySQL的配置文件为my.ini,在Linux系统中,配置文件为my.cnf,一般存放路径为/etc/my.cnf或/etc/mysql/my.cnf。...每次更改文件后,需要重启MySQL服务,使修改生效。...在该配置文件中,可以配置[client]、[mysqld]、[mysqldump]、[mysql]、[myisamchk]、[mysqlhotcopy]等模块,分别作用于不同的服务。...有个疑问:配置文件中的配置项和用 show variables 命令查看到的配置项是什么关系?...pid-file:pid所在的目录; log-error:错误日志文件路径; user:mysql服务的启动用户; open_files_limit:设定mysql打开最大文件数,MySQL打开的文件描述符限制
就像锁粒度的升级会增加系统开销一样,事务处理过程中也会增加服务器的开销。需要更强的CPU,更大的内存和磁盘空间。用户可以根据业务是否需要事务,来选择合适的存储引...
在MySQL中,只有Memory引擎显示支持哈希索引,这也是Memory引擎的默认索引类型。...三、高性能的索引策略 3.1、独立的列 索引列不能是表达式的一部分,也不能是函数的参数。...其实mysql可以使用索引来直接获取列的数据。...MySQL和存储引擎访问数据的方式, 加上索引的特性,使得索引成为一个影响数据访问的有力而灵活的工作(无论数据是在 磁盘中还是在内存中)。 在MySQL中,大多数情况下都会使用B-Tree索引。...参考: 《高性能 MySQL 第三版》 聚簇索引和非聚簇索引 mysql-覆盖索引 创建高性能的索引
一、Mysql逻辑架构 如果能在头脑中构建出一幅MySQL各组件之间如何协同工作的架构图,就会有助于深入理解MySQL服务器。.../lizhengi/MySQL/高性能MySQL/T.Mysql逻辑图.png)] 从上图可以看出My SQL逻辑结构大致可以分为三层: 第一层结构主要处理客户端与mysql服务端的连接、授权认证、安全等...加锁是实现并发控制的基本方法,MySQL中锁的粒度: 表级锁(服务器层):MySQL独立于存储引擎提供表锁,例如,对于ALTER TABLE语句,服务器提供表锁(table-level lock)。...如果能理解MySQL 在存储引擎和服务层之间处理查询时如何通过API来回交互,就能抓住MySQL的核心 基础架构的精髓。...参考: 《高性能 MySQL 第三版》 MySQL逻辑架构简介 mysql的并发控制
一,MySQL逻辑架构 第一层的服务不是MySQL独有的,大多数基于网络的客户端/服务器的工具或者服务都有类似的架构。比如连接处理、授权认证、安全等。 第二层架构是MySQL比较有意思的部分。...这层是MySQL的核心服务功能,包含:查询解析、分析、优化、缓存以及所有的内置函数(例如日期、时间、数学运算)所有跨存储引擎的功能都在这一层实现:存储过程、触发器、视图等。 第三层是存储引擎。...存储引擎负责MySQL中数据的存储和提取。服务器通过API和存储引擎进行通信。这些接口屏蔽了不同存储引擎之间的差异,使得这些差异对上层的查询过程透明。...MySQL提供了一个API,支持线程池插件,可以使用池中少量的线程来服务大量的连接。...三、优化与执行 MySQL会解析查询,并创建内部数据结构(解析树),然后对查询进行优化,包括重写查询、决定表的读取顺序,选择合适的索引等。用户可以通过特殊的关键字提示优化器,影响它的决策过程。
MySQL架构和历史 MySQL逻辑架构 第一层处理网络连接等, 比如链接认证授权等 第二层是 MySQL 的核心, 用来解析优化 SQL 语句, 设计缓存, 以及各种函数的实现, 包括存储过程, 触发器...客户端连接]auth[检查用户名密码]access[检查是否有对应资源的处理权限]query[执行SQL 操作]start-->authauth-->accessaccess-->query 并发控制 MySQL...即只对自己事务内部的数据有影响, 也叫不可重复读 REPEATEABLE READ 可重复读, A 事务本身对数据的修改对 A 事务后边的语句也不起作用, 所有的 SQL 操作的数据都来自数据库, 这是 MySQL...默认的事务隔离级别 SERIALIZABLE 可串行化, 这种会在事务操作的每一行记录上都加一个锁, 会严重降低性能, 但是数据一致性比较高 事务日志是顺序 I/O, 日志采用追加的方式 MySQL...存储引擎 InnoDB 支持行级锁 支持事务 全表使用 B+ tree 实现 数据只存在叶子节点上 MyISAM 不支持行级锁, 只支持表锁 数据文件和索引文件分开 不支持事务 可以通过压缩表技术提高性能
目录 前言 测试环境 MySQL配置文件在哪里?...my.cnf配置文件说明 修改配置文件 ---- 前言 本文主要介绍MySQL配置文件(my.cnf) ---- 测试环境 虚拟机环境:VirtualBox 6.0.24 操作系统:Oracle Linux...Server release 6.5 x86_64 MySQL版本:5.7.33 ---- MySQL配置文件在哪里?...~/.my.cnf 通过以上命令可以看出,mysql启动是会有一个读取配置文件的优先顺序 [root@rac02 ~]# locate my.cnf /etc/my.cnf #本环境中mysql的配置文件...my.cnf配置文件说明 默认配置文件查看: [mysqld] datadir = /usr/local/mysql/mysql-files socket = /usr/local/mysql/mysql-files
一、文件名和路径 1.Linux中: /etc/my.cnf 2.windows中: C:\ProgramData\MySQL\MySQL Server 5.7\my.ini 二、常见问题: 1.windows...下mysql配置文件my.ini的位置 (1)找到“服务”,搜索MySQL (2)右击属性查看位置 可以看到在可执行文件的路径是C:\ProgramData\MySQL\MySQL...Server 5.7\my.ini,即mysql的配置文件在该目录下。...显示之后,ProgramData出来了,按照路径一路查找过去,终于找到了my.ini配置文件。
优点是并不需要记录每一条sql语句和每一行的数据变化,减少了binlog日志量,节约IO,提高性能。...将开启binlog日志,mysql-bin 是日志的基本名或前缀名,可以更换。...查询: 在线配置: 配置文件:log-bin=mysql-bin | log-bin-index=mysql-bin.index expire_logs_days 超过指定天数的binlog将被删除 查询...查询:show variables like '%relay%'; 在线配置: 配置文件:relay-log=mysql.relay-log | relay-log-index=mysql.relay-log.index...:relay-log=mysql.relay-log | relay-log-index=mysql.relay-log.index max_relay_log_size 从服务器在主服务器上复制的binlog
高性能MySQL读书笔记。。。 MySQL架构 并发控制 读写锁 在处理并发读或者写时,通过实现一个由两种类型的锁组成的锁系统来解决问题。...MySQL的存储引擎 默认引擎为InnoDB,一般没有特殊需求直接使用即可。...意思是要用要求的表结构创建一张和源表无关的新表,然后通过重命名和删表操作交换两张表 不是所有的ALTER TABLE操作都会引起表重建,有两种方式: 只修改.frm文件 快速创建myisam索引 创建高性能的索引...索引的三个优点 大大减少服务器需要扫描的数据量 帮助服务器避免排序和临时表 将随机io变为顺序io 高性能的索引策略 独立的列 如果查询中的列不是独立的,则mysql就不会使用索引 前缀索引和索引选择性...压缩(前缀压缩)索引 MyISAM使用前缀压缩来减少索引的大小,从而让更多的索引可以防到内存中,在某些情况下可以极大提高性能。
为方便查看,建议点击或下载保存以下思维导图图片来放大查看。
1.mysql的索引工作类似一本书的目录部分,想找某个特定主题,先查找书的目录部分,找到对应的页码 2.ORM工具只能生成基本的合法的查询 3.索引是在存储引擎层实现的,不是服务器层 4.B-tree就是指的...content='haha' 10.三星评价系统:一星 索引将相关记录放一起;二星 数据顺序和查找顺序一致;三星 索引中包含了全部查询列 11.扩展:增加个元数据信息表,例如"哪个用户的信息存储在哪个表中" 高性能的使用索引策略
1.1 前言 在进行MySQL的优化之前必须要了解的就是MySQL的查询过程,很多的查询优化工作实际上就是遵循一些原则让MySQL的优化器能够按照预想的合理方式运行而已。 ?...安全 ---> 数据可持续性 性能 ---> 数据的高性能访问 1.3.2 优化的范围有哪些 存储、主机和操作系统方面: 主机架构稳定性 I/O规划及配置 Swap交换分区...SWAP: MySQL尽量避免使用swap。...修改MySQL的配置参数innodb_flush_method,开启O_DIRECT模式。 ...1.6 数据库优化 SQL优化方向: 执行计划、索引、SQL改写 架构优化方向: 高可用架构、高性能架构、分库分表 1.6.1 数据库参数优化 调整: 实例整体(高级优化,扩展): innodb_thread_concurrency
高性能MySQL之缓存 MySQL中的缓存是用来避免所查询的数据需要对磁盘进行访问,我们知道,磁盘上的访问会比内存的访问速度慢得多,所以,如果你的服务器上之部署了一个MySQL的服务,那么为它配置一个大的缓存无疑是明智之举...默认情况下,MyISAM将所有的索引都缓存在默认的键缓存中,当然,这个值我们可以在配置文件中手动设置。...,那么MySQL将会跳过所有的阶段,直接从缓存中拿到结果并返回给客户端。...在MySQL中,用于查询缓存的内存被分成了一个个的数据块,这些数据块中存储了自己的类型,大小和存储的数据本身,除了这些数据块之外,还有一个元数据维护的数据结构,当有查询结果需要缓存的时候,MySQL先从大的空间中申请一个数据块用于存储数据结果...,这个数据块的大小是由参数query_cache_min_res_unit决定的,到这里,我们知道MySQL无法为每一个查询的结果精确分配恰好匹配的缓存空间。
本节讨论MySQL在两个层面的并发控制:服务器层和存储引擎层。1、读写锁在处理并发读合并发写时,可以通过实现一个由两种类型的锁系统来解决问题。这两种类型的锁通常被称为共享锁和排他锁,也叫读锁和写锁。...在实际的数据库系统中,每时每刻都在发生锁定,当某个用户在修改一部分数据时,MySQL会通过锁定防止其他用户读取同一数据。1.1 锁粒度提高共享资源并发性的方式就是让锁定对象更有选择性。...MySQL提供了多种选择,每种MySQL存储引擎都可以实现自己的锁策略和锁粒度。MySQL支持多个存储引擎的架构,配置不同的锁策略和锁粒度,来支持不同场景的性能。...1.1.1表锁表锁是MySQL最基本的锁策略,并且是开销最小的策略。1.1.2 行级锁行级锁可以最大程度地支持并发处理,但同时也带来了最大的锁开销。在InnoDB和XtraDB实现了行级锁。...行级锁只在存储引擎层实现,MySQL服务层没有实现。服务器层完全不了解存储引擎中的锁实现。每天学一点,每天进步一点!
文章目录 前言 MySQL架构与历史 MySQL逻辑架构 连接管理 优化与执行 并发控制 锁粒度 表锁 行级锁 事务 隔离级别 事务日志 前言 我准备开一个新的系列,这是我以前接触不多的新领域...本系列取材于《高性能MySQL》第三版,是我的学习笔记。...---- MySQL架构与历史 MySQL逻辑架构 第二层架构是MySQL比较有意思的部分,大多数MySQL的核心服务功能都在这一层,包括增删查改以及所有的内置函数。...表锁 表锁是MySQL中最基本的锁策略,也是开销最小的策略。它会锁定整张表。...可重复度是MySQL默认事务隔离级别。 可串行化:这个是最高的隔离级别了,它通过强制要求事务串行执行,避免了前面所说的幻读问题。
innodb_old_blocks_pct增大,减小 innodb_old_blocks_time的时间,让有用的查询缓存数据尽量缓存在innodb_buffer_pool_size中,减小磁盘io,提高性能...作用范围为全局或会话级别,可用于配置文件,属动态变量。...所以在很多Linux发行版的源中,MySQL配置文件中默认使用了skip-external-locking来避免external locking。...MySQL5.5默认是关闭的,需要手动开启,在配置文件里添加 #performance_schema_events_waits_history_long_size= #performance_schema_events_waits_history_size...根据配置文件会限制Server接受的数据包大小。
以前要是想知道 my.cnf 配置文件,写的有没有问题;一个可行的方案就用它来启动一个 MySQL 服务,如果能正常地起来,说明至少没有致命的错误。现在看来不需要搞这么复杂了。...mysqld --defaults-file=/etc/my-3309.cnf --validate-config 也就是说我们只需要多指定一个 --validate-config 选项就行,如果配置文件有问题...auto mysqld 可以看到 8.0.29 , 8.0.30, 8.0.31 三个版本同时在我的机器上跑着,有一次我无意间用一个 8.0.31 的 mysqld 程序去检查一个 8.0.30 版本的配置文件...# 这里的 /etc/my-3308.cnf 是一份 8.0.30 的配置文件 cd /usr/local/mysql-8.0.31-linux-glibc2.12-x86_64/ bin/mysqld...可以看到它通过配置文件找到了 basedir ,并且默默的帮我检查了 basedir 下的文件对不对,这也真的够仔细了。 ----
[mysqld] #MySQL启动用户 user = mysql #设置mysql的安装目录 basedir=/usr/local/mysql #mysql.sock存放目录 socket=/var/lib.../mysql/mysql.sock #设置mysql数据库的数据的存放目录 datadir=/usr/local/mysql/data #日志文件输出 log-error=/var/log/mariadb...lower_case_table_names=1 #MySQL存放临时文件的目录 tmpdir = /data/tmpdate
领取专属 10元无门槛券
手把手带您无忧上云