合 MSSQL数据库后台进程(线程)介绍
Tags: MSSQLSQL Server体系结构后台进程
与Oracle数据库类似,微软数据库产品MSSQL也有诸多后台进程来保证数据库系统的高效正常运转,由于MSSQL采用的是线程模型,应该叫做后台线程,为了大家易于理解,我们在暂且称之为后台进程,下面我们就来简要看一下:
1、 数据写相关进程
1) Lazy writer:该进程用来确保系统缓冲区(buffer pool)中有足够的自由内存,该进程定期扫描缓冲内存页,以发现不常使用的内存页并将其移出缓冲区,期间,会先将脏页数据写出到磁盘并移除缓冲区。
2) Eager writer:和lazy writer类似,该进程也是负责将缓冲区内的脏页写出到磁盘,但它写出的这些内存页主要是和非日志(non-logged,例如:bulk insert,select into)操作相关,期间,允许读写新页并行发生。
3) Checkpoint:该进程定期扫描缓冲区以发现特定数据库的脏页,并将这些脏页写出到磁盘,通过创建一个在此之前确认所有脏页都写出到磁盘的时间点,可以减少最近数据库恢复需要的时间。用户可以通过提交checkpoint命令来请求一个检查点操作,或者系统也可以根据消耗的日志空间或时间自动产生一个检查点操作,此外,当系统中的某些事件也会导致检查点的发生,例如:增减或移除数据文件或日志文件,实例的关闭等。当检查点发生时,该进程将缓冲区内的脏页写出到磁盘,无论相关事务是否已经提交,都要写出到磁盘。
值得一提的是,这三个后台进程都是异步的,即它们在进行IO操作的同时可以去做其他工作,稍后再来检查之前IO的完成情况。
2、 事务日志相关进程
1) Log writer:该进程负责将事务日志从缓冲区刷出到磁盘日志文件。MSSQL2016前的版本,每个实例只有一个log writer进程,因此,该进程负责实例中的所有数据库log buffer。该进程通过异步IO完成log buffer到磁盘的写出,当用户提交一个事务时,该进程阻塞该用户会话,直到将相关数据库log buffer数据刷出到磁盘完成,同时,该进程还可以继续其他数据库log buffer的工作。MSSQL系统中的诸多事件都会触发log writer进程向磁盘写出log buffer中的内容,例如:会话提交当前事务,log buffer被写满,checkpoint等。
此外,该进程将lredo记录从log cache/buffer写出到磁盘log files时,写出单位是可以变化的,从512~64k不等,这点来说,不像data buffer写出进程一样,最小必须是数据页大小。