mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-06-06 22:04:58 +03:00

Authored by: John Wren Kennedy <john.kennedy@delphix.com> Reviewed by: Dan Kimmel <dan.kimmel@delphix.com> Reviewed by: Matthew Ahrens <mahrens@delphix.com> Reviewed by: Dan McDonald <danmcd@omniti.com> Approved by: Gordon Ross <gordon.w.ross@gmail.com> Ported-by: Brian Behlendorf <behlendorf1@llnl.gov> Ported-by: George Melikov <mail@gmelikov.ru> Porting Notes: - Utilities which aren't available under Linux have been removed. - Because of sudo's default secure path behavior PATH must be explicitly reset at the top of libtest.shlib. This avoids the need for all users to customize secure path on their system. - Updated ZoL infrastructure to manage constrained path - Updated all test cases - Check permissions for usergroup tests - When testing in-tree create links under bin/ - Update fault cleanup such that missing files during cleanup aren't fatal. - Configure su environment with constrained path OpenZFS-issue: https://www.illumos.org/issues/7290 OpenZFS-commit: https://github.com/openzfs/openzfs/commit/1d32ba6 Closes #5903
83 lines
2.2 KiB
Bash
Executable File
83 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
#
|
|
# This file and its contents are supplied under the terms of the
|
|
# Common Development and Distribution License ("CDDL"), version 1.0.
|
|
# You may only use this file in accordance with the terms of version
|
|
# 1.0 of the CDDL.
|
|
#
|
|
# A full copy of the text of the CDDL should have accompanied this
|
|
# source. A copy of the CDDL is also available via the Internet at
|
|
# http://www.illumos.org/license/CDDL.
|
|
#
|
|
|
|
#
|
|
# Copyright (c) 2016 by Intel, Corp.
|
|
#
|
|
|
|
#
|
|
# Linux platform placeholder for collecting prefetch I/O stats
|
|
# TBD if we can add additional kstats to achieve the desired results
|
|
#
|
|
|
|
zfs_kstats="/proc/spl/kstat/zfs"
|
|
|
|
function get_prefetch_ios
|
|
{
|
|
typeset -l data_misses=`awk '$1 == "prefetch_data_misses" \
|
|
{ print $3 }' $zfs_kstats/arcstats`
|
|
typeset -l metadata_misses=`awk '$1 == "prefetch_metadata_misses" \
|
|
{ print $3 }' $zfs_kstats/arcstats`
|
|
typeset -l total_misses=$(( $data_misses + $metadata_misses ))
|
|
|
|
echo $total_misses
|
|
}
|
|
|
|
function get_prefetched_demand_reads
|
|
{
|
|
typeset -l demand_reads=`awk '$1 == "demand_hit_predictive_prefetch" \
|
|
{ print $3 }' $zfs_kstats/arcstats`
|
|
|
|
echo $demand_reads
|
|
}
|
|
|
|
function get_sync_wait_for_async
|
|
{
|
|
typeset -l sync_wait=`awk '$1 == "sync_wait_for_async" \
|
|
{ print $3 }' $zfs_kstats/arcstats`
|
|
|
|
echo $sync_wait
|
|
}
|
|
|
|
if [ $# -ne 2 ]
|
|
then
|
|
echo "Usage: `basename $0` <poolname> interval" >&2
|
|
exit 1
|
|
fi
|
|
|
|
poolname=$1
|
|
interval=$2
|
|
prefetch_ios=$(get_prefetch_ios)
|
|
prefetched_demand_reads=$(get_prefetched_demand_reads)
|
|
sync_wait_for_async=$(get_sync_wait_for_async)
|
|
|
|
while true
|
|
do
|
|
new_prefetch_ios=$(get_prefetch_ios)
|
|
printf "%u\n%-24s\t%u\n" $(date +%s) "prefetch_ios" \
|
|
$(( $new_prefetch_ios - $prefetch_ios ))
|
|
prefetch_ios=$new_prefetch_ios
|
|
|
|
new_prefetched_demand_reads=$(get_prefetched_demand_reads)
|
|
printf "%-24s\t%u\n" "prefetched_demand_reads" \
|
|
$(( $new_prefetched_demand_reads - $prefetched_demand_reads ))
|
|
prefetched_demand_reads=$new_prefetched_demand_reads
|
|
|
|
new_sync_wait_for_async=$(get_sync_wait_for_async)
|
|
printf "%-24s\t%u\n" "sync_wait_for_async" \
|
|
$(( $new_sync_wait_for_async - $sync_wait_for_async ))
|
|
sync_wait_for_async=$new_sync_wait_for_async
|
|
|
|
sleep $interval
|
|
done
|