mysql数据库从库同步延迟的解决方案

MySQL主从复制实际上基于二进制日志,原理可以用一张图来表示:
在这里插入图片描述
分为四步走:

  1. 主库对所有DDL和DML产生的日志写进binlog;

  2. 主库生成一个 log dump 线程,用来给从库I/O线程读取binlog;

  3. 从库的I/O Thread去请求主库的binlog,并将得到的binlog日志写到relay log文件中;

  4. 从库的SQL Thread会读取relay log文件中的日志解析成具体操作,将主库的DDL和DML操作事件重放。

关于DDL和DML

SQL语言共分为四大类:查询语言DQL,控制语言DCL,操纵语言DML,定义语言DDL。

DQL:可以简单理解为SELECT语句;

DCL:GRANT、ROLLBACK和COMMIT一类语句;

DML:可以理解为CREATE一类的语句;

DDL:INSERT、UPDATE和DELETE语句都是

在从服务器上执行show slave status;可以查看到很多同步的参数,我们需要特别注意的参数如下:

Master_Log_File:                      SLAVE中的I/O线程当前正在读取的主服务器二进制日志文件的名称
Read_Master_Log_Pos:        在当前的主服务器二进制日志中,SLAVE中的I/O线程已经读取的位置
Relay_Log_File:                        SQL线程当前正在读取和执行的中继日志文件的名称
Relay_Log_Pos:                        在当前的中继日志中,SQL线程已读取和执行的位置
Relay_Master_Log_File:      由SQL线程执行的包含多数近期事件的主服务器二进制日志文件的名称
Slave_IO_Running:                 I/O线程是否被启动并成功地连接到主服务器上
Slave_SQL_Running:              SQL线程是否被启动
Seconds_Behind_Master:     从属服务器SQL线程和从属服务器I/O线程之间的时间差距,单位以秒计。

从库同步延迟情况出现的
1、show slave status显示参数Seconds_Behind_Master不为0,这个数值可能会很大
2、show slave status显示参数Relay_Master_Log_File和Master_Log_File显示bin-log的编号相差很大,说明bin-log在从库上没有及时同步,所以近期执行的bin-log和当前IO线程所读的bin-log相差很大
3、mysql的从库数据目录下存在大量mysql-relay-log日志,该日志同步完成之后就会被系统自动删除,存在大量日志,说明主从同步延迟很厉害

a、MySQL数据库主从同步延迟原理

mysql主从同步原理:
主库针对写操作,顺序写binlog,从库单线程去主库顺序读”写操作的binlog”,从库取到binlog在本地原样执行(随机写),来保证主从数据逻辑上一致。
mysql的主从复制都是单线程的操作,主库对所有DDL和DML产生binlog,binlog是顺序写,所以效率很高,slave的Slave_IO_Running线程到主库取日志,效率比较高,下一步,问题来了,slave的Slave_SQL_Running线程将主库的DDL和DML操作在slave实施。DML和DDL的IO操作是随即的,不是顺序的,成本高很多,还可能可slave上的其他查询产生lock争用,由于Slave_SQL_Running也是单线程的,所以一个DDL卡主了,需要执行10分钟,那么所有之后的DDL会等待这个DDL执行完才会继续执行,这就导致了延时。
有朋友会问:“主库上那个相同的DDL也需要执行10分,为什么slave会延时?”,答案是master可以并发,Slave_SQL_Running线程却不可以。

常见原因:Master负载过高、Slave负载过高、网络延迟、机器性能太低、MySQL配置不合理。
b、 MySQL数据库主从同步延迟是怎么产生的?

当主库的TPS并发较高时,产生的DDL数量超过slave一个sql线程所能承受的范围,那么延时就产生了,当然还有就是可能与slave的大型query语句产生了锁等待。
首要原因:数据库在业务上读写压力太大,CPU计算负荷大,网卡负荷大,硬盘随机IO太高
次要原因:读写binlog带来的性能影响,网络传输延迟。

c、 MySQL数据库主从同步延迟解决方案。

架构方面
1.业务的持久化层的实现采用分库架构,mysql服务可平行扩展,分散压力。
2.单个库读写分离,一主多从,主写从读,分散压力。这样从库压力比主库高,保护主库。
3.服务的基础架构在业务和mysql之间加入memcache或者redis的cache层。降低mysql的读压力。
4.不同业务的mysql物理上放在不同机器,分散压力。
5.使用比主库更好的硬件设备作为slave

总结,mysql压力小,延迟自然会变小。

硬件方面

1.采用好服务器,比如4u比2u性能明显好,2u比1u性能明显好。
2.存储用ssd或者盘阵或者san,提升随机写的性能。
3.主从间保证处在同一个交换机下面,并且是万兆环境。
总结,硬件强劲,延迟自然会变小。一句话,缩小延迟的解决方案就是花钱和花时间。

mysql主从同步加速

1、sync_binlog在slave端设置为0
2、–logs-slave-updates 从服务器从主服务器接收到的更新不记入它的二进制日志。
3、直接禁用slave端的binlog
4、slave端,如果使用的存储引擎是innodb,innodb_flush_log_at_trx_commit =2

通过监控 show slave status 命令输出的Seconds_Behind_Master参数的值来判断:
NULL,表示io_thread或是sql_thread有任何一个发生故障;
0,该值为零,表示主从复制良好;
正值,表示主从已经出现延时,数字越大表示从库延迟越严重

在这里插入图片描述

从文件系统本身属性角度优化
master端
修改linux、Unix文件系统中文件的etime属性, 由于每当读文件时OS都会将读取操作发生的时间回写到磁盘上,对于读操作频繁的数据库文件来说这是没必要的,只会增加磁盘系统的负担影响I/O性能。可以通过设置文件系统的mount属性,组织操作系统写atime信息,在linux上的操作为:
打开/etc/fstab,加上noatime参数
/dev/sdb1 /data reiserfs noatime 1 2
然后重新mount文件系统
#mount -oremount /data

PS:
主库是写,对数据安全性较高,比如sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之类的设置是需要的
而slave则不需要这么高的数据安全,完全可以讲sync_binlog设置为0或者关闭binlog,innodb_flushlog也可以设置为0来提高sql的执行效率

1、sync_binlog=1 o
MySQL提供一个sync_binlog参数来控制数据库的binlog刷到磁盘上去。
默认,sync_binlog=0,表示MySQL不控制binlog的刷新,由文件系统自己控制它的缓存的刷新。这时候的性能是最好的,但是风险也是最大的。一旦系统Crash,在binlog_cache中的所有binlog信息都会被丢失。
如果sync_binlog>0,表示每sync_binlog次事务提交,MySQL调用文件系统的刷新操作将缓存刷下去。最安全的就是sync_binlog=1了,表示每次事务提交,MySQL都会把binlog刷下去,是最安全但是性能损耗最大的设置。这样的话,在数据库所在的主机操作系统损坏或者突然掉电的情况下,系统才有可能丢失1个事务的数据。
但是binlog虽然是顺序IO,但是设置sync_binlog=1,多个事务同时提交,同样很大的影响MySQL和IO性能。
虽然可以通过group commit的补丁缓解,但是刷新的频率过高对IO的影响也非常大。对于高并发事务的系统来说,
“sync_binlog”设置为0和设置为1的系统写入性能差距可能高达5倍甚至更多。
所以很多MySQL DBA设置的sync_binlog并不是最安全的1,而是2或者是0。这样牺牲一定的一致性,可以获得更高的并发和性能。
默认情况下,并不是每次写入时都将binlog与硬盘同步。因此如果操作系统或机器(不仅仅是MySQL服务器)崩溃,有可能binlog中最后的语句丢失了。要想防止这种情况,你可以使用sync_binlog全局变量(1是最安全的值,但也是最慢的),使binlog在每N次binlog写入后与硬盘同步。即使sync_binlog设置为1,出现崩溃时,也有可能表内容和binlog内容之间存在不一致性。

