如何确定ZFS中ARC的当前大小,以及ARC与空闲或高速缓存有何关系?


17

ZFS使用ARC(自适应替换缓存),这在传统的Linux“缓存”内存使用中并未解决。我如何确定ZFS ARC的当前大小以及大小边界,它们如何与报告的空闲或缓存内存量(例如)关联free

Answers:


20

ZFS代码通过procfs报告各种统计信息。为了确定ARC中的尺寸,外观/proc/spl/kstat/zfs/arcstats(安装在/ PROC假设procfs的,按照惯例),特别是对于值cc_maxsize。(另请参阅Oracle社区论坛上的这篇文章。如果Oracle站点不可用,请选择Internet存档副本。)

  • c是ARC 的目标大小(以字节为单位)
  • c_max是ARC 的最大大小(以字节为单位)
  • size是ARC 的当前大小(以字节为单位)

可以通过zfs_arc_max=Nzfs模块传递参数(通过modprobe)来调整ARC的最大大小,该参数N是ARC的最大大小(以字节为单位),也可以通过将新的最大大小(以字节为单位)写入来动态调整/sys/module/zfs/parameters/zfs_arc_max

由于LinuxZFS的实现方式,ARC内存的行为类似于高速缓存内存(例如,如果系统受到内存压力,则将其逐出),但是由内核聚合为普通内存分配。这可能导致混乱,因为系统的可用内存似乎远少于当前系统工作负载下的预期可用内存,但这是正常现象。

要获取兆字节的ARC大小,可以使用awk '/^size/ { print $1 " " $3 / 1048576 }' < /proc/spl/kstat/zfs/arcstats。(1,048,576是兆字节的字节数。)

例如,我的系统(几乎仅使用ZFS)可能会报告

$ free -m
             total       used       free     shared    buffers     cached
Mem:         32194      17948      14245          0        158        982
-/+ buffers/cache:      16808      15386
Swap:        49152          0      49152
$ awk '/^size/ { print $1 " " $3 / 1048576 }' < /proc/spl/kstat/zfs/arcstats
size 8138.73
$

这意味着当前驻留的进程的实际内存使用量约为8,669 MB(16,808 MB减少了8,139 MB)。


13

要建立迈克尔·科约林的答案,您还可以使用 arc_summary.py

在这里,您可以看到ARC如何使用桌面内存的一半:

root @ host:〜#免费-g
             已使用的可用共享缓冲区总数
内存:62 56 6 1 1 5
-/ +缓冲区/缓存:49 13
掉期:7 0 7

根@主机:〜#arc_summary.py
-------------------------------------------------- ----------------------
ZFS子系统报告2017年2月24日星期五19:44:20
ARC摘要:(健康)
        内存节流计数:0

ARC其他:
        删除:1.33m
        互斥丢失:99
        驱逐跳过:99

弧度:98.13%30.80 GiB
        目标大小:(自适应)100.00%31.39 GiB
        最小大小(硬限制):0.10%32.00 MiB
        最大尺寸(高水位):1004:1 31.39 GiB

ARC大小明细:
        最近使用的缓存大小:84.25%26.45 GiB
        常用缓存大小:15.75%4.95 GiB

ARC哈希细目:
        元素最大:1.11m
        元素电流:53.48%592.56k
        碰撞:763.42k
        连锁上限:4
        链条:19.62k

ARC总访问量:36.34m
        缓存命中率:87.02%31.62m
        缓存未命中率:12.98%4.72m
        实际命中率:84.78%30.81m

        数据需求效率:93.49%2422万
        数据预取效率:2.57%819.12k

        通过缓存列表进行缓存:
          匿名使用:2.27%716.60k
          最近使用:17.26%5.46m
          最常用的:80.17%25.35m
          最近使用过的幽灵:0.19%60.25k
          最常用的鬼魂:0.11%35.37k

        按数据类型缓存
          需求数据:71.60%22.64m
          预取数据:0.07%21.04k
          需求元数据:25.82%816万
          预取元数据:2.51%794.39k

        按数据类型缓存错误:
          需求数据:33.44%150万
          预取数据:16.92%798.09k
          需求元数据:48.90%2.31m
          预取元数据:0.75%35.27k


DMU预取效率:173.06m
        命中率:86.14%149.07m
        漏检率:13.86%2399万



