作业三
将内存结构对应的部分大小查询出来,能够描述各个内存结构的作用,描述用户线程工作空间对应的状态监控变量
首先内存结构主要是由三大部分组成:innodb buffer pool、innodb log buffer、用户线程工作空间
对于innodb buffer pool来说,又叫做数据缓冲区,大小可以占物理内存的50%~80%之间。
对于innodb log buffer来说,是重做日志缓冲区,事务开始时,将redolog存到log buffer中 ,log thread将redolog刷新到log buffer中,保证只要事务提交,log thread就将redolog全部写入log buffer中,即使宕机,也能保证该事务所做的操作不会丢失。
对于用户工作线程空间来说。是每一个用户都会被分配一个线程,一个线程对应一个用户空间。在用户工作空间中有很多缓冲区。例如是sort buffer,当需要对大量数据进行排序操作时,会使用到sort buffer,如果设置过小的话,可能会发生磁盘排序。第二个是join buffer,当进行多表连接时,会使用到join buffer。对于read buffer和read rnd buffer来说,read buffer主要是针对myisam表的,可以设置小一些或者不变,对于read rnd buffer来说,是针对所有的表的,可以设置大一些,16M即可。
mysql> show variables like '%innodb_buffer_pool_size%';
+-------------------------+-----------+
| Variable_name | Value |
+-------------------------+-----------+
| innodb_buffer_pool_size | 134217728 |
+-------------------------+-----------+
mysql> show variables like '%innodb_log_buffer_size%';
+------------------------+----------+
| Variable_name | Value |
+------------------------+----------+
| innodb_log_buffer_size | 16777216 |
+------------------------+----------+
mysql> show variables like '%innodb_sort_buffer_size%';
+-------------------------+---------+
| Variable_name | Value |
+-------------------------+---------+
| innodb_sort_buffer_size | 1048576 |
+-------------------------+---------+
mysql> show variables like '%join_buffer%';
+------------------+--------+
| Variable_name | Value |
+-----------