2、innodb_flush_log_at_trx_commit (这个很管用)
抱怨Innodb比MyISAM慢 100倍?那么你大概是忘了调整这个值。默认值1的意思是每一次事务提交或事务外的指令都需要把日志写入(flush)硬盘,这是很费时的。特别是使用电池供电缓存(Battery backed up cache)时。设成2对于很多运用,特别是从MyISAM表转过来的是可以的,它的意思是不写入硬盘而是写入系统缓存。
日志仍然会每秒flush到硬 盘,所以你一般不会丢失超过1-2秒的更新。设成0会更快一点,但安全方面比较差,即使MySQL挂了也可能会丢失事务的数据。而值2只会在整个操作系统 挂了时才可能丢数据。

3、ls(1) 命令可用来列出文件的 atime、ctime 和 mtime。
atime 文件的access time 在读取文件或者执行文件时更改的
ctime 文件的create time 在写入文件,更改所有者,权限或链接设置时随inode的内容更改而更改
mtime 文件的modified time 在写入文件时随文件内容的更改而更改

ls -lc filename 列出文件的 ctime
ls -lu filename 列出文件的 atime
ls -l filename 列出文件的 mtime
stat filename 列出atime,mtime,ctime

atime不一定在访问文件之后被修改
因为:使用ext3文件系统的时候,如果在mount的时候使用了noatime参数那么就不会更新atime信息。
这三个time stamp都放在 inode 中.如果mtime,atime 修改,inode 就一定会改, 既然 inode 改了,那ctime也就跟着改了.
之所以在 mount option 中使用 noatime, 就是不想file system 做太多的修改, 而改善读取效能

参照方案二:

解决数据丢失的问题

  1. 半同步复制

从MySQL5.5开始,MySQL已经支持半同步复制了,半同步复制介于异步复制和同步复制之间,主库在执行完事务后不立刻返回结果给客户端,需要等待至少一个从库接收到并写到relay log中才返回结果给客户端。相对于异步复制,半同步复制提高了数据的安全性,同时它也造成了一个TCP/IP往返耗时的延迟。

  1. 主库配置sync_binlog=1,innodb_flush_log_at_trx_commit=1

sync_binlog的默认值是0,MySQL不会将binlog同步到磁盘,其值表示每写多少binlog同步一次磁盘。

innodb_flush_log_at_trx_commit为1表示每一次事务提交或事务外的指令都需要把日志flush到磁盘。

注意:将以上两个值同时设置为1时,写入性能会受到一定限制,只有对数据安全性要求很高的场景才建议使用,比如涉及到钱的订单支付业务,而且系统I/O能力必须可以支撑!

