mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-10-24 08:55:00 +03:00
Avoid extra work updating ARC kstats and tunables
After e357046
it should not be necessary to periodically update ARC
kstats and tunables. Tunable updates are applied when modified, and
kstats are updated on demand.
Update kstats in `arc_evict_cb_check()` for `ZFS_DEBUG` builds only.
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Ryan Moeller <ryan@iXsystems.com>
Closes #11237
This commit is contained in:
parent
fb188409f1
commit
1531506d23
@ -4882,14 +4882,7 @@ arc_kmem_reap_soon(void)
|
|||||||
static boolean_t
|
static boolean_t
|
||||||
arc_evict_cb_check(void *arg, zthr_t *zthr)
|
arc_evict_cb_check(void *arg, zthr_t *zthr)
|
||||||
{
|
{
|
||||||
/*
|
#ifdef ZFS_DEBUG
|
||||||
* This is necessary so that any changes which may have been made to
|
|
||||||
* many of the zfs_arc_* module parameters will be propagated to
|
|
||||||
* their actual internal variable counterparts. Without this,
|
|
||||||
* changing those module params at runtime would have no effect.
|
|
||||||
*/
|
|
||||||
arc_tuning_update(B_FALSE);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is necessary in order to keep the kstat information
|
* This is necessary in order to keep the kstat information
|
||||||
* up to date for tools that display kstat data such as the
|
* up to date for tools that display kstat data such as the
|
||||||
@ -4897,15 +4890,15 @@ arc_evict_cb_check(void *arg, zthr_t *zthr)
|
|||||||
* typically do not call kstat's update function, but simply
|
* typically do not call kstat's update function, but simply
|
||||||
* dump out stats from the most recent update. Without
|
* dump out stats from the most recent update. Without
|
||||||
* this call, these commands may show stale stats for the
|
* this call, these commands may show stale stats for the
|
||||||
* anon, mru, mru_ghost, mfu, and mfu_ghost lists. Even
|
* anon, mru, mru_ghost, mfu, and mfu_ghost lists. Even
|
||||||
* with this change, the data might be up to 1 second
|
* with this call, the data might be out of date if the
|
||||||
* out of date(the arc_evict_zthr has a maximum sleep
|
* evict thread hasn't been woken recently; but that should
|
||||||
* time of 1 second); but that should suffice. The
|
* suffice. The arc_state_t structures can be queried
|
||||||
* arc_state_t structures can be queried directly if more
|
* directly if more accurate information is needed.
|
||||||
* accurate information is needed.
|
|
||||||
*/
|
*/
|
||||||
if (arc_ksp != NULL)
|
if (arc_ksp != NULL)
|
||||||
arc_ksp->ks_update(arc_ksp, KSTAT_READ);
|
arc_ksp->ks_update(arc_ksp, KSTAT_READ);
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We have to rely on arc_wait_for_eviction() to tell us when to
|
* We have to rely on arc_wait_for_eviction() to tell us when to
|
||||||
@ -7675,8 +7668,8 @@ arc_init(void)
|
|||||||
kstat_install(arc_ksp);
|
kstat_install(arc_ksp);
|
||||||
}
|
}
|
||||||
|
|
||||||
arc_evict_zthr = zthr_create_timer("arc_evict",
|
arc_evict_zthr = zthr_create("arc_evict",
|
||||||
arc_evict_cb_check, arc_evict_cb, NULL, SEC2NSEC(1));
|
arc_evict_cb_check, arc_evict_cb, NULL);
|
||||||
arc_reap_zthr = zthr_create_timer("arc_reap",
|
arc_reap_zthr = zthr_create_timer("arc_reap",
|
||||||
arc_reap_cb_check, arc_reap_cb, NULL, SEC2NSEC(1));
|
arc_reap_cb_check, arc_reap_cb, NULL, SEC2NSEC(1));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user