事务控制语句
data:image/s3,"s3://crabby-images/0a7f9/0a7f9dc92b0408f82a9a8a48ae8015c83d11eb68" alt=""
data:image/s3,"s3://crabby-images/dfaee/dfaeede57dc4114f9cc53457470d1addcdaeca61" alt=""
行锁和死锁
data:image/s3,"s3://crabby-images/edee8/edee878352906e9ab944c4b98c30fbc15efa4fb2" alt=""
行锁
两个客户端同时对同一索引行进行操作
客户端1正常运行
data:image/s3,"s3://crabby-images/d22e3/d22e3b5871141174b3094805f53387f9a3960833" alt=""
客户端2想修改,被锁行
data:image/s3,"s3://crabby-images/c9d3d/c9d3d0f3b2fe7a3c7510b6fd5f4ac42d579f1d35" alt=""
除非将事务提交才能继续运行
死锁
客户端1删除第5行
data:image/s3,"s3://crabby-images/c3558/c35582d1dcfca7870d308a3f6782103cc7075684" alt=""
客户端2设置第1行为排他锁
data:image/s3,"s3://crabby-images/5a633/5a633b0133a0435a7c4276cddf90708c532af9b3" alt=""
客户端1删除行1被锁
data:image/s3,"s3://crabby-images/c6486/c64868e07f81af883ac0b186e88841450de792c5" alt=""
客户端2更新行5被锁
data:image/s3,"s3://crabby-images/73fdc/73fdcae4e554b7f566508645348f17192f32a8e0" alt=""
data:image/s3,"s3://crabby-images/69d95/69d95c7e316aa0a802bc957afdf0d0fe2f937e29" alt=""
如何避免死锁
data:image/s3,"s3://crabby-images/b9bf0/b9bf062778116a58116024b1469915032b0a5ec7" alt=""
mysql的备份和还原以及日志管理
备份的目的就是灾难恢复
数据备份的分类
data:image/s3,"s3://crabby-images/b0870/b0870b1d19550178b970cd95e5439287f7b0d0b1" alt=""
备份策略
data:image/s3,"s3://crabby-images/58f0a/58f0ae1453aa4072ee1d45611268dd9da50c6fef" alt=""
全量备份
data:image/s3,"s3://crabby-images/e7762/e7762593ac7b6c6e0aec22ca5fa8e06c89f8b8cd" alt=""
查看mysql数据保存路径
vim /etc/my.cnf
data:image/s3,"s3://crabby-images/08c81/08c8161859640512b508f9cb9a53b4073ac0ebee" alt=""
tar Jcvf /opt/mysql_all_$(date +%F).tar.xz /usr/local/mysql/data/
把mysql的data目录,打包的格式.xz,保存到opt的目录下
data:image/s3,"s3://crabby-images/a5474/a5474f096deec81a57361b32f464b1b36f39c63e" alt=""
mysqldump的备份和恢复
data:image/s3,"s3://crabby-images/9b0ba/9b0ba44005e881a59636d1415166c160d16b02c9" alt=""
data:image/s3,"s3://crabby-images/5d4af/5d4afbc2a8788e708e797a9ea927085d32eb2266" alt=""
data:image/s3,"s3://crabby-images/0f2a7/0f2a789d0531f9e363593b1f1f394132fc9bb355" alt=""
热备份
data:image/s3,"s3://crabby-images/e9be2/e9be20681afa42faed4a29d616195321a0c34dbb" alt=""
通过二进制日志进行备份和还原
先将mysql的二进制日志功能打开
data:image/s3,"s3://crabby-images/0ef0a/0ef0af0f046ca540a7d85b74f097ce90383e59c0" alt=""
二进制日志的记录格式
data:image/s3,"s3://crabby-images/ae77f/ae77fb563354109c1cf1d8c930f560aa8e9fd9e1" alt=""
data:image/s3,"s3://crabby-images/b1f34/b1f34a489b8929acf8e8ec45c8259fc749f3f1e9" alt=""
使用mysqlbinlog命令来查看日志文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000001
data:image/s3,"s3://crabby-images/7c8f5/7c8f53dbf16c6b627cca6d448d5d0ee833e06ac1" alt=""
二进制日志的分割
mysqladimn -u root -p123456 flush-log
data:image/s3,"s3://crabby-images/ec7d3/ec7d30bf863158ea22c993fe88d1bf811ba1a0e1" alt=""
通过二进制日志进行恢复
mysqlbinlog --no-defaults mysql-bin.000001 | mysql -u root -p123456
如果日志在当前文件则不需要指明路径,反之必须指明路径
data:image/s3,"s3://crabby-images/61e65/61e651168bf93c717b7e13c0e6b519d94ab7ad13" alt=""
mysqladmin -u root -p123456 flush-logs
我们是按天来执行的,我们就可以按天对数据库进行增量的备份。
mysqlbinlog --no-defaults mysql-bin.000004 | mysql -u root -p123456
基于位置和时间进行恢复
mysqlbinlog --no-defaults --start-position='1338' mysql-bin.000005 | mysql -u root -p123456
从指定位置开始恢复数据,一直恢复到文件的结尾。
mysqlbinlog --no-defaults --stop-position='1338' mysql-bin.000005 | mysql -u root -p123456
从开始恢复到结束位置
从指定位置开始,到指定的位置结束:
mysqlbinlog --no-defaults --start-position='1338' --stop-position='1338' mysql-bin.000005 |mysql -u root -p123456
mysqlbinlog --no-defaults --start-datetime='1338' mysql-bin.000005 | mysql -u root -p123456
从指定时间开始恢复数据,一直恢复到文件的结尾。
mysqlbinlog --no-defaults --stop-datetime='1338' mysql-bin.000005 | mysql -u root -p123456
从开始时间到结束位置
从指定时间开始,到指定的时间结束:
mysqlbinlog --no-defaults --start-datetime='2024-12-20 13:47:17' --stop-datetime='2024-12-20 13:47:38' mysql-bin.000005 |mysql -u root -p123456
log-error=/usr/local/mysql/date/mysql-error.log
#记录mysql在启动,停止或者是运行时,产生错误的日志
general_log=ON general_log_file=/usr/local/mysql/date/mysql_general.log
#开启mysql在使用过程中的记录日志
slow_query_log=ON slow_query_log_file=/usr/local/mysql/date/mysql_slow_query.log long_query_time=5
#开启慢查询日志,用来记录所有查询的时间超过long_query_time=5的记录,查询的执行时间超过5秒钟就会记录。
不注明,默认是10秒
开启错误日志
og-error=/usr/local/mysql/date/mysql-error.log
#记录mysql在启动,停止或者是运行时,产生错误的日志
general_log=ON general_log_file=/usr/local/mysql/date/mysql_general.log
#开启mysql在使用过程中的记录日志
slow_query_log=ON slow_query_log_file=/usr/local/mysql/date/mysql_slow_query.log long_query_time=5
#开启慢查询日志,用来记录所有查询的时间超过long_query_time=5的记录,查询的执行时间超过5秒钟就会记录。
不注明,默认是10秒