解决从库复制延迟的问题:

  1. 优化网络

  2. 升级Slave硬件配置

  3. Slave调整参数,关闭binlog,修改innodb_flush_log_at_trx_commit参数值

  4. 升级MySQL版本到5.7,使用并行复制

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
书名:《Java开发实战1200例(第I卷)》(清华大学出版社.李钟尉,陈丹丹) PDF格式扫描版,全书分为24章,共817页。2011年1月出版。 全书压缩打包成4部分,这是第3部分 注:本系列图书的第I、II卷再版时均相应改名为《xxx开发实例大全》(基础卷)及(提高卷),但内容基本无变化,需要的童鞋可自由匹配查找。 内容简介   《Java开发实战1200例》分为I、II两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;书中实例来源于多位工程师的多年积累,具有很强的实用性。 本书是第II卷,以开发人员在项目开发中经常遇到的问题和必须掌握的技术为中心,介绍了应用Java进行桌面程序开发各个方面的知识和技巧,主要包括Java语法与面向对象技术、Java高级应用、窗体与控件应用、文件操作典型应用和数据库应用。全书分5篇24章,共计603个实例和603个经验技巧。每个实例都是经过笔者精心筛选的,具有很强的实用性,其中一些实例是开发人员难于寻觅的解决方案。 本书两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;本书实例来源于多位工程师的多年积累,具有很强的实用性。   本书非常适合Java的初学者,如高校学生、求职人员作为练习、速查、学习使用,也适合Java程序员参考、查阅。 目 录 第1篇 Java语法与面向对象技术 第1章 开发环境的应用 2 1.1 Java环境 3 实例001 下载JDK开发工具包 3 实例002 把JDK工具包安装到指定磁盘 4 实例003 设置JDK的环境变量 6 实例004 验证Java开发环境 7 实例005 下载并安装JRE执行环境 8 实例006 编程输出星号组成的等腰三角形 9 1.2 开发工具 11 实例007 下载最新的Eclipse 11 实例008 为最新的Eclipse安装中文语言包 12 实例009 活用Eclipse的工作空间 14 实例010 在Eclipse项目中编程输出字符表情 15 实例011 为Eclipse添加新的JDK环境 17 实例012 设置Eclipse中文API提示信息 18 实例013 为项目添加类库 20 实例014 使当前项目依赖另一个项目 21 1.3 界面设计器 22 实例015 安装界面设计器 22 实例016 设计Windows系统的运行对话框 界面 23 实例017 设计计算器程序界面 26 实例018 设计关于进销存管理系统的界面 27 第2章 Java基础应用 29 2.1 基本语法 30 实例019 输出错误信息与调试信息 30 实例020 从控制台接收输入字符 31 实例021 重定向输出流实现程序日志 31 实例022 自动类型转换与强制类型转换 33 2.2 运算符 34 实例023 加密可以这样简单(位运算) 34 实例024 用三元运算符判断奇数和偶数 35 实例025 更精确地使用浮点数 35 实例026 不用乘法运算符实现2×16 37 实例027 实现两个变量的互换(不借助 第3个变量) 37 2.3 条件语句 38 实例028 判断某一年是否为闰年 38 实例029 验证登录信息的合法性 39 实例030 为新员工分配部门 40 实例031 用Switch语句根据消费金额计算折扣 41 实例032 判断用户输入月份的季节 42 2.4 循环控制 43 实例033 使用while与自增运算符循环遍历 数组 43 实例034 使用for循环输出杨辉三角 43 实例035 使用嵌套循环在控制台上输出 九九乘法表 44 实例036 用while循环计算1+1/2!+1/3!…1/20! 45 实例037 for循环输出空心的菱形 46 实例038 foreach循环优于for循环 47 实例039 终止循环体 48 实例040 循环体的过滤器 49 实例041 循环的极限 50 第3章 数组与集合的应用 51 3.1 数组演练 52 实例042 获取一维数组最小值 52 实例043 将二维数组中的行列互换 53 实例044 利用数组随机抽取幸运观众 54 实例045 用数组设置JTable表格的列名与列宽 55 3.2 数组操作 57 实例046 数组的下标界限 57 实例047 按钮控件数组实现计数器界面 58 实例048 复选框控件数组 59 实例049 用数组反转字符串 60 3.3 数组排序与查询 61 实例050 使用选择排序法 61 实例051 使用冒泡排序法 62 实例052 使用快速排序法 64 实例053 使用直接插入法 65 实例054 使用sort方法对数组进行排序 67 实例055 反转数组中元素的顺序 68 3.4 常用集合的使用 69 实例056 用动态数组保存学生姓名 69 实例057 用List集合传递学生信息 70 实例058 用TreeSet生成不重复自动排序 随机数组 71 实例059 Map映射集合实现省市级联选择框 73 第4章 字符串处理技术 75 4.1 格式化字符串 76 实例060 把数字格式化为货币字符串 76 实例061 格式化当前日期 77 实例062 货币金额大写格式 78 实例063 String类格式化当前日期 80 实例064 字符串大小写转换 82 实例065 字符与Unicode码的转换 83 4.2 辨别字符串 84 实例066 判断用户名是否正确 84 实例067 用户名排序 85 实例068 判断网页请求与FTP请求 86 实例069 判断文件类型 87 实例070 判断字符串是否为数字 89 实例071 验证IP地址的有效性 90 实例072 鉴别非法电话号码 91 4.3 操作字符串 92 实例073 根据标点符号对字符串进行分行 92 实例074 将字符串的每个字符进行倒序输出 94 实例075 获取字符串中汉字的个数 94 实例076 批量替换某一类字符串 95 实例077 把异常与错误信息显示到窗体中 97 实例078 从字符串中分离文件路径、 文件名及扩展名 98 实例079 判断手机号的合法性 99 实例080 用字符串构建器追加字符 100 实例081 去掉字符串中的所有空格 101 实例082 汉字与区位码的转换 102 第5章 面向对象技术应用 103 5.1 Java中类的定义 104 实例083 自定义图书类 104 实例084 温度单位转换工具 105 实例085 域的默认初始化值 106 实例086 编写同名的方法 107 实例087 构造方法的应用 108 5.2 修饰符的使用 109 实例088 单例模式的应用 109 实例089 祖先的止痒药方 110 实例090 统计图书的销售量 111 实例091 汉诺塔问题求解 112 实例092 不能重写的方法 113 5.3 包装类的使用 114 实例093 将字符串转换成整数 114 实例094 整数进制转换器 115 实例095 查看数字的取值范围 116 实例096 ASCII编码查看器 117 实例097 Double类型的比较 118 5.4 面向对象的特征 119 实例098 经理与员工的差异 119 实例099 重写父类中的方法 121 实例100 计算几何图形的面积 122 实例101 提高产品质量的方法 123 实例102 简单的汽车销售商场 124 5.5 Object类的应用 126 实例103 两只完全相同的宠物 126 实例104 简化equals()方法的重写 127 实例105 重新计算对象的哈希码 129 实例106 简化hashCode()方法的重写 130 实例107 使用字符串输出对象 132 实例108 简化toString()方法的重写 133 5.6 克隆与序列化 134 实例109 Java对象的假克隆 134 实例110 Java对象的浅克隆 135 实例111 Java对象的深克隆 137 实例112 序列化与对象克隆 139 实例113 深克隆效率的比较 141 实例114 transient关键字的应用 143 5.7 接口和内部类 145 实例115 使用sort()方法排序 145 实例116 简化compareTo()方法的重写 146 实例117 策略模式的简单应用 148 实例118 适配器模式的简单应用 149 实例119 普通内部类的简单应用 151 实例120 局部内部类的简单应用 152 实例121 匿名内部类的简单应用 153 实例122 静态内部类的简单应用 154 第2篇 Java高级应用 第6章 多线程技术 158 6.1 线程的基础 159 实例123 新建无返回值的线程 159 实例124 查看线程的运行状态 160 实例125 查看JVM中的线程名 161 实例126 查看和修改线程名称 163 实例127 查看和修改线程优先级 165 实例128 使用守护线程 166 实例129 休眠当前线程 167 实例130 终止指定线程 169 实例131 线程的插队运行 170 6.2 线程的同步 171 实例132 非同步的数据读写 171 实例133 使用方法实现线程同步 172 实例134 使用代码块实现线程同步 174 实例135 使用特殊域变量实现线程同步 175 实例136 使用重入锁实现线程同步 176 实例137 使用线程局部变量实现线程同步 177 实例138 简单的线程通信 179 实例139 简单的线程死锁 180 实例140 解决线程的死锁问题 182 6.3 线程的进阶 183 实例141 使用阻塞队列实现线程同步 183 实例142 新建有返回值的线程 184 实例143 使用线程池优化多线程编程 186 实例144 Object类中线程相关的方法 187 实例145 哲学家就餐问题 189 实例146 使用信号量实现线程同步 190 实例147 使用原子变量实现线程同步 191 实例148 使用事件分配线程更新Swing控件 193 实例149 使用SwingWorker类完成耗时操作 194 第7章 反射与异常处理 195 7.1 反射的基础 196 实例150 实例化Class类的5种方式 196 实例151 获得Class对象表示实体的名称 197 实例152 查看类的声明 198 实例153 查看类的成员 199 实例154 按继承层次对类排序 201 实例155 查看内部类信息 202 7.2 反射的进阶 203 实例156 动态设置类的私有域 203 实例157 动态调用类中的方法 204 实例158 动态实例化类 205 实例159 创建长度可变的数组 206 实例160 利用反射重写toString()方法 208 实例161 反射与动态代理 209 7.3 常见的未检查型异常 210 实例162 算数异常 210 实例163 数组存值异常 211 实例164 数组下标越界异常 212 实例165 空指针异常 213 7.4 常见的已检查型异常 214 实例166 类未发现异常 214 实例167 非法访问异常 215 实例168 文件未发现异常 216 实例169 数据库操作异常 217 7.5 处理异常 218 实例170 方法中抛出异常 218 实例171 方法上抛出异常 219 实例172 自定义异常类 220 实例173 捕获单个异常 221 实例174 捕获多个异常 222 第8章 枚举与泛型的应用 223 8.1 枚举使用的简介 224 实例175 查看枚举类型的定义 224 实例176 枚举类型的基本特性 225 实例177 增加枚举元素的信息 226 实例178 选择合适的枚举元素 227 实例179 高效的枚举元素集合 228 实例180 高效的枚举元素映射 229 实例181 遍历枚举接口的元素 230 实例182 简单的文件合并工具 231 8.2 泛型使用的简介 233 实例183 自定义非泛型栈结构 233 实例184 使用泛型实现栈结构 234 实例185 自定义泛型化数组类 235 实例186 泛型方法与数据查询 236 实例187 泛型化方法与最小值 238 实例188 泛型化接口与最大值 239 实例189 使用通配符增强泛型 240 实例190 泛型化的折半查找法 241 第9章 编程常用类 343 9.1 Calendar类的使用 244 实例191 简单的数字时钟 244 实例192 简单的电子时钟 245 实例193 简单的模拟时钟 246 实例194 简单的公历万年历 248 实例195 查看生日相关信息 249 9.2 SimpleDateFormat与TimeZone 类的使用 250 实例196 日期格式有效性判断 250 实例197 常见日期格式使用 252 实例198 查看本地时区 253 实例199 简单的时区转换工具 254 9.3 System类的使用 255 实例200 查看常用系统属性 255 实例201 重定向标准输出 256 实例202 计算程序运行时间 257 实例203 从控制台输入密码 258 9.4 Math类的使用 259 实例204 角度和弧度的转换 259 实例205 三角函数的使用 260 实例206 反三角函数的使用 261 实例207 双曲函数的使用 262 实例208 指数与对数运算 263 9.5 其他常用类的使用 264 实例209 高精度整数运算 264 实例210 高精度浮点运算 265 实例211 七星彩号码生成器 266 实例212 大乐透号码生成器 267 实例213 监视JVM内存状态 268 实例214 启动默认文本工具 269 实例215 简单的截图软件 270 第10章 Commons组件 272 10.1 Commons Lang组件简介 273 实例216 数组元素的增加 273 实例217 数组元素的删除 274 实例218 生成随机字符串 275 实例219 序列化与反序列化 276 实例220 分数的常见运算 277 实例221 整数取值范围判断 279 10.2 Commons Math组件简介 280 实例222 描述统计学应用 280 实例223 绘制简单直方图 281 实例224 一元线性回归计算 282 实例225 实数矩阵的运算 283 实例226 复数的常见运算 284 实例227 T分布常用计算 285 10.3 Commons IO组件简介 286 实例228 简化文件(夹)删除 286 实例229 简化文件(夹)复制 287 实例230 简化文件(夹)排序 288 实例231 简化文件(夹)过滤 289 实例232 简化文件的读写操作 290 10.4 Commons BeanUtils组件简介 291 实例233 设置JavaBean简单属性 291 实例234 设置JavaBean级联属性 293 实例235 动态生成JavaBean 295 实例236 复制JavaBean属性 296 实例237 动态排序JavaBean 298 10.5 其他Commons组件简介 299 实例238 优雅的JDBC代码 299 实例239 结果集与Bean列表 301 实例240 编写MD5查看器 302 实例241 基于Base64编码 304 实例242 基于Base64解码 305 实例243 发送简单的Email 306 实例244 发送带附件的Email 308 实例245 读取XML文件属性 310 第3篇 窗体与控件应用 第11章 窗体设计 314 11.1 设置窗体位置 315 实例246 控制窗体加载时的位置 315 实例247 设置窗体在屏幕中的位置 315 实例248 从上次关闭位置启动窗体 316 实例249 始终在桌面最顶层显示的窗体 317 11.2 设置窗体大小 319 实例250 设置窗体大小 319 实例251 根据桌面大小调整窗体大小 320 实例252 自定义最大化、最小化和关闭按钮 321 实例253 禁止改变窗体的大小 323 11.3 设置窗体的标题栏 324 实例254 指定窗体标题栏图标 324 实例255 拖动没有标题栏的窗体 325 实例256 取消窗体标题栏与边框 326 实例257 设置闪烁的标题栏 328 11.4 设置窗体的背景 329 实例258 设置窗体背景颜色为淡蓝色 329 实例259 实现带背景图片的窗体 330 实例260 使背景图片自动适应窗体的大小 331 实例261 背景为渐变色的主界面 332 实例262 随机更换窗体背景 334 11.5 窗体形状及应用 335 实例263 椭圆形窗体界面 335 实例264 钻石形窗体 336 实例265 创建透明窗体 337 11.6 对话框 338 实例266 模态对话框与非模态对话框 338 实例267 信息提示对话框 340 实例268 设置信息提示对话框的图标 341 实例269 文件选择对话框指定数据库备份文件 342 实例270 指定打开对话框的文件类型 343 实例271 文件的保存对话框 344 实例272 为保存对话框设置默认文件名 346 实例273 支持图片预览的文件选择对话框 347 实例274 颜色选择对话框 348 实例275 信息输入对话框 350 实例276 定制信息对话框 350 11.7 MDI窗体的使用 352 实例277 创建内部子窗体 352 实例278 使子窗体最大化显示 353 实例279 对子窗体进行平铺排列 354 实例280 禁用MDI窗体控制栏中的“最大化” 按钮 355 第12章 窗体特效 357 12.1 让窗体更有活力 358 实例281 右下角弹出信息窗体 358 实例282 淡入淡出的窗体 359 实例283 窗体顶层的进度条 361 实例284 设置窗体的鼠标光标 362 实例285 窗体抖动 363 实例286 窗体标题显示计时器 364 实例287 动态展开窗体 365 实例288 仿QQ隐藏窗体 366 实例289 窗体百叶窗登场特效 367 实例290 关闭窗体打开网址 368 12.2 窗体与控件外观 369 实例291 Nimbus外观 369 实例292 本地系统外观 370 实例293 分割的窗体界面 371 实例294 圆周运动的窗体 373 第13章 基本控件应用 375 13.1 顶层容器的应用 376 实例295 框架容器的背景图片 376 实例296 更多选项的框架容器 377 实例297 拦截事件的玻璃窗格 378 实例298 简单的每日提示信息 379 实例299 震动效果的提示信息 380 13.2 布局管理器应用 382 实例300 边框布局的简单应用 382 实例301 流式布局的简单应用 383 实例302 网格布局的简单应用 384 实例303 制作圆形布局管理器 385 实例304 制作阶梯布局管理器 386 13.3 输入控件的应用 387 实例305 可以打开网页的标签 387 实例306 密码域控件的简单应用 389 实例307 给文本域设置背景图片 390 实例308 给文本区设置背景图片 391 实例309 简单的字符统计工具 392 13.4 选择控件的应用 393 实例310 能预览图片的复选框 393 实例311 简单的投票计数软件 394 实例312 单选按钮的简单应用 395 实例313 能显示图片的组合框 396 实例314 使用滑块来选择日期 398 13.5 菜单控件的应用 400 实例315 模仿记事本的菜单栏 400 实例316 自定义纵向的菜单栏 401 实例317 复选框与单选按钮菜单 402 实例318 包含图片的弹出菜单 404 实例319 工具栏的实现与应用 405 13.6 其他技术的应用 406 实例320 自定义软件安装向导 406 实例321 查看系统支持的外观 407 实例322 制作软件的闪屏界面 408 实例323 自定义系统托盘图标 410 实例324 使用撤销与重做功能 412 第14章 复合数据类型控件应用 414 14.1 列表的简单应用 415 实例325 修改列表项显示方式 415 实例326 修改列表项选择模式 416 实例327 列表项的全选与不选 417 实例328 列表元素与提示信息 419 实例329 监听列表项单击事件 420 实例330 监听列表项双击事件 421 14.2 列表的高级应用 422 实例331 实现自动排序的列表 422 实例332 列表项的增加与删除 423 实例333 查找特定的列表元素 425 实例334 包含边框的列表元素 426 实例335 包含图片的列表元素 427 实例336 可以预览字体的列表 428 14.3 表格的简单应用 430 实例337 表头与列的高度设置 430 实例338 调整表格各列的宽度 431 实例339 设置表格的选择模式 433 实例340 为表头增添提示信息 434 实例341 单元格的粗粒度排序 436 实例342 实现表格的查找功能 437 14.4 表格的高级应用 438 实例343 在表格中应用组合框 438 实例344 删除表格中选中的行 440 实例345 实现表格的分页技术 442 实例346 为单元格绘制背景色 444 实例347 实现表格的栅栏效果 445 实例348 单元格的细粒度排序 446 14.5 树控件简单应用 448 实例349 编写中国省市信息树 448 实例350 树控件常用遍历方式 449 实例351 自定义树节点的图标 451 实例352 监听节点的选择事件 452 实例353 设置树控件选择模式 453 实例354 查看节点的各种状态 455 14.6 树控件高级应用 456 实例355 在树控件中增加节点 456 实例356 在树控件中删除节点 458 实例357 在树控件中查找节点 459 实例358 自定义树节点的外观 460 实例359 为树节点增加提示信息 463 实例360 双击编辑树节点功能 464 第15章 其他高级控件应用 466 15.1 JTextPane控件的应用 467 实例361 自定义文档标题的样式 467 实例362 文档中显示自定义图片 468 实例363 检查代码中的括号是否匹配 469 实例364 描红显示100以内的质数 471 15.2 JEditorPane控件的应用 472 实例365 自定义RTF文件查看器 472 实例366 编写简单的浏览器 474 实例367 支持超链接的浏览器 474 实例368 高亮用户指定的关键字 476 15.3 其他文本控件的应用 477 实例369 只能输入整数的文本域 477 实例370 强制输入合法的整数 478 实例371 使用微调控件调整时间 479 实例372 使用微调控件浏览图片 480 15.4 进度指示器的应用 481 实例373 显示完成情况的进度条 481 实例374 监听进度条的变化事件 482 实例375 进度监视器控件的应用 484 实例376 监视文件读入的进度 485 15.5 控件组织器的应用 487 实例377 分割面板的简单应用 487 实例378 为选项卡增加快捷键 488 实例379 为选项卡标题设置图标 489 实例380 记录选项卡的访问状态 490 第16章 控件特效与自定义控件 492 16.1 控件边框效果 493 实例381 实现标签控件的立体边框 493 实例382 实现按钮控件边框留白 494 实例383 实现文本域控件的浮雕化边框 495 实例384 为文本框控件添加LineBorder 线形边框 496 实例385 控件的纯色边框与图标边框 498 实例386 实现带标题边框的面板容器 499 实例387 指定字体的标题边框 501 实例388 嵌套的标题边框 502 实例389 带图标边框的标题边框 503 实例390 文本框的下划线边框 504 16.2 控件渲染让界面UI更灵活 506 实例391 支持图标的列表控件 506 实例392 在列表控件中显示单选按钮 507 实例393 列表控件折行显示列表项 508 实例394 使用图片制作绚丽按钮 510 实例395 实现按钮关键字描红 511 实例396 忙碌的按钮控件 512 实例397 实现透明效果的表格控件 513 实例398 在表格中显示工作进度百分比 515 实例399 在表格中显示图片 517 16.3 让控件活起来 518 实例400 鼠标经过时按钮放大效果 518 实例401 迟到的登录按钮 520 实例402 焦点按钮的缩放 521 实例403 标签文本的跑马灯特效 522 实例404 延迟生效的按钮 524 实例405 动态加载表格数据 525 16.4 自定义控件 526 实例406 石英钟控件 526 实例407 IP输入文本框控件 527 实例408 日历控件 530 实例409 平移面板控件 531 实例410 背景图面板控件 533 第4篇 文件操作典型应用 第17章 文件与文件夹操作 536 17.1 文件操作 537 实例411 修改文件属性 537 实例412 显示指定类型的文件 538 实例413 以树结构显示文件路径 540 实例414 查找替换文本文件内容 541 实例415 支持图片预览的文件选择对话框 543 实例416 设置Windows的文件属性 545 实例417 文件批量重命名 547 实例418 快速批量移动文件 549 实例419 删除磁盘中所有的.tmp临时文件 551 17.2 文件与数据库 553 实例420 提取数据库内容到文件 553 实例421 提取文本文件的内容到MySQL数据库 555 实例422 将图片文件保存到SQL Server数据库 556 实例423 显示数据库中的图片信息 558 实例424 提取技术网站数据到文件夹 559 实例425 读取文件路径到数据库 561 实例426 在数据库中建立磁盘文件索引 562 17.3 操作磁盘文件夹 564 实例427 窗体动态加载磁盘文件 564 实例428 删除文件夹中所有文件 565 实例429 创建磁盘索引文件 567 实例430 快速全盘查找文件 568 实例431 获取磁盘所有文本文件 570 实例432 网络文件夹备份 571 第18章 文件的读取、写入、整理和控制 573 18.1 文件的读取与写入 574 实例433 键盘录入内容保存到文本文件 574 实例434 将数组写入到文件中并逆序输出 575 实例435 利用StringBuffer避免文件的多次写入 576 实例436 合并多个txt文件 577 实例437 实现文件简单加密与解密 579 实例438 对大文件实现分割处理 581 实例439 将分割后的文件重新合并 583 实例440 读取属性文件的单个属性值 584 实例441 向属性文件中添加信息 585 实例442 在复制文件时使用进度条 586 实例443 从XML文件中读取数据 587 实例444 读取Jar文件属性 589 实例445 电子通讯录 590 18.2 实现文件整理 592 实例446 批量复制指定扩展名的文件 592 实例447 计数器小程序 594 实例448 将某文件夹中的文件进行分类存储 595 18.3 文件控制 597 实例449 利用StreamTokenizer统计文件的 字符数 597 实例450 在指定目录下搜索文件 598 实例451 序列化和反序列化对象 600 实例452 文件锁定 602 实例453 投票统计 603 第19章 文件压缩 605 19.1 Java实现文件压缩 606 实例454 压缩所有文本文件 606 实例455 压缩包解压到指定文件夹 607 实例456 压缩所有子文件夹 608 实例457 深层文件夹压缩包的释放 610 实例458 解决压缩包中文乱码 611 实例459 Apache实现文件解压缩 612 实例460 把窗体压缩成ZIP文件 613 实例461 解压缩Java对象 615 19.2 RAR文件压缩 616 实例462 文件压缩为RAR文档 616 实例463 解压缩RAR压缩包 619 实例464 文件分卷压缩 621 实例465 为RAR压缩包添加注释 623 实例466 获取压缩包详细文件列表 625 实例467 从RAR压缩包中删除文件 627 实例468 在压缩文件中查找字符串 628 实例469 重命名RAR压缩包中的文件 629 实例470 创建自解压RAR压缩包 631 实例471 设置RAR压缩包密码 632 19.3 数据压缩的网络应用 634 实例472 以压缩格式传输网络数据 634 实例473 压缩远程文件夹 637 实例474 压缩存储网页 638 第20章 操作办公文档 640 20.1 操作Word 641 实例475 把文本文件导入到Word中 641 实例476 浏览本地Word文件 642 实例477 将员工表插入到Word文档中 644 实例478 将员工照片插入到Word简历 645 实例479 将Word文档保存为HTML格式 646 20.2 操作Excel 647 实例480 将员工信息保存到Excel表中 647 实例481 通过Excel公式计算出商品表中的 总售价 649 实例482 将数据库表中的内容写入到Excel 651 实例483 将Excel表中的内容保存到数据库 653 实例484 将Excel文件转换为HTML格式 654 20.3 操作PDF 655 实例485 应用iText组件生成PDF 655 实例486 在窗体中显示PDF文件 657 实例487 应用PDF Renderer组件实现放大 PDF文件 658 实例488 应用PDF Renderer组件实现缩小 PDF文件 660 实例489 应用PDF Renderer组件实现抓手功能 661 实例490 全屏显示PDF文件 662 第5篇 数据库应用 第21章 SQL应用 666 21.1 排序和分组函数应用 667 实例491 对数据进行降序查询 667 实例492 对数据进行多条件排序查询 669 实例493 对统计结果进行排序 670 实例494 查询SQL Server数据库中的前3条 数据 671 实例495 查询SQL Server数据库中的后3 条数据 672 实例496 查询MySQL数据库中的前3条数据 673 实例497 查询MySQL数据库中的后3条数据 674 实例498 按照字母顺序对留学生表进行排序 675 实例499 按姓氏笔画排序 677 实例500 将汉字按音序排序 678 实例501 按列的编号排序 679 实例502 从表中随机返回记录 680 实例503 使用GROUP BY子句实现对数据的 分组统计 681 实例504 使用GROUP BY子句实现多表 分组统计 682 21.2 聚集函数与日期查询 683 实例505 利用SUM函数实现数据汇总 683 实例506 利用AVG函数实现计算平均值 684 实例507 利用MIN函数求数据表中的最小值 685 实例508 利用MAX函数求数据表中的最大值 686 实例509 利用COUNT函数求销售额大于某值的 图书种类 688 实例510 查询编程词典6月的销售量 689 实例511 查询与张静同一天入司的员工信息 690 实例512 使用IN谓词查询某几个时间的数据 692 实例513 日期查询中避免千年虫问题 693 21.3 大小比较与逻辑应用 694 实例514 在查询结果中不显示重复记录 694 实例515 使用NOT查询不满足条件的记录 695 实例516 使用between进行区间查询 697 实例517 列出销量表中的重复记录和记录条数 698 实例518 使用关系运算符查询某一时间段数据 699 实例519 计算两个日期之间的月份数 700 实例520 格式化金额 702 实例521 在查询语句中过滤掉字符串中的空格 703 第22章 数据库操作 705 22.1 通过JDBC-ODBC桥连接数据库 706 实例522 通过JDBC-ODBC桥连接SQL Server 2000数据库 706 实例523 JDBC-ODBC桥连接Access数据库 708 实例524 JDBC-ODBC桥与Oracle数据库 建立连接 710 22.2 JDBC技术连接数据库 711 实例525 通过JDBC连接SQL Server 2000 数据库 711 实例526 JDBC连接MySQL数据库 713 实例527 JDBC连接SQL Server 2005数据库 714 实例528 JDBC技术连接Oracle数据库 715 实例529 JDBC连接JavaDB数据库 716 22.3 数据库与数据表 717 实例530 列举SQL Server数据库下的数据表 717 实例531 列举MySQL数据库下的数据表 718 实例532 查看数据表结构 719 实例533 动态维护投票数据库 721 实例534 SQL Server数据备份 722 实例535 SQL Server数据恢复 725 实例536 MySQL数据备份 728 实例537 MySQL数据恢复 730 实例538 动态附加数据库 731 实例539 生成SQL数据库脚本 733 实例540 获取SQL Server数据表字段的描述信息 734 22.4 数据增加、更新与删除操作 736 实例541 将员工信息添加到数据表 736 实例542 添加数据时使用数据验证 737 实例543 插入用户登录日志信息 739 实例544 生成有规律的编号 740 实例545 生成无规律的编号 742 实例546 在插入数据时过滤掉危险字符 743 实例547 将用户选择的爱好以字符串形式保存 到数据库 744 实例548 将数据从一张表复制到另一张表 745 实例549 使用UNION ALL语句批量插入数据 746 实例550 更新指定记录 747 实例551 在删除数据时给出提示信息 748 实例552 将数据表清空 749 实例553 字符串大小写转换 750 第23章 数据查询 752 23.1 使用子查询 753 实例554 将子查询作为表达式 753 实例555 用子查询作为派生表 754 实例556 通过子查询关联数据 755 实例557 使用IN谓词限定查询范围 756 实例558 使用NOT IN子查询实现差集运算 758 实例559 使用NOT IN子查询实现反向查询 759 实例560 返回笛卡尔乘积 760 实例561 比较运算符引入子查询 761 实例562 在子查询中使用聚集函数 762 实例563 在删除数据时使用子查询 763 23.2 嵌套查询 764 实例564 查询平均成绩在85分以上的学生信息 764 实例565 查询本科部门经理月收入情况 766 实例566 在嵌套中使用EXISTS关键字 767 实例567 动态指定查询条件 768 23.3 连接查询 769 实例568 使用UNION运算符使学生档案归档 769 实例569 内连接获取指定课程的教师信息 771 实例570 左外连接查询员工信息 772 实例571 右外连接查询员工信息 773 实例572 多表外连接查询 774 实例573 完全连接查询 775 23.4 函数查询 777 实例574 在查询中使用patindex()函数进行 模糊查询 777 实例575 对查询结果进行格式化 778 实例576 在查询中使用字符串函数 780 实例577 在查询中使用ALL谓词 781 实例578 在查询中使用ANY谓词 782 实例579 使用UNION运算符消除重复的行 784 实例580 使用UNION ALL运算符保留重复的行 785 实例581 计算商品销售额所占的百分比 786 第24章 数据库高级应用 787 24.1 在Java程序中使用存储过程 788 实例582 调用存储过程实现用户身份验证 788 实例583 应用存储过程添加数据 789 实例584 调用加密存储过程 791 实例585 获取数据库中所有存储过程 792 实例586 修改存储过程 793 实例587 删除存储过程 795 24.2 使用触发器 796 实例588 应用触发器添加日志信息 796 实例589 在删除成绩表时将学生表中的数据删除 798 实例590 在程序中调用UPDATE触发器 799 实例591 获取数据库中的触发器名称 801 实例592 创建带有触发条件的触发器 802 24.3 使用批处理 803 实例593 使用批处理删除数据 803 实例594 使用批处理提升部门员工工资 805 实例595 将教师表中的数据全部添加到选课表 806 实例596 在批处理中使用事务 807 24.4 使用视图 809 实例597 创建视图 809 实例598 使用视图过滤不想要的数据 810 实例599 使用视图与计算数据 812 实例600 使用视图重新格式化检索出来的数据 813 实例601 获取数据库中的全部用户视图 814 实例602 修改视图 815 实例603 删除视图 816
mysql 总结........................................................................................................................................6 1.1 数据库的种类...........................................................................................................6 1.1.1 关系型数据库介绍.................................................................................................6 1.1.2 非关系型数据库介绍.............................................................................................7 1.1.3 非关系型数据库种类.............................................................................................7 1.1.4 关系型数据库产品介绍.........................................................................................8 1.1.5 常用非关系型数据库产品介绍.............................................................................8 1.2 mysql 多实例安装实战......................................................................................................9 1.2.1 什么是 mysql 多实例? .........................................................................................9 1.2.2 mysql 的多实例结构图.........................................................................................10 1.2.3 实战安装 mysql 多实例需要的依赖包...............................................................10 1.2.4 安装编译 mysql 需要的软件...............................................................................10 1.2.5 安装 mysql 软件...................................................................................................11 1.2.6 创建存放两个 mysql 实例的数据目录...............................................................11 1.2.7 创建两个 mysql 多实例的配置文件...................................................................12 1.2.7.1 3306 的实例................................................................................................12 1.2.7.2 3307 的实例................................................................................................16 1.2.7.3 多实例本地登录 mysql .............................................................................20 1.2.7.4 远程连接登录 mysql 多实例....................................................................20 1.3 mysql 基础安全................................................................................................................21 1.3.1 启动程序设置 700,属主和用户组为 mysql .....................................................21 1.3.2 为 mysq 超级用户 root 设置密码........................................................................21 1.3.3 登录时尽量不要在命令行暴漏密码,备份脚本中如果有密码,给设置 700, 属主和用户组为 mysql 或 root......................................................................................21 1.3.4 删除默认存在的 test 库 .......................................................................................21 1.3.5 初始删除无用的用户,只保留 root 127.0.0.1 和 root localhost........................21 1.3.6 授权用户对应的主机不要用%,权限不要给 all,最小化授权,从库只给 select 权限.................................................................................................................................21 1.3.7 不要给一个用户管所有的库,尽量专库专用户...............................................21 1.3.8 清理 mysql 操作日志文件~/mysql_history.........................................................21 1.3.9 禁止开发获取到 web 连接的密码,禁止开发连接操作生产对外的库...........21 1.4.0 服务器禁止设置外网 IP ......................................................................................21 1.4.1 防 SQL 注入(WEB), php.ini 配置文件里面设置 ..........................................21 1.4.2 mysql 的备份的脚本给 700 的权限,并且属主和属组为 root..........................21 1.4 关于 mysql 的启动与关闭..............................................................................................21 1.4.1 单实例 MySQL 启动与关闭方法........................................................................21 1.4.2 多实例 MySQL 启动与关闭方法示例................................................................21 1.5 生产环境关闭 mysql 的命令..........................................................................................22 1.5.1 生产环境不能用强制命令关闭 mysql 服务 .......................................................22 1.5.2 下面来介绍优雅关闭数据库方法: ...................................................................22 1.6 登录 mysql 方法..............................................................................................................22 1.6.1 单实例 MySQL 登录的方法................................................................................22 1.6.2 多实例 MySQL 的登录方法................................................................................22 1.7 关于 mysql 管理员设置..................................................................................................22资源由 www.eimhe.com 美河学习在线收集分享 1.7.1 为管理员 root 用户设置密码并修改方法之一...................................................22 1.7.2 修改管理员 root 密码法二(sql 语句修改) .....................................................22 1.7.3 找回丢失的 mysql root 用户密码(单实例和多实例) ....................................23 1.8 SQL 结构化查询语言......................................................................................................23 1.8.1 什么是 SQL? ......................................................................................................23 1.8.2 SQL 语句最常见的分类一般就是 3 类 ...............................................................24 1.9 数据库的管理应用..........................................................................................................24 1.9.1 创建数据库...........................................................................................................24 1.9.2 查看库的字符集及校队规则...............................................................................24 1.9.3 企业场景创建什么字符集的数据库呢? ...........................................................26 1.9.4 显示数据库...........................................................................................................26 1.9.5 删除数据库...........................................................................................................26 1.9.6 进入数据库中指定的库.......................................................................................27 1.9.7 查看进入当前数据库的用户...............................................................................27 1.9.8 删除数据库多余的账号.......................................................................................27 1.9.9 查看数据库的用户...............................................................................................27 2.0.0 创建 MySQL 用户及赋予用户权限............................................................................27 2.0.1 使用语法:..............................................................................................................27 2.0.2 第一种创建用户及授权方法: ...........................................................................28 2.0.3 第二种创建用户及授权方法: ...........................................................................28 2.0.4 创建用户及授权哪个网段的主机可以连接 oldboy_gbk 库..............................29 2.0.4.1 第一种方法: .............................................................................................29 2.0.4.2 第二种方法: ............................................................................................29 2.0.5 关于 mysql 回收某个用户权限...........................................................................29 2.0.6 企业生产环境如何授权用户权限(mysql 主库) ............................................30 2.1 数据库表操作..................................................................................................................31 2.1.1 以默认字符集 latin1 建库....................................................................................31 2.1.2 建立表并查看表的结构.......................................................................................31 2.1.3 mysql 表的字符类型.............................................................................................32 2.1.3.1 数字类型.....................................................................................................32 2.1.3.2 日期和时间类型.........................................................................................32 2.1.3.3 字符串类型................................................................................................33 2.1.3.4 关于字符类型小结....................................................................................33 2.1.4 为表的字段创建索引...........................................................................................33 2.1.4.1 为表创建主键索引的方法........................................................................33 2.1.4.2 查看 student 表的结构 ..............................................................................34 2.1.4.3 怎么删除一个表的主键............................................................................34 2.1.4.4 利用 alter 命令修改 id 列为自增主键列..................................................34 2.1.4.5 建表后利用 alter 增加普通索引...............................................................34 2.1.4.6 对表字段的前 n 个字符创建普通索引....................................................36 2.1.4.7 为表的多个字段创建联合索引................................................................38 2.1.4.8 为表的多个字段的前 n 个字符创建联合索引........................................38 2.1.4.9 主键也可以联合多列做索引....................................................................39 2.1.5.0 统计一个字段列的唯一值个数................................................................40资源由 www.eimhe.com 美河学习在线收集分享 2.1.5.1 创建唯一索引(非主键) ........................................................................41 2.1.5.2 索引列的创建及生效条件........................................................................42 2.1.5 往表中插入数据...................................................................................................42 2.1.6 往表中删除一条数据...........................................................................................44 2.1.7 查询数据................................................................................................................44 2.1.7.1 查询表的所有数据行................................................................................44 2.1.7.2 查看 mysql 库的用户................................................................................45 2.1.7.3 根据指定条件查询表的部分数据............................................................45 2.1.7.4 根据固定条件查数据................................................................................46 2.1.7.5 指定固定条件范围查数据........................................................................46 2.1.7.6 根据顺序查看列数据................................................................................46 2.1.6.7 在表中根据条件导出数据至文件中........................................................47 2.1.8 多表查询...............................................................................................................47 2.1.8.1 创建学生表................................................................................................47 2.1.8.2 在学生表里插入数据.................................................................................47 2.1.8.3 创建课程表................................................................................................47 2.1.8.4 在课程表里插入数据................................................................................48 2.1.8.5 创建选课表................................................................................................48 2.1.8.6 联表查询命令............................................................................................49 2.1.9 使用 explain 查看 select 语句的执行计划..........................................................49 2.1.9.1 用查询语句查看是否使用索引情况........................................................49 2.1.9.2 为该列创建索引,再用查询语句查看是否走了索引............................50 2.2.0 使用 explain 优化 SQL 语句(select 语句)的基本流程..................................50 2.2.1 用命令抓取慢 SQL 语句,然后用 explain 命令查看查询语句是否走的索 引查询.....................................................................................................................50 2.2.2 设置配置参数记录慢查询语句...................................................................51 2.2.3 对抓取到的慢查询语句用 explain 命令检查索引执行情况 .....................51 2.2.4 对需要建索引的条件列建立索引...............................................................51 2.2.5 切割慢查询日志,去重分析后发给大家...................................................51 2.2.1 修改表中数据.......................................................................................................51 2.2.1.1 修改表中指定条件固定列的数据............................................................51 2.2.2 删除表中的数据...................................................................................................52 2.2.2.1 实践删除表中的数据................................................................................52 2.2.2.2 通过 update 伪删除数据...........................................................................53 2.2.3 增删改表的字段...................................................................................................53 2.2.3.1 命令语法及默认添加演示........................................................................53 2.2.4 更改表名...............................................................................................................55 2.2.5 删除表名...............................................................................................................56 2.2.6 mysql 数据库的备份与恢复.................................................................................56 2.2.6.1 备份单个数据库练习多种参数使用........................................................56 2.2.6.2 查看数据库 oldboy 的内容.......................................................................56 2.2.6.3 执行备份的命令........................................................................................57 2.2.6.4 查看备份的结果........................................................................................57 2.2.6.5 mysqldump 备份时加上-B 参数时的备份,然后比较不加-B 备份的不同资源由 www.eimhe.com 美河学习在线收集分享 .................................................................................................................................57 2.2.6.6 删除数据库中备份过的库 oldboy,然后将备份的数据重新导入数据库 .................................................................................................................................58 2.2.6.7 利用 mysqldump 命令对指定的库进行压缩备份...................................59 2.2.6.8 利用 mysqldump 命令备份多个库(-B 参数后可以指定多个库) ......59 2.2.6.9 分库备份(对 mysql、 oldboy、 oldboy_gbk、 wordpress 库进行备份) .................................................................................................................................60 2.2.7.0 对一个库的多个表备份............................................................................60 2.2.7.1 备份多个表................................................................................................61 2.2.7.2 备份单个表................................................................................................61 2.2.7.3 关于 mysqldump 的参数说明...................................................................61 2.2.7.4 刷新 binglog 的参数..................................................................................62 2.2.7.5 生产场景不同引擎 mysqldump 备份命令...............................................62 2.2.8 恢复数据库实践...................................................................................................63 2.2.8.1 数据库恢复事项........................................................................................63 2.2.8.2 利用 source 命令恢复数据库 ...................................................................63 2.2.8.3 利用 mysql 命令恢复(标准) ................................................................64 2.2.8.4 针对压缩的备份数据恢复........................................................................66 2.2.9 实现和 mysql 非交互式对话...............................................................................66 2.2.9.1 利用 mysql –e 参数查看 mysql 数据库的库名........................................66 2.2.9.2 利用 mysql –e 参数查看 mysql 数据库的线程状态................................66 2.2.9.3 mysql sleep 线程过多的问题案例............................................................66 2.2.9.4 查看 mysql 配置文件有没有在数据库中生效 ........................................67 2.2.9.5 不重启数据库修改数据库参数................................................................68 2.2.9.6 不重启数据库更改数据库参数小结........................................................69 2.3.0 查看 mysql 状态的信息(利用 zabbix 可以监控其状态信息) .......................69 2.3.1 mysqladmin 的命令...............................................................................................75 2.3.2 mysql 工具 mysqlbinlog........................................................................................76 2.3.2.1 mysql 的 binlog 日志是什么? ..................................................................76 2.3.2.2 mysql 的 binlog 日志作用是什么? ..........................................................76 2.3.2.3 mysqlbinlog 工具解析 binlog 日志实践....................................................76 2.3.2.4 解析指定库的 binlog 日志........................................................................76 2.3.3 mysql 数据库的服务日志.....................................................................................77 2.3.3.1 错误日志(error log)介绍与调整..........................................................77 2.3.3.2 普通查询日志(general query log)介绍与调整(生产环境中不用) 77 2.3.3.3 慢查询日志介绍与调整............................................................................78 2.3.3.4 二进制日志介绍与调整............................................................................78 2.3.4 mysql 的 binlog 有三种模式.................................................................................78 2.3.4.1 row level......................................................................................................78 2.3.4.2 statement level(默认) ..................................................................................79 2.3.4.3 Mixed ..........................................................................................................79 2.3.5 企业场景如何选择 binlog 的模式.......................................................................79 2.3.6 设置 mysql binlog 的格式....................................................................................79 2.3.7 mysql 生产备份实战应用指南.............................................................................80资源由 www.eimhe.com 美河学习在线收集分享 2.3.7.1 全量备份....................................................................................................80 2.3.7.2 增量备份....................................................................................................80 2.3.7.3 企业场景和增量的频率是怎么做的? ....................................................81 2.3.7.4 mysql 增量恢复必备条件..........................................................................81 2.3.7.5 实战模拟凌晨 00 点对 oldboy库做个全备,早上 10 点左右删除了 oldboy 库,下面是其恢复过程.........................................................................................81 2.3.7.6 实战模拟凌晨 00 点对 oldboy库做个全备,早上 10 点左右更新了 oldboy 库的 test 表中所有字段数据,下面是其恢复过程(update 表中的数据的时候, 把表中的字段换成了一个相同的内容,这时候要停库) .................................83 2.3.8 mysql 的主从复制的结构图.................................................................................85 2.3.8.1 单向的主从复制图,此架构只能在 master 端进行数据写入(生产环境 可以使用) .............................................................................................................85 2.3.8.2 双向的主主同步逻辑图,此架构可以在 master1 端或 master2 端进行数 据写入(生产环境不建议使用) .........................................................................85 2.3.8.3 线性级联单向双主同步逻辑图,此架构只能在 master1 端进行数据写入 (生产环境可以使用) .........................................................................................86 2.3.8.4 环状级联单向多主同步逻辑图,任意一个都可以写入数据(生产环境 不建议使用) .........................................................................................................86 2.3.8.5 环状级联单向多主多从同步逻辑图,此架构只能在任意一个 master 端 进行数据写入(生产环境不建议使用) .............................................................86 2.3.9 mysql 主从复制的原理.........................................................................................86 2.4.0 mysql 主从复制的原理图.....................................................................................87 2.4.1 mysql 主从复制的实践.........................................................................................87 2.4.1.1 环境准备....................................................................................................87 2.4.1.2 分别查看 3306 和 3307 不同数据库有哪些库........................................87 2.4.1.3 全量备份 3306 数据库的库,然后到 3307 数据库中............................88 2.4.1.4 在 3306 数据库上授权用户可以到 3306 数据库上复制 binlog.............89 2.4.1.5 在 3307 数据库上开启复制 3306 的 binlog 开关,并查看是否处于同步 状态.........................................................................................................................89 2.4.1.6 在 3306 上创建数据库 zhangxuan,看 3307 上是否同步过来..............91 2.4.2 关于主从复制出现故障怎么解决.......................................................................92 2.4.3 主从复制延迟问题原因及解决方案...................................................................92 2.4.3.1 一个主库的从库太多,导致复制延迟....................................................92 2.4.3.2 从库硬件比主库差,导致复制延迟........................................................92 2.4.3.3 慢 SQL 语句过多 ......................................................................................92 2.4.3.4 主从复制的设计问题................................................................................93 2.4.3.5 主从库之间的网络延迟............................................................................93 2.4.3.6 主库读写压力大,导致复制延迟............................................................93 2.4.4 通过 read-only 参数让从库只读访问..................................................................93 2.4.5 web 用户专业设置方案: mysql 主从复制读写分离集群..................................93 2.4.6 让 mysql 从库记录 binlog 日志方法...................................................................94 2.4.7 mysql 主从复制集群架构的数据备份策略.........................................................94 2.4.8 mysql 一主多从,主库宕机,从库怎么接管.....................................................95 2.4.8.1 半同步从库(谷歌半同步插件 5.5 版本自带) .....................................95资源由 www.eimhe.com 美河学习在线收集分享 2.4.8.2 S1,啥也不干只做同步从库, 500 台服务器,百度..........................95 2.4.8.3 皇帝驾崩现选(耽误事,容易被篡位) ................................................95 2.4.9 事务介绍...............................................................................................................97 2.4.9.1 事务的四大特性(ACID) ......................................................................97 2.4.9.2 事务的开启................................................................................................97 2.4.9.3 事物的实现................................................................................................98 2.5.0 mysql 引擎概述.....................................................................................................98 2.5.0.1 什么是存储引擎? ....................................................................................98 2.5.0.2 mysql 存储引擎的架构..............................................................................99 2.5.0.3 myisaw 引擎介绍 .......................................................................................99 2.5.0.4 myisaw 引擎特点 .......................................................................................99 2.5.1 myisaw 引擎调忧精要 ........................................................................................100 2.5.2 innodb 引擎..........................................................................................................100 2.5.2.1 什么是 innodb 引擎? .............................................................................100 2.5.2.2 innodb 引擎特点.......................................................................................101 2.5.2.3 innodb 引擎适应的生产业务场景...........................................................102 2.5.2.4 关于 innodb 引擎的一些参数设置.........................................................102 2.5.2.5 innodb 引擎调忧精要...............................................................................102 2.5.3 有关 mysql 引擎特别说明.................................................................................103 2.5.4 关于 mysql 的字符集.........................................................................................103 2.5.4.1 mysql 常见的字符集? ............................................................................103 2.5.4.2 mysql 如何选择合适的字符集? ............................................................103 2.5.4.3 如何查看字符集......................................................................................103 2.5.4.4 不同字符集参数的含义如下(要想数据库字符不乱码,下面几个字符 集要相同) ...........................................................................................................104 2.5.4.5 set names 字符集名,此命令有什么作用 .............................................105 2.5.4.6 根据配置文件更改客户端字符集..........................................................105 2.5.4.7 更改 mysql 服务端的字符集..................................................................106 2.5.4.8 怎么解决乱码问题..................................................................................106 2.5.4.9 插入数据不乱码的方法..........................................................................106 2.5.5.0 更改数据库的字符集..............................................................................106 2.5.5.1 更改表的字符集......................................................................................106 2.5.6 模拟将 latin1 字符集的数据库修改成 UTF8 字符集的实际过程 ..................107

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值