NLRUQ parameter: Difference between revisions

From m204wiki
Jump to navigation Jump to search
Line 19: Line 19:
<p>NLRUQ=1 preserves the single reuse queue model used in releases of <var class="product">Model&nbsp;204</var> before V6R1.0. </p>
<p>NLRUQ=1 preserves the single reuse queue model used in releases of <var class="product">Model&nbsp;204</var> before V6R1.0. </p>
<p>In the following formula NLRUQ is used as a multiplier to determine the minimum number of disk buffers used in an Online. </p>
<p>In the following formula NLRUQ is used as a multiplier to determine the minimum number of disk buffers used in an Online. </p>
<p class="code">MINUF >= NLRUQ * ((NSERVS + NSUBTKS) * MAXOBUF + 15)
<p class="code"><var>[[MINBUF_parameter|MINUF]]</var> >= NLRUQ * ((<var>[[NSERVS_parameter|NSERVS]]</var> + <var>[[NSUBTKS_parameter|NSUBTKS]]</var>) * <var>[[MAXOBUF_parameter|MAXOBUF]]</var> + 15)
</p>
</p>
<p>A reasonable guess for a proper NLRUQ would be adding two for each MP subtask so that a NMPSUBS=1 would suggest NLRUQ=3 and NMPSUBS=7 would suggest NLRUQ=15. </p>
<p>A reasonable guess for a proper NLRUQ would be adding two for each MP subtask so that a NMPSUBS=1 would suggest NLRUQ=3 and NMPSUBS=7 would suggest NLRUQ=15. </p>

Revision as of 15:13, 25 August 2015

# of DKBM LRU queues

Summary

Default value
1, also the minimum
Parameter type
System
Where set
Not resettable
Related products
All
Introduced
Model 204 V6.1

Description

The NLRUQ parameter reduces contention on the MP lock that protects the reuse queues.

This MP lock is a primary source of MP overhead. Setting this parameter to greater than 1 has no benefit in a non-MP run. In fact, in all cases a setting of greater than 1 might result in a slight increase in disk I/O, due to a loss in precision in the least-recently used algorithm for managing the disk buffer pool. With NLRUQ greater than 1, it would be possible for a page to be stolen from the buffer pool before one that was less recently used.

NLRUQ=1 preserves the single reuse queue model used in releases of Model 204 before V6R1.0.

In the following formula NLRUQ is used as a multiplier to determine the minimum number of disk buffers used in an Online.

MINUF >= NLRUQ * ((NSERVS + NSUBTKS) * MAXOBUF + 15)

A reasonable guess for a proper NLRUQ would be adding two for each MP subtask so that a NMPSUBS=1 would suggest NLRUQ=3 and NMPSUBS=7 would suggest NLRUQ=15.

If NLRUQ is set greater than 1, then the values of LDKBMWND, MAXBUF, and MINBUF are all rounded up to a multiple of NLRUQ. The maximum setting for NLRUQ is 255.

A high conflict count for LRU queue locks that would appear in MONITOR MPLOCK command output indicates that you should increase NLRUQ and NLRUQG.