ZFS可调:
        metaslab_debug_load 0
        zfs_arc_min_prefetch_lifespan 0
        zfetch_max_streams 8
        zfs_nopwrite_enabled 1
        zfetch_min_sec_reap 2
        zfs_dbgmsg_enable 0
        zfs_dirty_data_max_max_percent 25
        zfs_arc_p_aggressive_disable 1
        spa_load_verify_data 1
        zfs_zevent_cols 80
        zfs_dirty_data_max_percent 10
        zfs_sync_pass_dont_compress 5
        l2arc_write_max 8388608
        zfs_vdev_scrub_max_active 2
        zfs_vdev_sync_write_min_active 10
        zvol_prefetch_bytes 131072
        metaslab_aliquot 524288
        zfs_no_scrub_prefetch 0
        zfs_arc_shrink_shift 0
        zfetch_block_cap 256
        zfs_txg_history 0
        zfs_delay_scale 500000
        zfs_vdev_async_write_active_min_dirty_percent 30
        metaslab_debug_unload 0
        zfs_read_history 0
        zvol_max_discard_blocks 16384
        zfs_recover 0
        l2arc_headroom 2
        zfs_deadman_synctime_ms 1000000
        zfs_scan_idle 50
        zfs_free_min_time_ms 1000
        zfs_dirty_data_max 6741298790
        zfs_vdev_async_read_min_active 1
        zfs_mg_noalloc_threshold 0
        zfs_dedup_prefetch 0
        zfs_vdev_max_active 1000
        l2arc_write_boost 8388608
        zfs_resilver_min_time_ms 3000
        zfs_vdev_async_write_max_active 10
        zil_slog_limit 1048576
        zfs_prefetch_disable 0
        zfs_resilver_delay 2
        metaslab_lba_weighting_enabled 1
        zfs_mg_fragmentation_threshold 85
        l2arc_feed_again 1
        zfs_zevent_console 0
        zfs_immediate_write_sz 32768
        zfs_dbgmsg_maxsize 4194304
        zfs_free_leak_on_eio 0
        zfs_deadman_enabled 1
        metaslab_bias_enabled 1
        zfs_arc_p_dampener_disable 1
        zfs_object_mutex_size 64
        zfs_metaslab_fragmentation_threshold 70
        zfs_no_scrub_io 0
        metaslabs_per_vdev 200
        zfs_dbuf_state_index 0
        zfs_vdev_sync_read_min_active 10
        metaslab_fragmentation_factor_enabled 1
        zvol_inhibit_dev 0
        zfs_vdev_async_write_active_max_dirty_percent 60
        zfs_vdev_cache_size 0
        zfs_vdev_mirror_switch_us 10000
        zfs_dirty_data_sync 67108864
        spa_config_path /etc/zfs/zpool.cache
        zfs_dirty_data_max_max 16853246976
        zfs_arc_lotsfree_percent 10
        zfs_zevent_len_max 128
        zfs_scan_min_time_ms 1000
        zfs_arc_sys_free 0
        zfs_arc_meta_strategy 1
        zfs_vdev_cache_bshift 16
        zfs_arc_meta_adjust_restarts 4096
        zfs_max_recordsize 1048576
        zfs_vdev_scrub_min_active 1
        zfs_vdev_read_gap_limit 32768
        zfs_arc_meta_limit 0
        zfs_vdev_sync_write_max_active 10
        l2arc_norw 0
        zfs_arc_meta_prune 10000
        metaslab_preload_enabled 1
        l2arc_nocompress 0
        zvol_major 230
        zfs_vdev_aggregation_limit 131072
        zfs_flags 0
        spa_asize_inflation 24
        zfs_admin_snapshot 0
        l2arc_feed_secs 1
        zio_taskq_batch_pct 75
        zfs_sync_pass_deferred_free 2
        zfs_disable_dup_eviction 0
        zfs_arc_grow_retry 0
        zfs_read_history_hits 0
        zfs_vdev_async_write_min_active 1
        zfs_vdev_async_read_max_active 3
        zfs_scrub_delay 4
        zfs_delay_min_dirty_percent 60
        zfs_free_max_blocks 100000
        zfs_vdev_cache_max 16384
        zio_delay_max 30000
        zfs_top_maxinflight 32
        ignore_hole_birth 1
        spa_slop_shift 5
        zfs_vdev_write_gap_limit 4096
        spa_load_verify_metadata 1
        spa_load_verify_maxinflight 10000
        l2arc_noprefetch 1
        zfs_vdev_scheduler noop
        zfs_expire_snapshot 300
        zfs_sync_pass_rewrite 2
        zil_replay_disable 0
        zfs_nocacheflush 0
        zfs_arc_max 0
        zfs_arc_min 0
        zfs_read_chunk_size 1048576
        zfs_txg_timeout 5
        zfs_pd_bytes_max 52428800
        l2arc_headroom_boost 200
        zfs_send_corrupt_data 0
        l2arc_feed_min_ms 200
        zfs_arc_meta_min 0
        zfs_arc_average_blocksize 8192
        zfetch_array_rd_sz 1048576
        zfs_autoimport_disable 1
        zfs_arc_p_min_shift 0
        zio_requeue_io_start_cut_in_line 1
        zfs_vdev_sync_read_max_active 10
        zfs_mdcomp_disable 0
        zfs_arc_num_sublists_per_state 8

我想知道报告的最大尺寸(高水)比例的意义是什么。
CMCDragonkai '17年

对于Ubuntu用户:这是arc_summary没有.py
弹簧加载
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.