19b50d902SRodney W. Grimes /* 29b50d902SRodney W. Grimes * Copyright (c) 1983, 1989, 1993 39b50d902SRodney W. Grimes * The Regents of the University of California. All rights reserved. 49b50d902SRodney W. Grimes * 59b50d902SRodney W. Grimes * This code is derived from software contributed to Berkeley by 69b50d902SRodney W. Grimes * Rick Macklem at The University of Guelph. 79b50d902SRodney W. Grimes * 89b50d902SRodney W. Grimes * Redistribution and use in source and binary forms, with or without 99b50d902SRodney W. Grimes * modification, are permitted provided that the following conditions 109b50d902SRodney W. Grimes * are met: 119b50d902SRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 129b50d902SRodney W. Grimes * notice, this list of conditions and the following disclaimer. 139b50d902SRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 149b50d902SRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 159b50d902SRodney W. Grimes * documentation and/or other materials provided with the distribution. 16fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors 179b50d902SRodney W. Grimes * may be used to endorse or promote products derived from this software 189b50d902SRodney W. Grimes * without specific prior written permission. 199b50d902SRodney W. Grimes * 209b50d902SRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 219b50d902SRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 229b50d902SRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 239b50d902SRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 249b50d902SRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 259b50d902SRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 269b50d902SRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 279b50d902SRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 289b50d902SRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 299b50d902SRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 309b50d902SRodney W. Grimes * SUCH DAMAGE. 319b50d902SRodney W. Grimes */ 32693957f8SRick Macklem /*- 33693957f8SRick Macklem * Copyright (c) 2004, 2008, 2009 Silicon Graphics International Corp. 34693957f8SRick Macklem * All rights reserved. 35693957f8SRick Macklem * 36693957f8SRick Macklem * Redistribution and use in source and binary forms, with or without 37693957f8SRick Macklem * modification, are permitted provided that the following conditions 38693957f8SRick Macklem * are met: 39693957f8SRick Macklem * 1. Redistributions of source code must retain the above copyright 40693957f8SRick Macklem * notice, this list of conditions, and the following disclaimer, 41693957f8SRick Macklem * without modification. 42693957f8SRick Macklem * 2. Redistributions in binary form must reproduce at minimum a disclaimer 43693957f8SRick Macklem * substantially similar to the "NO WARRANTY" disclaimer below 44693957f8SRick Macklem * ("Disclaimer") and any redistribution must be conditioned upon 45693957f8SRick Macklem * including a substantially similar Disclaimer requirement for further 46693957f8SRick Macklem * binary redistribution. 47693957f8SRick Macklem * 48693957f8SRick Macklem * NO WARRANTY 49693957f8SRick Macklem * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 50693957f8SRick Macklem * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 51693957f8SRick Macklem * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 52693957f8SRick Macklem * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 53693957f8SRick Macklem * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 54693957f8SRick Macklem * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 55693957f8SRick Macklem * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 56693957f8SRick Macklem * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 57693957f8SRick Macklem * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 58693957f8SRick Macklem * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 59693957f8SRick Macklem * POSSIBILITY OF SUCH DAMAGES. 60693957f8SRick Macklem */ 61693957f8SRick Macklem 629b50d902SRodney W. Grimes 639b50d902SRodney W. Grimes #ifndef lint 64db995e00SXin LI static const char copyright[] = 659b50d902SRodney W. Grimes "@(#) Copyright (c) 1983, 1989, 1993\n\ 669b50d902SRodney W. Grimes The Regents of the University of California. All rights reserved.\n"; 679b50d902SRodney W. Grimes #endif /* not lint */ 689b50d902SRodney W. Grimes 699b50d902SRodney W. Grimes #ifndef lint 70eae79dd1SBruce Evans #if 0 71eae79dd1SBruce Evans static char sccsid[] = "@(#)nfsstat.c 8.2 (Berkeley) 3/31/95"; 72eae79dd1SBruce Evans #endif 7307e532e7SGarrett Wollman static const char rcsid[] = 74c3aac50fSPeter Wemm "$FreeBSD$"; 759b50d902SRodney W. Grimes #endif /* not lint */ 769b50d902SRodney W. Grimes 779b50d902SRodney W. Grimes #include <sys/param.h> 7833f5882eSEd Schouten #include <sys/module.h> 799b50d902SRodney W. Grimes #include <sys/mount.h> 805a4838fcSPoul-Henning Kamp #include <sys/time.h> 8107e532e7SGarrett Wollman #include <sys/sysctl.h> 82a62dc406SDoug Rabson #include <nfs/nfsproto.h> 8391196234SPeter Wemm #include <nfsclient/nfs.h> 8491196234SPeter Wemm #include <nfsserver/nfs.h> 85bcdaa850SRick Macklem #include <nfs/nfssvc.h> 86bcdaa850SRick Macklem 87bcdaa850SRick Macklem #include <fs/nfs/nfsport.h> 88bcdaa850SRick Macklem 899b50d902SRodney W. Grimes #include <signal.h> 909b50d902SRodney W. Grimes #include <fcntl.h> 91821df508SXin LI #include <ctype.h> 929b50d902SRodney W. Grimes #include <errno.h> 939c9f2eefSThomas Moestl #include <limits.h> 949b50d902SRodney W. Grimes #include <nlist.h> 959b50d902SRodney W. Grimes #include <unistd.h> 969b50d902SRodney W. Grimes #include <stdio.h> 97693957f8SRick Macklem #include <stdint.h> 989b50d902SRodney W. Grimes #include <stdlib.h> 999b50d902SRodney W. Grimes #include <string.h> 100821df508SXin LI #include <paths.h> 101693957f8SRick Macklem #include <devstat.h> 10207e532e7SGarrett Wollman #include <err.h> 1039b50d902SRodney W. Grimes 1042145d321SEmmanuel Vadot #include <libxo/xo.h> 1052145d321SEmmanuel Vadot 1064893ef0bSMatthew Dillon static int widemode = 0; 107813947b7SJohn Baldwin static int zflag = 0; 108bcdaa850SRick Macklem static int printtitle = 1; 109693957f8SRick Macklem static struct nfsstatsv1 ext_nfsstats; 110e85b7d75SRick Macklem static int extra_output = 0; 11107e532e7SGarrett Wollman 112722e2552SEdward Tomasz Napierala static void intpr(int, int); 113693957f8SRick Macklem static void printhdr(int, int, int); 114722e2552SEdward Tomasz Napierala static void usage(void); 115722e2552SEdward Tomasz Napierala static char *sperc1(int, int); 116722e2552SEdward Tomasz Napierala static char *sperc2(int, int); 1172145d321SEmmanuel Vadot static void exp_intpr(int, int, int); 118693957f8SRick Macklem static void exp_sidewaysintpr(u_int, int, int, int); 119693957f8SRick Macklem static void compute_new_stats(struct nfsstatsv1 *cur_stats, 120693957f8SRick Macklem struct nfsstatsv1 *prev_stats, int curop, long double etime, 121693957f8SRick Macklem long double *mbsec, long double *kb_per_transfer, 122693957f8SRick Macklem long double *transfers_per_second, long double *ms_per_transfer, 123693957f8SRick Macklem uint64_t *queue_len, long double *busy_pct); 1244893ef0bSMatthew Dillon 1254893ef0bSMatthew Dillon #define DELTA(field) (nfsstats.field - lastst.field) 1269b50d902SRodney W. Grimes 127693957f8SRick Macklem #define STAT_TYPE_READ 0 128693957f8SRick Macklem #define STAT_TYPE_WRITE 1 129693957f8SRick Macklem #define STAT_TYPE_COMMIT 2 130693957f8SRick Macklem #define NUM_STAT_TYPES 3 131693957f8SRick Macklem 132693957f8SRick Macklem struct stattypes { 133693957f8SRick Macklem int stat_type; 134693957f8SRick Macklem int nfs_type; 135684d18c9SRick Macklem }; 136684d18c9SRick Macklem static struct stattypes statstruct[] = { 137693957f8SRick Macklem {STAT_TYPE_READ, NFSV4OP_READ}, 138693957f8SRick Macklem {STAT_TYPE_WRITE, NFSV4OP_WRITE}, 139693957f8SRick Macklem {STAT_TYPE_COMMIT, NFSV4OP_COMMIT} 140693957f8SRick Macklem }; 141693957f8SRick Macklem 142693957f8SRick Macklem #define STAT_TYPE_TO_NFS(stat_type) statstruct[stat_type].nfs_type 143693957f8SRick Macklem 1442145d321SEmmanuel Vadot #define NFSSTAT_XO_VERSION "1" 1452145d321SEmmanuel Vadot 14670c3c978SStefan Farfeleder int 147813947b7SJohn Baldwin main(int argc, char **argv) 1489b50d902SRodney W. Grimes { 1499b50d902SRodney W. Grimes u_int interval; 1504893ef0bSMatthew Dillon int clientOnly = -1; 1514893ef0bSMatthew Dillon int serverOnly = -1; 152693957f8SRick Macklem int newStats = 0; 1539b50d902SRodney W. Grimes int ch; 1549b50d902SRodney W. Grimes char *memf, *nlistf; 155a6c903b8SRick Macklem int mntlen, i; 156a6c903b8SRick Macklem char buf[1024]; 157a6c903b8SRick Macklem struct statfs *mntbuf; 158a6c903b8SRick Macklem struct nfscl_dumpmntopts dumpmntopts; 1599b50d902SRodney W. Grimes 1609b50d902SRodney W. Grimes interval = 0; 1619b50d902SRodney W. Grimes memf = nlistf = NULL; 1622145d321SEmmanuel Vadot 1632145d321SEmmanuel Vadot argc = xo_parse_args(argc, argv); 1642145d321SEmmanuel Vadot if (argc < 0) 1652145d321SEmmanuel Vadot exit(1); 1662145d321SEmmanuel Vadot 1672145d321SEmmanuel Vadot xo_set_version(NFSSTAT_XO_VERSION); 1682145d321SEmmanuel Vadot 1692145d321SEmmanuel Vadot while ((ch = getopt(argc, argv, "cdEesWM:mN:w:zq")) != -1) 1709b50d902SRodney W. Grimes switch(ch) { 1719b50d902SRodney W. Grimes case 'M': 1729b50d902SRodney W. Grimes memf = optarg; 1739b50d902SRodney W. Grimes break; 174a6c903b8SRick Macklem case 'm': 175a6c903b8SRick Macklem /* Display mount options for NFS mount points. */ 176a6c903b8SRick Macklem mntlen = getmntinfo(&mntbuf, MNT_NOWAIT); 177a6c903b8SRick Macklem for (i = 0; i < mntlen; i++) { 178a6c903b8SRick Macklem if (strcmp(mntbuf->f_fstypename, "nfs") == 0) { 179a6c903b8SRick Macklem dumpmntopts.ndmnt_fname = 180a6c903b8SRick Macklem mntbuf->f_mntonname; 181a6c903b8SRick Macklem dumpmntopts.ndmnt_buf = buf; 182a6c903b8SRick Macklem dumpmntopts.ndmnt_blen = sizeof(buf); 183a6c903b8SRick Macklem if (nfssvc(NFSSVC_DUMPMNTOPTS, 184a6c903b8SRick Macklem &dumpmntopts) >= 0) 185a6c903b8SRick Macklem printf("%s on %s\n%s\n", 186a6c903b8SRick Macklem mntbuf->f_mntfromname, 187a6c903b8SRick Macklem mntbuf->f_mntonname, buf); 1887c44c114SRick Macklem else if (errno == EPERM) 1897c44c114SRick Macklem errx(1, "Only priviledged users" 1907c44c114SRick Macklem " can use the -m option"); 191a6c903b8SRick Macklem } 192a6c903b8SRick Macklem mntbuf++; 193a6c903b8SRick Macklem } 194a6c903b8SRick Macklem exit(0); 1959b50d902SRodney W. Grimes case 'N': 1969b50d902SRodney W. Grimes nlistf = optarg; 1979b50d902SRodney W. Grimes break; 1984893ef0bSMatthew Dillon case 'W': 1994893ef0bSMatthew Dillon widemode = 1; 2004893ef0bSMatthew Dillon break; 2019b50d902SRodney W. Grimes case 'w': 2029b50d902SRodney W. Grimes interval = atoi(optarg); 2039b50d902SRodney W. Grimes break; 2044893ef0bSMatthew Dillon case 'c': 2054893ef0bSMatthew Dillon clientOnly = 1; 2064893ef0bSMatthew Dillon if (serverOnly < 0) 2074893ef0bSMatthew Dillon serverOnly = 0; 2084893ef0bSMatthew Dillon break; 209693957f8SRick Macklem case 'd': 210693957f8SRick Macklem newStats = 1; 211693957f8SRick Macklem if (interval == 0) 212693957f8SRick Macklem interval = 1; 213693957f8SRick Macklem break; 2144893ef0bSMatthew Dillon case 's': 2154893ef0bSMatthew Dillon serverOnly = 1; 2164893ef0bSMatthew Dillon if (clientOnly < 0) 2174893ef0bSMatthew Dillon clientOnly = 0; 2184893ef0bSMatthew Dillon break; 219813947b7SJohn Baldwin case 'z': 220813947b7SJohn Baldwin zflag = 1; 221813947b7SJohn Baldwin break; 2220744a2b0SRick Macklem case 'E': 2230744a2b0SRick Macklem if (extra_output != 0) 2242145d321SEmmanuel Vadot xo_err(1, "-e and -E are mutually exclusive"); 2250744a2b0SRick Macklem extra_output = 2; 2260744a2b0SRick Macklem break; 22761a2fc1fSRick Macklem case 'e': 2280744a2b0SRick Macklem if (extra_output != 0) 2292145d321SEmmanuel Vadot xo_err(1, "-e and -E are mutually exclusive"); 230e85b7d75SRick Macklem extra_output = 1; 231bcdaa850SRick Macklem break; 2322145d321SEmmanuel Vadot case 'q': 2332145d321SEmmanuel Vadot printtitle = 0; 2342145d321SEmmanuel Vadot break; 2359b50d902SRodney W. Grimes case '?': 2369b50d902SRodney W. Grimes default: 2379b50d902SRodney W. Grimes usage(); 2389b50d902SRodney W. Grimes } 2399b50d902SRodney W. Grimes argc -= optind; 2409b50d902SRodney W. Grimes argv += optind; 2419b50d902SRodney W. Grimes 2429b50d902SRodney W. Grimes #define BACKWARD_COMPATIBILITY 2439b50d902SRodney W. Grimes #ifdef BACKWARD_COMPATIBILITY 2449b50d902SRodney W. Grimes if (*argv) { 2459b50d902SRodney W. Grimes interval = atoi(*argv); 2469b50d902SRodney W. Grimes if (*++argv) { 2479b50d902SRodney W. Grimes nlistf = *argv; 2489b50d902SRodney W. Grimes if (*++argv) 2499b50d902SRodney W. Grimes memf = *argv; 2509b50d902SRodney W. Grimes } 2519b50d902SRodney W. Grimes } 2529b50d902SRodney W. Grimes #endif 253722e2552SEdward Tomasz Napierala if (modfind("nfscommon") < 0) 2542145d321SEmmanuel Vadot xo_err(1, "NFS client/server not loaded"); 2559b50d902SRodney W. Grimes 256bcdaa850SRick Macklem if (interval) { 257693957f8SRick Macklem exp_sidewaysintpr(interval, clientOnly, serverOnly, 258693957f8SRick Macklem newStats); 259bcdaa850SRick Macklem } else { 2602145d321SEmmanuel Vadot xo_open_container("nfsstat"); 2612145d321SEmmanuel Vadot if (extra_output != 0) 2622145d321SEmmanuel Vadot exp_intpr(clientOnly, serverOnly, extra_output - 1); 2639b50d902SRodney W. Grimes else 2644893ef0bSMatthew Dillon intpr(clientOnly, serverOnly); 2652145d321SEmmanuel Vadot xo_close_container("nfsstat"); 266bcdaa850SRick Macklem } 2672145d321SEmmanuel Vadot 2682145d321SEmmanuel Vadot xo_finish(); 2699b50d902SRodney W. Grimes exit(0); 2709b50d902SRodney W. Grimes } 2719b50d902SRodney W. Grimes 2729b50d902SRodney W. Grimes /* 2739b50d902SRodney W. Grimes * Print a description of the nfs stats. 2749b50d902SRodney W. Grimes */ 275722e2552SEdward Tomasz Napierala static void 2764893ef0bSMatthew Dillon intpr(int clientOnly, int serverOnly) 2779b50d902SRodney W. Grimes { 278e85b7d75SRick Macklem int nfssvc_flag; 2799b50d902SRodney W. Grimes 280693957f8SRick Macklem nfssvc_flag = NFSSVC_GETSTATS | NFSSVC_NEWSTRUCT; 281e85b7d75SRick Macklem if (zflag != 0) { 282e85b7d75SRick Macklem if (clientOnly != 0) 283e85b7d75SRick Macklem nfssvc_flag |= NFSSVC_ZEROCLTSTATS; 284e85b7d75SRick Macklem if (serverOnly != 0) 285e85b7d75SRick Macklem nfssvc_flag |= NFSSVC_ZEROSRVSTATS; 286e85b7d75SRick Macklem } 287693957f8SRick Macklem ext_nfsstats.vers = NFSSTATS_V1; 288e85b7d75SRick Macklem if (nfssvc(nfssvc_flag, &ext_nfsstats) < 0) 2892145d321SEmmanuel Vadot xo_err(1, "Can't get stats"); 2904893ef0bSMatthew Dillon if (clientOnly) { 2912145d321SEmmanuel Vadot xo_open_container("clientstats"); 2922145d321SEmmanuel Vadot 2932145d321SEmmanuel Vadot if (printtitle) 2942145d321SEmmanuel Vadot xo_emit("{T:Client Info:\n"); 2952145d321SEmmanuel Vadot 2962145d321SEmmanuel Vadot xo_open_container("operations"); 2972145d321SEmmanuel Vadot xo_emit("{T:Rpc Counts:}\n"); 2982145d321SEmmanuel Vadot 2992145d321SEmmanuel Vadot xo_emit("{T:Getattr/%13.13s}{T:Setattr/%13.13s}" 3002145d321SEmmanuel Vadot "{T:Lookup/%13.13s}{T:Readlink/%13.13s}" 3012145d321SEmmanuel Vadot "{T:Read/%13.13s}{T:Write/%13.13s}" 3022145d321SEmmanuel Vadot "{T:Create/%13.13s}{T:Remove/%13.13s}\n"); 3032145d321SEmmanuel Vadot xo_emit("{:getattr/%13ju}{:setattr/%13ju}" 3042145d321SEmmanuel Vadot "{:lookup/%13ju}{:readlink/%13ju}" 3052145d321SEmmanuel Vadot "{:read/%13ju}{:write/%13ju}" 3062145d321SEmmanuel Vadot "{:create/%13ju}{:remove/%13ju}\n", 307693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_GETATTR], 308693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETATTR], 309693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LOOKUP], 310693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READLINK], 311693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READ], 312693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_WRITE], 313693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_CREATE], 314693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_REMOVE]); 3152145d321SEmmanuel Vadot 3162145d321SEmmanuel Vadot xo_emit("{T:Rename/%13.13s}{T:Link/%13.13s}" 3172145d321SEmmanuel Vadot "{T:Symlink/%13.13s}{T:Mkdir/%13.13s}" 3182145d321SEmmanuel Vadot "{T:Rmdir/%13.13s}{T:Readdir/%13.13s}" 3192145d321SEmmanuel Vadot "{T:RdirPlus/%13.13s}{T:Access/%13.13s}\n"); 3202145d321SEmmanuel Vadot xo_emit("{:rename/%13ju}{:link/%13ju}" 3212145d321SEmmanuel Vadot "{:symlink/%13ju}{:mkdir/%13ju}" 3222145d321SEmmanuel Vadot "{:rmdir/%13ju}{:readdir/%13ju}" 3232145d321SEmmanuel Vadot "{:rdirplus/%13ju}{:access/%13ju}\n", 324693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RENAME], 325693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LINK], 326693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SYMLINK], 327693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_MKDIR], 328693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RMDIR], 329693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READDIR], 330693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READDIRPLUS], 331693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_ACCESS]); 3322145d321SEmmanuel Vadot 3332145d321SEmmanuel Vadot xo_emit("{T:Mknod/%13.13s}{T:Fsstat/%13.13s}" 3342145d321SEmmanuel Vadot "{T:Fsinfo/%13.13s}{T:PathConf/%13.13s}" 3352145d321SEmmanuel Vadot "{T:Commit/%13.13s}\n"); 3362145d321SEmmanuel Vadot xo_emit("{:mknod/%13ju}{:fsstat/%13ju}" 3372145d321SEmmanuel Vadot "{:fsinfo/%13ju}{:pathconf/%13ju}" 3382145d321SEmmanuel Vadot "{:commit/%13ju}\n", 339693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_MKNOD], 340693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_FSSTAT], 341693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_FSINFO], 342693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_PATHCONF], 343693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_COMMIT]); 3442145d321SEmmanuel Vadot 3452145d321SEmmanuel Vadot xo_close_container("operations"); 3462145d321SEmmanuel Vadot 3472145d321SEmmanuel Vadot xo_open_container("rpcs"); 3482145d321SEmmanuel Vadot xo_emit("{T:Rpc Info:}\n"); 3492145d321SEmmanuel Vadot 3502145d321SEmmanuel Vadot xo_emit("{T:TimedOut/%13.13s}{T:Invalid/%13.13s}" 3512145d321SEmmanuel Vadot "{T:X Replies/%13.13s}{T:Retries/%13.13s}" 3522145d321SEmmanuel Vadot "{T:Requests/%13.13s}\n"); 3532145d321SEmmanuel Vadot xo_emit("{:timedout/%13ju}{:invalid/%13ju}" 3542145d321SEmmanuel Vadot "{:xreplies/%13ju}{:retries/%13ju}" 3552145d321SEmmanuel Vadot "{:requests/%13ju}\n", 356693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpctimeouts, 357693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpcinvalid, 358693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpcunexpected, 359693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpcretries, 360693957f8SRick Macklem (uintmax_t)ext_nfsstats.rpcrequests); 3612145d321SEmmanuel Vadot xo_close_container("rpcs"); 3622145d321SEmmanuel Vadot 3632145d321SEmmanuel Vadot xo_open_container("cache"); 3642145d321SEmmanuel Vadot xo_emit("{T:Cache Info:}\n"); 3652145d321SEmmanuel Vadot 3662145d321SEmmanuel Vadot xo_emit("{T:Attr Hits/%13.13s}{T:Attr Misses/%13.13s}" 3672145d321SEmmanuel Vadot "{T:Lkup Hits/%13.13s}{T:Lkup Misses/%13.13s}" 3682145d321SEmmanuel Vadot "{T:BioR Hits/%13.13s}{T:BioR Misses/%13.13s}" 3692145d321SEmmanuel Vadot "{T:BioW Hits/%13.13s}{T:BioW Misses/%13.13s}\n"); 3702145d321SEmmanuel Vadot xo_emit("{:attrhits/%13ju}{:attrmisses/%13ju}" 3712145d321SEmmanuel Vadot "{:lkuphits/%13ju}{:lkupmisses/%13ju}" 3722145d321SEmmanuel Vadot "{:biorhits/%13ju}{:biormisses/%13ju}" 3732145d321SEmmanuel Vadot "{:biowhits/%13ju}{:biowmisses/%13ju}\n", 374693957f8SRick Macklem (uintmax_t)ext_nfsstats.attrcache_hits, 375693957f8SRick Macklem (uintmax_t)ext_nfsstats.attrcache_misses, 376693957f8SRick Macklem (uintmax_t)ext_nfsstats.lookupcache_hits, 3772145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.lookupcache_misses, 378693957f8SRick Macklem (uintmax_t)(ext_nfsstats.biocache_reads - 379693957f8SRick Macklem ext_nfsstats.read_bios), 380693957f8SRick Macklem (uintmax_t)ext_nfsstats.read_bios, 381693957f8SRick Macklem (uintmax_t)(ext_nfsstats.biocache_writes - 382693957f8SRick Macklem ext_nfsstats.write_bios), 383693957f8SRick Macklem (uintmax_t)ext_nfsstats.write_bios); 3842145d321SEmmanuel Vadot 3852145d321SEmmanuel Vadot xo_emit("{T:BioRL Hits/%13.13s}{T:BioRL Misses/%13.13s}" 3862145d321SEmmanuel Vadot "{T:BioD Hits/%13.13s}{T:BioD Misses/%13.13s}" 3872145d321SEmmanuel Vadot "{T:DirE Hits/%13.13s}{T:DirE Misses/%13.13s}" 3882145d321SEmmanuel Vadot "{T:Accs Hits/%13.13s}{T:Accs Misses/%13.13s}\n"); 3892145d321SEmmanuel Vadot xo_emit("{:biosrlhits/%13ju}{:biorlmisses/%13ju}" 3902145d321SEmmanuel Vadot "{:biodhits/%13ju}{:biodmisses/%13ju}" 3912145d321SEmmanuel Vadot "{:direhits/%13ju}{:diremisses/%13ju}" 3922145d321SEmmanuel Vadot "{:accshits/%13ju}{:accsmisses/%13ju}\n", 393693957f8SRick Macklem (uintmax_t)(ext_nfsstats.biocache_readlinks - 394693957f8SRick Macklem ext_nfsstats.readlink_bios), 395693957f8SRick Macklem (uintmax_t)ext_nfsstats.readlink_bios, 396693957f8SRick Macklem (uintmax_t)(ext_nfsstats.biocache_readdirs - 397693957f8SRick Macklem ext_nfsstats.readdir_bios), 3982145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.readdir_bios, 399693957f8SRick Macklem (uintmax_t)ext_nfsstats.direofcache_hits, 400693957f8SRick Macklem (uintmax_t)ext_nfsstats.direofcache_misses, 401693957f8SRick Macklem (uintmax_t)ext_nfsstats.accesscache_hits, 402693957f8SRick Macklem (uintmax_t)ext_nfsstats.accesscache_misses); 4032145d321SEmmanuel Vadot 4042145d321SEmmanuel Vadot xo_close_container("cache"); 4052145d321SEmmanuel Vadot 4062145d321SEmmanuel Vadot xo_close_container("clientstats"); 4074893ef0bSMatthew Dillon } 4084893ef0bSMatthew Dillon if (serverOnly) { 4092145d321SEmmanuel Vadot xo_open_container("serverstats"); 4102145d321SEmmanuel Vadot 4112145d321SEmmanuel Vadot xo_emit("{T:Server Info:}\n"); 4122145d321SEmmanuel Vadot xo_open_container("operations"); 4132145d321SEmmanuel Vadot 4142145d321SEmmanuel Vadot xo_emit("{T:Getattr/%13.13s}{T:Setattr/%13.13s}" 4152145d321SEmmanuel Vadot "{T:Lookup/%13.13s}{T:Readlink/%13.13s}" 4162145d321SEmmanuel Vadot "{T:Read/%13.13s}{T:Write/%13.13s}" 4172145d321SEmmanuel Vadot "{T:Create/%13.13s}{T:Remove/%13.13s}\n"); 4182145d321SEmmanuel Vadot xo_emit("{:getattr/%13ju}{:setattr/%13ju}" 4192145d321SEmmanuel Vadot "{:lookup/%13ju}{:readlink/%13ju}" 4202145d321SEmmanuel Vadot "{:read/%13ju}{:write/%13ju}" 4212145d321SEmmanuel Vadot "{:create/%13ju}{:remove/%13ju}\n", 422693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETATTR], 423693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETATTR], 424693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOOKUP], 425693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READLINK], 426693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READ], 427693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WRITE], 428693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_CREATE], 429693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_REMOVE]); 4302145d321SEmmanuel Vadot 4312145d321SEmmanuel Vadot xo_emit("{T:Rename/%13.13s}{T:Link/%13.13s}" 4322145d321SEmmanuel Vadot "{T:Symlink/%13.13s}{T:Mkdir/%13.13s}" 4332145d321SEmmanuel Vadot "{T:Rmdir/%13.13s}{T:Readdir/%13.13s}" 4342145d321SEmmanuel Vadot "{T:RdirPlus/%13.13s}{T:Access/%13.13s}\n"); 4352145d321SEmmanuel Vadot xo_emit("{:rename/%13ju}{:link/%13ju}" 4362145d321SEmmanuel Vadot "{:symlink/%13ju}{:mkdir/%13ju}" 4372145d321SEmmanuel Vadot "{:rmdir/%13ju}{:readdir/%13ju}" 4382145d321SEmmanuel Vadot "{:rdirplus/%13ju}{:access/%13ju}\n", 439693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RENAME], 440693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LINK], 441693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SYMLINK], 442693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_MKDIR], 443693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RMDIR], 444693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READDIR], 445693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READDIRPLUS], 446693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_ACCESS]); 4472145d321SEmmanuel Vadot 4482145d321SEmmanuel Vadot xo_emit("{T:Mknod/%13.13s}{T:Fsstat/%13.13s}" 4492145d321SEmmanuel Vadot "{T:Fsinfo/%13.13s}{T:PathConf/%13.13s}" 4502145d321SEmmanuel Vadot "{T:Commit/%13.13s}\n"); 4512145d321SEmmanuel Vadot xo_emit("{:mknod/%13ju}{:fsstat/%13ju}" 4522145d321SEmmanuel Vadot "{:fsinfo/%13ju}{:pathconf/%13ju}" 4532145d321SEmmanuel Vadot "{:commit/%13ju}\n", 454693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_MKNOD], 455693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_FSSTAT], 456693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_FSINFO], 457693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_PATHCONF], 458693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_COMMIT]); 4592145d321SEmmanuel Vadot 4602145d321SEmmanuel Vadot xo_close_container("operations"); 4612145d321SEmmanuel Vadot 4622145d321SEmmanuel Vadot xo_open_container("server"); 463b5965b56SRick Macklem xo_emit("{T:Server Re-Failed}\n"); 464b5965b56SRick Macklem xo_emit("{:retfailed/%16ju}\n", (uintmax_t)ext_nfsstats.srvrpc_errs); 4652145d321SEmmanuel Vadot 466b5965b56SRick Macklem xo_emit("{T:Server Faults}\n"); 467b5965b56SRick Macklem xo_emit("{:faults/%13ju}\n", (uintmax_t)ext_nfsstats.srv_errs); 4682145d321SEmmanuel Vadot 4692145d321SEmmanuel Vadot xo_emit("{T:Server Write Gathering:/%13.13s}\n"); 4702145d321SEmmanuel Vadot 4712145d321SEmmanuel Vadot xo_emit("{T:WriteOps/%13.13s}{T:WriteRPC/%13.13s}" 4722145d321SEmmanuel Vadot "{T:Opsaved/%13.13s}\n"); 4732145d321SEmmanuel Vadot xo_emit("{:writeops/%13ju}{:writerpc/%13ju}" 4742145d321SEmmanuel Vadot "{:opsaved/%13ju}\n", 475e85b7d75SRick Macklem /* 476e85b7d75SRick Macklem * The new client doesn't do write gathering. It was 477e85b7d75SRick Macklem * only useful for NFSv2. 478e85b7d75SRick Macklem */ 479693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WRITE], 480693957f8SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WRITE], 0); 4812145d321SEmmanuel Vadot 4822145d321SEmmanuel Vadot xo_close_container("server"); 4832145d321SEmmanuel Vadot 4842145d321SEmmanuel Vadot xo_open_container("cache"); 4852145d321SEmmanuel Vadot xo_emit("{T:Server Cache Stats:/%13.13s}\n"); 4862145d321SEmmanuel Vadot xo_emit("{T:Inprog/%13.13s}{T:Idem/%13.13s}" 4872145d321SEmmanuel Vadot "{T:Non-Idem/%13.13s}{T:Misses/%13.13s}\n"); 4882145d321SEmmanuel Vadot xo_emit("{:inprog/%13ju}{:idem/%13ju}" 4892145d321SEmmanuel Vadot "{:nonidem/%13ju}{:misses/%13ju}\n", 4902145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvcache_inproghits, 4912145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvcache_idemdonehits, 4922145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvcache_nonidemdonehits, 4932145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvcache_misses); 4942145d321SEmmanuel Vadot xo_close_container("cache"); 4952145d321SEmmanuel Vadot 4962145d321SEmmanuel Vadot xo_close_container("serverstats"); 4974893ef0bSMatthew Dillon } 4989b50d902SRodney W. Grimes } 4999b50d902SRodney W. Grimes 500722e2552SEdward Tomasz Napierala static void 501693957f8SRick Macklem printhdr(int clientOnly, int serverOnly, int newStats) 5029b50d902SRodney W. Grimes { 503693957f8SRick Macklem 504693957f8SRick Macklem if (newStats) { 505693957f8SRick Macklem printf(" [%s Read %s] [%s Write %s] " 506693957f8SRick Macklem "%s[=========== Total ============]\n" 507693957f8SRick Macklem " KB/t tps MB/s%s KB/t tps MB/s%s " 508693957f8SRick Macklem "%sKB/t tps MB/s ms ql %%b", 509693957f8SRick Macklem widemode ? "========" : "=====", 510693957f8SRick Macklem widemode ? "========" : "=====", 511693957f8SRick Macklem widemode ? "========" : "=====", 512693957f8SRick Macklem widemode ? "=======" : "====", 513693957f8SRick Macklem widemode ? "[Commit ] " : "", 514693957f8SRick Macklem widemode ? " ms" : "", 515693957f8SRick Macklem widemode ? " ms" : "", 516693957f8SRick Macklem widemode ? "tps ms " : ""); 517693957f8SRick Macklem } else { 5184893ef0bSMatthew Dillon printf("%s%6.6s %6.6s %6.6s %6.6s %6.6s %6.6s %6.6s %6.6s", 5194893ef0bSMatthew Dillon ((serverOnly && clientOnly) ? " " : " "), 5204893ef0bSMatthew Dillon "GtAttr", "Lookup", "Rdlink", "Read", "Write", "Rename", 5214893ef0bSMatthew Dillon "Access", "Rddir"); 5224893ef0bSMatthew Dillon if (widemode && clientOnly) { 5234893ef0bSMatthew Dillon printf(" Attr Lkup BioR BioW Accs BioD"); 5249b50d902SRodney W. Grimes } 525693957f8SRick Macklem } 5264893ef0bSMatthew Dillon printf("\n"); 5274893ef0bSMatthew Dillon fflush(stdout); 5289b50d902SRodney W. Grimes } 5299b50d902SRodney W. Grimes 530722e2552SEdward Tomasz Napierala static void 531813947b7SJohn Baldwin usage(void) 5329b50d902SRodney W. Grimes { 5339b50d902SRodney W. Grimes (void)fprintf(stderr, 534693957f8SRick Macklem "usage: nfsstat [-cdemszW] [-M core] [-N system] [-w wait]\n"); 5359b50d902SRodney W. Grimes exit(1); 5369b50d902SRodney W. Grimes } 5374893ef0bSMatthew Dillon 5384893ef0bSMatthew Dillon static char SPBuf[64][8]; 5394893ef0bSMatthew Dillon static int SPIndex; 5404893ef0bSMatthew Dillon 541722e2552SEdward Tomasz Napierala static char * 5424893ef0bSMatthew Dillon sperc1(int hits, int misses) 5434893ef0bSMatthew Dillon { 5444893ef0bSMatthew Dillon char *p = SPBuf[SPIndex]; 5454893ef0bSMatthew Dillon 5464893ef0bSMatthew Dillon if (hits + misses) { 5474893ef0bSMatthew Dillon sprintf(p, "%3d%%", 5484893ef0bSMatthew Dillon (int)(char)((quad_t)hits * 100 / (hits + misses))); 5494893ef0bSMatthew Dillon } else { 5504893ef0bSMatthew Dillon sprintf(p, " -"); 5514893ef0bSMatthew Dillon } 5524893ef0bSMatthew Dillon SPIndex = (SPIndex + 1) & 63; 5534893ef0bSMatthew Dillon return(p); 5544893ef0bSMatthew Dillon } 5554893ef0bSMatthew Dillon 556722e2552SEdward Tomasz Napierala static char * 5574893ef0bSMatthew Dillon sperc2(int ttl, int misses) 5584893ef0bSMatthew Dillon { 5594893ef0bSMatthew Dillon char *p = SPBuf[SPIndex]; 5604893ef0bSMatthew Dillon 5614893ef0bSMatthew Dillon if (ttl) { 5624893ef0bSMatthew Dillon sprintf(p, "%3d%%", 5634893ef0bSMatthew Dillon (int)(char)((quad_t)(ttl - misses) * 100 / ttl)); 5644893ef0bSMatthew Dillon } else { 5654893ef0bSMatthew Dillon sprintf(p, " -"); 5664893ef0bSMatthew Dillon } 5674893ef0bSMatthew Dillon SPIndex = (SPIndex + 1) & 63; 5684893ef0bSMatthew Dillon return(p); 5694893ef0bSMatthew Dillon } 5704893ef0bSMatthew Dillon 571693957f8SRick Macklem #define DELTA_T(field) \ 572693957f8SRick Macklem devstat_compute_etime(&cur_stats->field, \ 573693957f8SRick Macklem (prev_stats ? &prev_stats->field : NULL)) 574693957f8SRick Macklem 575693957f8SRick Macklem /* 576693957f8SRick Macklem * XXX KDM mostly copied from ctlstat. We should commonize the code (and 577693957f8SRick Macklem * the devstat code) somehow. 578693957f8SRick Macklem */ 579693957f8SRick Macklem static void 580693957f8SRick Macklem compute_new_stats(struct nfsstatsv1 *cur_stats, 581693957f8SRick Macklem struct nfsstatsv1 *prev_stats, int curop, 582693957f8SRick Macklem long double etime, long double *mbsec, 583693957f8SRick Macklem long double *kb_per_transfer, 584693957f8SRick Macklem long double *transfers_per_second, 585693957f8SRick Macklem long double *ms_per_transfer, uint64_t *queue_len, 586693957f8SRick Macklem long double *busy_pct) 587693957f8SRick Macklem { 588693957f8SRick Macklem uint64_t total_bytes = 0, total_operations = 0; 589693957f8SRick Macklem struct bintime total_time_bt; 590693957f8SRick Macklem struct timespec total_time_ts; 591693957f8SRick Macklem 592693957f8SRick Macklem bzero(&total_time_bt, sizeof(total_time_bt)); 593693957f8SRick Macklem bzero(&total_time_ts, sizeof(total_time_ts)); 594693957f8SRick Macklem 595693957f8SRick Macklem total_bytes = cur_stats->srvbytes[curop]; 596693957f8SRick Macklem total_operations = cur_stats->srvops[curop]; 597693957f8SRick Macklem if (prev_stats != NULL) { 598693957f8SRick Macklem total_bytes -= prev_stats->srvbytes[curop]; 599693957f8SRick Macklem total_operations -= prev_stats->srvops[curop]; 600693957f8SRick Macklem } 601693957f8SRick Macklem 602693957f8SRick Macklem *mbsec = total_bytes; 603693957f8SRick Macklem *mbsec /= 1024 * 1024; 604693957f8SRick Macklem if (etime > 0.0) { 605693957f8SRick Macklem *busy_pct = DELTA_T(busytime); 606693957f8SRick Macklem if (*busy_pct < 0) 607693957f8SRick Macklem *busy_pct = 0; 608693957f8SRick Macklem *busy_pct /= etime; 609693957f8SRick Macklem *busy_pct *= 100; 610693957f8SRick Macklem if (*busy_pct < 0) 611693957f8SRick Macklem *busy_pct = 0; 612693957f8SRick Macklem *mbsec /= etime; 613693957f8SRick Macklem } else { 614693957f8SRick Macklem *busy_pct = 0; 615693957f8SRick Macklem *mbsec = 0; 616693957f8SRick Macklem } 617693957f8SRick Macklem *kb_per_transfer = total_bytes; 618693957f8SRick Macklem *kb_per_transfer /= 1024; 619693957f8SRick Macklem if (total_operations > 0) 620693957f8SRick Macklem *kb_per_transfer /= total_operations; 621693957f8SRick Macklem else 622693957f8SRick Macklem *kb_per_transfer = 0; 623693957f8SRick Macklem if (etime > 0.0) { 624693957f8SRick Macklem *transfers_per_second = total_operations; 625693957f8SRick Macklem *transfers_per_second /= etime; 626693957f8SRick Macklem } else { 627693957f8SRick Macklem *transfers_per_second = 0.0; 628693957f8SRick Macklem } 629693957f8SRick Macklem 630693957f8SRick Macklem if (total_operations > 0) { 631693957f8SRick Macklem *ms_per_transfer = DELTA_T(srvduration[curop]); 632693957f8SRick Macklem *ms_per_transfer /= total_operations; 633693957f8SRick Macklem *ms_per_transfer *= 1000; 634693957f8SRick Macklem } else 635693957f8SRick Macklem *ms_per_transfer = 0.0; 636693957f8SRick Macklem 637693957f8SRick Macklem *queue_len = cur_stats->srvstartcnt - cur_stats->srvdonecnt; 638693957f8SRick Macklem } 639693957f8SRick Macklem 640bcdaa850SRick Macklem /* 6410744a2b0SRick Macklem * Print a description of the nfs stats for the client/server, 6420744a2b0SRick Macklem * including NFSv4.1. 6430744a2b0SRick Macklem */ 6440744a2b0SRick Macklem static void 6452145d321SEmmanuel Vadot exp_intpr(int clientOnly, int serverOnly, int nfs41) 6460744a2b0SRick Macklem { 6470744a2b0SRick Macklem int nfssvc_flag; 6480744a2b0SRick Macklem 6492145d321SEmmanuel Vadot xo_open_container("nfsv4"); 6502145d321SEmmanuel Vadot 6510744a2b0SRick Macklem nfssvc_flag = NFSSVC_GETSTATS | NFSSVC_NEWSTRUCT; 6520744a2b0SRick Macklem if (zflag != 0) { 6530744a2b0SRick Macklem if (clientOnly != 0) 6540744a2b0SRick Macklem nfssvc_flag |= NFSSVC_ZEROCLTSTATS; 6550744a2b0SRick Macklem if (serverOnly != 0) 6560744a2b0SRick Macklem nfssvc_flag |= NFSSVC_ZEROSRVSTATS; 6570744a2b0SRick Macklem } 6580744a2b0SRick Macklem ext_nfsstats.vers = NFSSTATS_V1; 6590744a2b0SRick Macklem if (nfssvc(nfssvc_flag, &ext_nfsstats) < 0) 6602145d321SEmmanuel Vadot xo_err(1, "Can't get stats"); 6610744a2b0SRick Macklem if (clientOnly != 0) { 6622145d321SEmmanuel Vadot xo_open_container("clientstats"); 6632145d321SEmmanuel Vadot 6642145d321SEmmanuel Vadot xo_open_container("operations"); 6650744a2b0SRick Macklem if (printtitle) { 6662145d321SEmmanuel Vadot xo_emit("{T:Client Info:}\n"); 6672145d321SEmmanuel Vadot xo_emit("{T:RPC Counts:}\n"); 6680744a2b0SRick Macklem } 6692145d321SEmmanuel Vadot xo_emit("{T:Getattr/%13.13s}{T:Setattr/%13.13s}" 6702145d321SEmmanuel Vadot "{T:Lookup/%13.13s}{T:Readlink/%13.13s}" 6712145d321SEmmanuel Vadot "{T:Read/%13.13s}{T:Write/%13.13s}\n"); 6722145d321SEmmanuel Vadot xo_emit("{:getattr/%13ju}{:setattr/%13ju}{:lookup/%13ju}" 6732145d321SEmmanuel Vadot "{:readlink/%13ju}{:read/%13ju}{:write/%13ju}\n", 6740744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_GETATTR], 6750744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETATTR], 6760744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LOOKUP], 6770744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READLINK], 6780744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READ], 6790744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_WRITE]); 6802145d321SEmmanuel Vadot xo_emit("{T:Create/%13.13s}{T:Remove/%13.13s}" 6812145d321SEmmanuel Vadot "{T:Rename/%13.13s}{T:Link/%13.13s}" 6822145d321SEmmanuel Vadot "{T:Symlink/%13.13s}{T:Mkdir/%13.13s}\n"); 6832145d321SEmmanuel Vadot xo_emit("{:create/%13ju}{:remove/%13ju}{:rename/%13ju}" 6842145d321SEmmanuel Vadot "{:link/%13ju}{:symlink/%13ju}{:mkdir/%13ju}\n", 6850744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_CREATE], 6860744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_REMOVE], 6870744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RENAME], 6880744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LINK], 6890744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SYMLINK], 6900744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_MKDIR]); 6912145d321SEmmanuel Vadot xo_emit("{T:Rmdir/%13.13s}{T:Readdir/%13.13s}" 6922145d321SEmmanuel Vadot "{T:RdirPlus/%13.13s}{T:Access/%13.13s}" 6932145d321SEmmanuel Vadot "{T:Mknod/%13.13s}{T:Fsstat/%13.13s}\n"); 6942145d321SEmmanuel Vadot xo_emit("{:rmdir/%13ju}{:readdir/%13ju}{:rdirplus/%13ju}" 6952145d321SEmmanuel Vadot "{:access/%13ju}{:mknod/%13ju}{:fsstat/%13ju}\n", 6960744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RMDIR], 6970744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READDIR], 6980744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READDIRPLUS], 6990744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_ACCESS], 7000744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_MKNOD], 7010744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_FSSTAT]); 7022145d321SEmmanuel Vadot xo_emit("{T:FSinfo/%13.13s}{T:pathConf/%13.13s}" 7032145d321SEmmanuel Vadot "{T:Commit/%13.13s}{T:SetClId/%13.13s}" 7042145d321SEmmanuel Vadot "{T:SetClIdCf/%13.13s}{T:Lock/%13.13s}\n"); 7052145d321SEmmanuel Vadot xo_emit("{:fsinfo/%13ju}{:pathconf/%13ju}{:commit/%13ju}" 7062145d321SEmmanuel Vadot "{:setclientid/%13ju}{:setclientidcf/%13ju}{:lock/%13ju}\n", 7070744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_FSINFO], 7080744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_PATHCONF], 7090744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_COMMIT], 7100744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETCLIENTID], 7110744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETCLIENTIDCFRM], 7120744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LOCK]); 7132145d321SEmmanuel Vadot xo_emit("{T:LockT/%13.13s}{T:LockU/%13.13s}" 7142145d321SEmmanuel Vadot "{T:Open/%13.13s}{T:OpenCfr/%13.13s}\n"); 7152145d321SEmmanuel Vadot xo_emit("{:lockt/%13ju}{:locku/%13ju}" 7162145d321SEmmanuel Vadot "{:open/%13ju}{:opencfr/%13ju}\n", 7170744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LOCKT], 7180744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LOCKU], 7190744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_OPEN], 7202145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_OPENCONFIRM]); 7212145d321SEmmanuel Vadot 7222145d321SEmmanuel Vadot if (nfs41) { 7232145d321SEmmanuel Vadot xo_open_container("nfsv41"); 7242145d321SEmmanuel Vadot 7252145d321SEmmanuel Vadot xo_emit("{T:OpenDownGr/%13.13s}{T:Close/%13.13s}\n"); 7262145d321SEmmanuel Vadot xo_emit("{:opendowngr/%13ju}{:close/%13ju}\n", 7270744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_OPENDOWNGRADE], 7280744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_CLOSE]); 7292145d321SEmmanuel Vadot 7302145d321SEmmanuel Vadot xo_emit("{T:RelLckOwn/%13.13s}{T:FreeStateID/%13.13s}" 7312145d321SEmmanuel Vadot "{T:PutRootFH/%13.13s}{T:DelegRet/%13.13s}" 7322145d321SEmmanuel Vadot "{T:GetAcl/%13.13s}{T:SetAcl/%13.13s}\n"); 7332145d321SEmmanuel Vadot xo_emit("{:rellckown/%13ju}{:freestateid/%13ju}" 7342145d321SEmmanuel Vadot "{:getacl/%13ju}{:delegret/%13ju}" 7352145d321SEmmanuel Vadot "{:getacl/%13ju}{:setacl/%13ju}\n", 7360744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RELEASELCKOWN], 7370744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_FREESTATEID], 7380744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_PUTROOTFH], 7390744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_DELEGRETURN], 7400744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_GETACL], 7410744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETACL]); 7422145d321SEmmanuel Vadot 7432145d321SEmmanuel Vadot xo_emit("{T:ExchangeId/%13.13s}{T:CreateSess/%13.13s}" 7442145d321SEmmanuel Vadot "{T:DestroySess/%13.13s}{T:DestroyClId/%13.13s}" 7452145d321SEmmanuel Vadot "{T:LayoutGet/%13.13s}{T:GetDevInfo/%13.13s}\n"); 7462145d321SEmmanuel Vadot xo_emit("{:exchangeid/%13ju}{:createsess/%13ju}" 7472145d321SEmmanuel Vadot "{:destroysess/%13ju}{:destroyclid/%13ju}" 7482145d321SEmmanuel Vadot "{:layoutget/%13ju}{:getdevinfo/%13ju}\n", 7490744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_EXCHANGEID], 7500744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_CREATESESSION], 7510744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_DESTROYSESSION], 7520744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_DESTROYCLIENT], 7530744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LAYOUTGET], 7540744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_GETDEVICEINFO]); 7552145d321SEmmanuel Vadot 7562145d321SEmmanuel Vadot xo_emit("{T:LayoutCommit/%13.13s}{T:LayoutReturn/%13.13s}" 7572145d321SEmmanuel Vadot "{T:ReclaimCompl/%13.13s}{T:ReadDataS/%13.13s}" 7582145d321SEmmanuel Vadot "{T:WriteDataS/%13.13s}{T:CommitDataS/%13.13s}\n"); 7592145d321SEmmanuel Vadot xo_emit("{:layoutcomit/%13ju}{:layoutreturn/%13ju}" 7602145d321SEmmanuel Vadot "{:reclaimcompl/%13ju}{:readdatas/%13ju}" 7612145d321SEmmanuel Vadot "{:writedatas/%13ju}{:commitdatas/%13ju}\n", 7620744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LAYOUTCOMMIT], 7630744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LAYOUTRETURN], 7640744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RECLAIMCOMPL], 7650744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_READDS], 7660744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_WRITEDS], 7670744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_COMMITDS]); 7682145d321SEmmanuel Vadot 7692145d321SEmmanuel Vadot xo_emit("{T:OpenLayout/%13.13s}{T:CreateLayout/%13.13s}\n"); 7702145d321SEmmanuel Vadot xo_emit("{:openlayout/%13ju}{:createlayout/%13ju}\n", 7712d446498SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_OPENLAYGET], 7722d446498SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_CREATELAYGET]); 7732145d321SEmmanuel Vadot 7742145d321SEmmanuel Vadot xo_close_container("nfsv41"); 775*309c8f76SRick Macklem 776*309c8f76SRick Macklem xo_open_container("nfsv42"); 777*309c8f76SRick Macklem 778*309c8f76SRick Macklem xo_emit("{T:IOAdvise/%13.13s}{T:Allocate/%13.13s}" 779*309c8f76SRick Macklem "{T:Copy/%13.13s}{T:Seek/%13.13s}" 780*309c8f76SRick Macklem "{T:SeekDataS/%13.13s}{T:GetExtattr/%13.13s}\n"); 781*309c8f76SRick Macklem xo_emit("{:ioadvise/%13ju}{:allocate/%13ju}" 782*309c8f76SRick Macklem "{:copy/%13ju}{:seek/%13ju}" 783*309c8f76SRick Macklem "{:seekdatas/%13ju}{:getextattr/%13ju}\n", 784*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_IOADVISE], 785*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_ALLOCATE], 786*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_COPY], 787*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SEEK], 788*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SEEKDS], 789*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_GETEXTATTR]); 790*309c8f76SRick Macklem 791*309c8f76SRick Macklem xo_emit("{T:SetExtattr/%13.13s}{T:RmExtattr/%13.13s}" 792*309c8f76SRick Macklem "{T:ListExtattr/%13.13s}\n"); 793*309c8f76SRick Macklem xo_emit("{:setextattr/%13ju}{:rmextattr/%13ju}" 794*309c8f76SRick Macklem "{:listextattr/%13ju}\n", 795*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_SETEXTATTR], 796*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_RMEXTATTR], 797*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.rpccnt[NFSPROC_LISTEXTATTR]); 798*309c8f76SRick Macklem 799*309c8f76SRick Macklem xo_close_container("nfsv42"); 8002145d321SEmmanuel Vadot } 8012145d321SEmmanuel Vadot xo_close_container("operations"); 8022145d321SEmmanuel Vadot 8032145d321SEmmanuel Vadot xo_open_container("client"); 8042145d321SEmmanuel Vadot xo_emit("{T:OpenOwner/%13.13s}{T:Opens/%13.13s}" 8052145d321SEmmanuel Vadot "{T:LockOwner/%13.13s}{T:Locks/%13.13s}" 8062145d321SEmmanuel Vadot "{T:Delegs/%13.13s}{T:LocalOwn/%13.13s}\n"); 8072145d321SEmmanuel Vadot xo_emit("{:openowner/%13ju}{:opens/%13ju}" 8082145d321SEmmanuel Vadot "{:lockowner/%13ju}{:locks/%13ju}" 8092145d321SEmmanuel Vadot "{:delegs/%13ju}{:localown/%13ju}\n", 8100744a2b0SRick Macklem (uintmax_t)ext_nfsstats.clopenowners, 8110744a2b0SRick Macklem (uintmax_t)ext_nfsstats.clopens, 8120744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllockowners, 8130744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllocks, 8140744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cldelegates, 8150744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllocalopenowners); 8162145d321SEmmanuel Vadot 8172145d321SEmmanuel Vadot xo_emit("{T:LocalOpen/%13.13s}{T:LocalLown/%13.13s}" 818a16e0d44SRick Macklem "{T:LocalLock/%13.13s}\n"); 8192145d321SEmmanuel Vadot xo_emit("{:localopen/%13ju}{:locallown/%13ju}" 8202145d321SEmmanuel Vadot "{:locallock/%13ju}\n", 8210744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllocalopens, 8220744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllocallockowners, 8230744a2b0SRick Macklem (uintmax_t)ext_nfsstats.cllocallocks); 8242145d321SEmmanuel Vadot xo_close_container("client"); 8252145d321SEmmanuel Vadot 8262145d321SEmmanuel Vadot xo_open_container("rpc"); 8272145d321SEmmanuel Vadot if (printtitle) 8282145d321SEmmanuel Vadot xo_emit("{T:Rpc Info:}\n"); 8292145d321SEmmanuel Vadot xo_emit("{T:TimedOut/%13.13s}{T:Invalid/%13.13s}" 8302145d321SEmmanuel Vadot "{T:X Replies/%13.13s}{T:Retries/%13.13s}" 8312145d321SEmmanuel Vadot "{T:Requests/%13.13s}\n"); 8322145d321SEmmanuel Vadot xo_emit("{:timedout/%13ju}{:invalid/%13ju}" 8332145d321SEmmanuel Vadot "{:xreplies/%13ju}{:retries/%13ju}" 8342145d321SEmmanuel Vadot "{:requests/%13ju}\n", 8350744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpctimeouts, 8360744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpcinvalid, 8370744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpcunexpected, 8380744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpcretries, 8390744a2b0SRick Macklem (uintmax_t)ext_nfsstats.rpcrequests); 8402145d321SEmmanuel Vadot xo_close_container("rpc"); 8412145d321SEmmanuel Vadot 8422145d321SEmmanuel Vadot xo_open_container("cache"); 8432145d321SEmmanuel Vadot if (printtitle) 8442145d321SEmmanuel Vadot xo_emit("{T:Cache Info:}\n"); 8452145d321SEmmanuel Vadot xo_emit("{T:Attr Hits/%13.13s}{T:Attr Misses/%13.13s}" 8462145d321SEmmanuel Vadot "{T:Lkup Hits/%13.13s}{T:Lkup Misses/%13.13s}\n"); 8472145d321SEmmanuel Vadot xo_emit("{:attrhits/%13ju}{:attrmisses/%13ju}" 8482145d321SEmmanuel Vadot "{:lkuphits/%13ju}{:lkupmisses/%13ju}\n", 8490744a2b0SRick Macklem (uintmax_t)ext_nfsstats.attrcache_hits, 8500744a2b0SRick Macklem (uintmax_t)ext_nfsstats.attrcache_misses, 8510744a2b0SRick Macklem (uintmax_t)ext_nfsstats.lookupcache_hits, 8520744a2b0SRick Macklem (uintmax_t)ext_nfsstats.lookupcache_misses); 8532145d321SEmmanuel Vadot 8542145d321SEmmanuel Vadot xo_emit("{T:BioR Hits/%13.13s}{T:BioR Misses/%13.13s}" 8552145d321SEmmanuel Vadot "{T:BioW Hits/%13.13s}{T:BioW Misses/%13.13s}\n"); 8562145d321SEmmanuel Vadot xo_emit("{:biorhits/%13ju}{:biormisses/%13ju}" 8572145d321SEmmanuel Vadot "{:biowhits/%13ju}{:biowmisses/%13ju}\n", 8580744a2b0SRick Macklem (uintmax_t)(ext_nfsstats.biocache_reads - 8590744a2b0SRick Macklem ext_nfsstats.read_bios), 8600744a2b0SRick Macklem (uintmax_t)ext_nfsstats.read_bios, 8610744a2b0SRick Macklem (uintmax_t)(ext_nfsstats.biocache_writes - 8620744a2b0SRick Macklem ext_nfsstats.write_bios), 8630744a2b0SRick Macklem (uintmax_t)ext_nfsstats.write_bios); 8642145d321SEmmanuel Vadot 8652145d321SEmmanuel Vadot xo_emit("{T:BioRL Hits/%13.13s}{T:BioRL Misses/%13.13s}" 8662145d321SEmmanuel Vadot "{T:BioD Hits/%13.13s}{T:BioD Misses/%13.13s}\n"); 8672145d321SEmmanuel Vadot xo_emit("{:biorlhits/%13ju}{:biorlmisses/%13ju}" 8682145d321SEmmanuel Vadot "{:biodhits/%13ju}{:biodmisses/%13ju}\n", 8690744a2b0SRick Macklem (uintmax_t)(ext_nfsstats.biocache_readlinks - 8700744a2b0SRick Macklem ext_nfsstats.readlink_bios), 8710744a2b0SRick Macklem (uintmax_t)ext_nfsstats.readlink_bios, 8720744a2b0SRick Macklem (uintmax_t)(ext_nfsstats.biocache_readdirs - 8730744a2b0SRick Macklem ext_nfsstats.readdir_bios), 8740744a2b0SRick Macklem (uintmax_t)ext_nfsstats.readdir_bios); 8752145d321SEmmanuel Vadot 8762145d321SEmmanuel Vadot xo_emit("{T:DirE Hits/%13.13s}{T:DirE Misses/%13.13s}\n"); 8772145d321SEmmanuel Vadot xo_emit("{:direhits/%13ju}{:diremisses/%13ju}\n", 8780744a2b0SRick Macklem (uintmax_t)ext_nfsstats.direofcache_hits, 8790744a2b0SRick Macklem (uintmax_t)ext_nfsstats.direofcache_misses); 8802145d321SEmmanuel Vadot xo_open_container("cache"); 8812145d321SEmmanuel Vadot 8822145d321SEmmanuel Vadot xo_close_container("clientstats"); 8830744a2b0SRick Macklem } 8840744a2b0SRick Macklem if (serverOnly != 0) { 8852145d321SEmmanuel Vadot xo_open_container("serverstats"); 8862145d321SEmmanuel Vadot 8872145d321SEmmanuel Vadot xo_open_container("operations"); 8882145d321SEmmanuel Vadot if (printtitle) 8892145d321SEmmanuel Vadot xo_emit("{T:Server Info:}\n"); 8902145d321SEmmanuel Vadot xo_emit("{T:Getattr/%13.13s}{T:Setattr/%13.13s}" 8912145d321SEmmanuel Vadot "{T:Lookup/%13.13s}{T:Readlink/%13.13s}" 8922145d321SEmmanuel Vadot "{T:Read/%13.13s}{T:Write/%13.13s}\n"); 8932145d321SEmmanuel Vadot xo_emit("{:getattr/%13ju}{:setattr/%13ju}{:lookup/%13ju}" 8942145d321SEmmanuel Vadot "{:readlink/%13ju}{:read/%13ju}{:write/%13ju}\n", 8950744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETATTR], 8960744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETATTR], 8970744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOOKUP], 8980744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READLINK], 8990744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READ], 9000744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WRITE]); 9012145d321SEmmanuel Vadot xo_emit("{T:Create/%13.13s}{T:Remove/%13.13s}" 9022145d321SEmmanuel Vadot "{T:Rename/%13.13s}{T:Link/%13.13s}" 9032145d321SEmmanuel Vadot "{T:Symlink/%13.13s}{T:Mkdir/%13.13s}\n"); 9042145d321SEmmanuel Vadot xo_emit("{:create/%13ju}{:remove/%13ju}{:rename/%13ju}" 9052145d321SEmmanuel Vadot "{:link/%13ju}{:symlink/%13ju}{:mkdir/%13ju}\n", 9060744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_V3CREATE], 9070744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_REMOVE], 9080744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RENAME], 9090744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LINK], 9100744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SYMLINK], 9110744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_MKDIR]); 9122145d321SEmmanuel Vadot xo_emit("{T:Rmdir/%13.13s}{T:Readdir/%13.13s}" 9132145d321SEmmanuel Vadot "{T:RdirPlus/%13.13s}{T:Access/%13.13s}" 9142145d321SEmmanuel Vadot "{T:Mknod/%13.13s}{T:Fsstat/%13.13s}\n"); 9152145d321SEmmanuel Vadot xo_emit("{:rmdir/%13ju}{:readdir/%13ju}{:rdirplus/%13ju}" 9162145d321SEmmanuel Vadot "{:access/%13ju}{:mknod/%13ju}{:fsstat/%13ju}\n", 9170744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RMDIR], 9180744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READDIR], 9190744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READDIRPLUS], 9200744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_ACCESS], 9210744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_MKNOD], 9220744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_FSSTAT]); 9232145d321SEmmanuel Vadot xo_emit("{T:FSinfo/%13.13s}{T:pathConf/%13.13s}" 9242145d321SEmmanuel Vadot "{T:Commit/%13.13s}{T:LookupP/%13.13s}" 9252145d321SEmmanuel Vadot "{T:SetClId/%13.13s}{T:SetClIdCf/%13.13s}\n"); 9262145d321SEmmanuel Vadot xo_emit("{:fsinfo/%13ju}{:pathconf/%13ju}{:commit/%13ju}" 9272145d321SEmmanuel Vadot "{:lookupp/%13ju}{:setclientid/%13ju}{:setclientidcfrm/%13ju}\n", 9280744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_FSINFO], 9290744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_PATHCONF], 9300744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_COMMIT], 9310744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOOKUPP], 9320744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETCLIENTID], 9330744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETCLIENTIDCFRM]); 9342145d321SEmmanuel Vadot xo_emit("{T:Open/%13.13s}{T:OpenAttr/%13.13s}" 9352145d321SEmmanuel Vadot "{T:OpenDwnGr/%13.13s}{T:OpenCfrm/%13.13s}" 9362145d321SEmmanuel Vadot "{T:DelePurge/%13.13s}{T:DelRet/%13.13s}\n"); 9372145d321SEmmanuel Vadot xo_emit("{:open/%13ju}{:openattr/%13ju}{:opendwgr/%13ju}" 9382145d321SEmmanuel Vadot "{:opencfrm/%13ju}{:delepurge/%13ju}{:delreg/%13ju}\n", 9390744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OPEN], 9400744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OPENATTR], 9410744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OPENDOWNGRADE], 9420744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OPENCONFIRM], 9430744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_DELEGPURGE], 9440744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_DELEGRETURN]); 9452145d321SEmmanuel Vadot xo_emit("{T:GetFH/%13.13s}{T:Lock/%13.13s}" 9462145d321SEmmanuel Vadot "{T:LockT/%13.13s}{T:LockU/%13.13s}" 9472145d321SEmmanuel Vadot "{T:Close/%13.13s}{T:Verify/%13.13s}\n"); 9482145d321SEmmanuel Vadot xo_emit("{:getfh/%13ju}{:lock/%13ju}{:lockt/%13ju}" 9492145d321SEmmanuel Vadot "{:locku/%13ju}{:close/%13ju}{:verify/%13ju}\n", 9500744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETFH], 9510744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOCK], 9520744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOCKT], 9530744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LOCKU], 9540744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_CLOSE], 9550744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_VERIFY]); 9562145d321SEmmanuel Vadot xo_emit("{T:NVerify/%13.13s}{T:PutFH/%13.13s}" 9572145d321SEmmanuel Vadot "{T:PutPubFH/%13.13s}{T:PutRootFH/%13.13s}" 9582145d321SEmmanuel Vadot "{T:Renew/%13.13s}{T:RestoreFH/%13.13s}\n"); 9592145d321SEmmanuel Vadot xo_emit("{:nverify/%13ju}{:putfh/%13ju}{:putpubfh/%13ju}" 9602145d321SEmmanuel Vadot "{:putrootfh/%13ju}{:renew/%13ju}{:restore/%13ju}\n", 9610744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_NVERIFY], 9620744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_PUTFH], 9630744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_PUTPUBFH], 9640744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_PUTROOTFH], 9650744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RENEW], 9660744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RESTOREFH]); 9672145d321SEmmanuel Vadot xo_emit("{T:SaveFH/%13.13s}{T:Secinfo/%13.13s}" 9682145d321SEmmanuel Vadot "{T:RelLockOwn/%13.13s}{T:V4Create/%13.13s}\n"); 9692145d321SEmmanuel Vadot xo_emit("{:savefh/%13ju}{:secinfo/%13ju}{:rellockown/%13ju}" 9702145d321SEmmanuel Vadot "{:v4create/%13ju}\n", 9710744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SAVEFH], 9720744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SECINFO], 9730744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RELEASELCKOWN], 9742145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_CREATE]); 9752145d321SEmmanuel Vadot if (nfs41) { 9762145d321SEmmanuel Vadot xo_open_container("nfsv41"); 9772145d321SEmmanuel Vadot xo_emit("{T:BackChannelCtrl/%13.13s}{T:BindConnToSess/%13.13s}" 9782145d321SEmmanuel Vadot "{T:ExchangeID/%13.13s}{T:CreateSess/%13.13s}" 9792145d321SEmmanuel Vadot "{T:DestroySess/%13.13s}{T:FreeStateID/%13.13s}\n"); 9802145d321SEmmanuel Vadot xo_emit("{:backchannelctrl/%13ju}{:bindconntosess/%13ju}" 9812145d321SEmmanuel Vadot "{:exchangeid/%13ju}{:createsess/%13ju}" 9822145d321SEmmanuel Vadot "{:destroysess/%13ju}{:freestateid/%13ju}\n", 9830744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_BACKCHANNELCTL], 9842145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_BINDCONNTOSESS], 9850744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_EXCHANGEID], 9860744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_CREATESESSION], 9870744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_DESTROYSESSION], 9882145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_FREESTATEID]), 9892145d321SEmmanuel Vadot 9902145d321SEmmanuel Vadot xo_emit("{T:GetDirDeleg/%13.13s}{T:GetDevInfo/%13.13s}" 9912145d321SEmmanuel Vadot "{T:GetDevList/%13.13s}{T:layoutCommit/%13.13s}" 9922145d321SEmmanuel Vadot "{T:LayoutGet/%13.13s}{T:LayoutReturn/%13.13s}\n"); 9932145d321SEmmanuel Vadot xo_emit("{:getdirdeleg/%13ju}{:getdevinfo/%13ju}" 9942145d321SEmmanuel Vadot "{:getdevlist/%13ju}{:layoutcommit/%13ju}" 9952145d321SEmmanuel Vadot "{:layoutget/%13ju}{:layoutreturn/%13ju}\n", 9960744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETDIRDELEG], 9972145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETDEVINFO], 9980744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETDEVLIST], 9990744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LAYOUTCOMMIT], 10000744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LAYOUTGET], 10012145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LAYOUTRETURN]); 10022145d321SEmmanuel Vadot 10032145d321SEmmanuel Vadot xo_emit("{T:SecInfNoName/%13.13s}{T:Sequence/%13.13s}" 10042145d321SEmmanuel Vadot "{T:SetSSV/%13.13s}{T:TestStateID/%13.13s}" 10052145d321SEmmanuel Vadot "{T:WantDeleg/%13.13s}{T:DestroyClId/%13.13s}\n"); 10062145d321SEmmanuel Vadot xo_emit("{:secinfnoname/%13ju}{:sequence/%13ju}" 10072145d321SEmmanuel Vadot "{:setssv/%13ju}{:teststateid/%13ju}{:wantdeleg/%13ju}" 10082145d321SEmmanuel Vadot "{:destroyclid/%13ju}\n", 10090744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SECINFONONAME], 10102145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SEQUENCE], 10110744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETSSV], 10120744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_TESTSTATEID], 10130744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WANTDELEG], 10142145d321SEmmanuel Vadot (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_DESTROYCLIENTID]); 10152145d321SEmmanuel Vadot 10162145d321SEmmanuel Vadot xo_emit("{T:ReclaimCompl/%13.13s}\n"); 10172145d321SEmmanuel Vadot xo_emit("{:reclaimcompl/%13ju}\n", 10180744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_RECLAIMCOMPL]); 10192145d321SEmmanuel Vadot 10202145d321SEmmanuel Vadot xo_close_container("nfsv41"); 1021*309c8f76SRick Macklem 1022*309c8f76SRick Macklem xo_open_container("nfsv42"); 1023*309c8f76SRick Macklem 1024*309c8f76SRick Macklem xo_emit("{T:Allocate/%13.13s}{T:Copy/%13.13s}" 1025*309c8f76SRick Macklem "{T:CopyNotify/%13.13s}{T:Deallocate/%13.13s}" 1026*309c8f76SRick Macklem "{T:IOAdvise/%13.13s}{T:LayoutError/%13.13s}\n"); 1027*309c8f76SRick Macklem xo_emit("{:allocate/%13ju}{:copy/%13ju}" 1028*309c8f76SRick Macklem "{:copynotify/%13ju}{:deallocate/%13ju}" 1029*309c8f76SRick Macklem "{:ioadvise/%13ju}{:layouterror/%13ju}\n", 1030*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_ALLOCATE], 1031*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_COPY], 1032*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_COPYNOTIFY], 1033*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_DEALLOCATE], 1034*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_IOADVISE], 1035*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LAYOUTERROR]); 1036*309c8f76SRick Macklem 1037*309c8f76SRick Macklem xo_emit("{T:LayoutStats/%13.13s}{T:OffloadCncl/%13.13s}" 1038*309c8f76SRick Macklem "{T:OffloadStat/%13.13s}{T:ReadPlus/%13.13s}" 1039*309c8f76SRick Macklem "{T:Seek/%13.13s}{T:WriteSame/%13.13s}\n"); 1040*309c8f76SRick Macklem xo_emit("{:layoutstats/%13ju}{:offloadcncl/%13ju}" 1041*309c8f76SRick Macklem "{:offloadstat/%13ju}{:readplus/%13ju}" 1042*309c8f76SRick Macklem "{:seek/%13ju}{:writesame/%13ju}\n", 1043*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LAYOUTSTATS], 1044*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OFFLOADCANCEL], 1045*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_OFFLOADSTATUS], 1046*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_READPLUS], 1047*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SEEK], 1048*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_WRITESAME]); 1049*309c8f76SRick Macklem 1050*309c8f76SRick Macklem xo_emit("{T:Clone/%13.13s}{T:GetExtattr/%13.13s}" 1051*309c8f76SRick Macklem "{T:SetExtattr/%13.13s}{T:ListExtattr/%13.13s}" 1052*309c8f76SRick Macklem "{T:RmExtattr/%13.13s}\n"); 1053*309c8f76SRick Macklem xo_emit("{:clone/%13ju}{:getextattr/%13ju}" 1054*309c8f76SRick Macklem "{:setextattr/%13ju}{:listextattr/%13ju}" 1055*309c8f76SRick Macklem "{:rmextattr/%13ju}\n", 1056*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_CLONE], 1057*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_GETXATTR], 1058*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_SETXATTR], 1059*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_LISTXATTRS], 1060*309c8f76SRick Macklem (uintmax_t)ext_nfsstats.srvrpccnt[NFSV4OP_REMOVEXATTR]); 1061*309c8f76SRick Macklem 1062*309c8f76SRick Macklem xo_close_container("nfsv42"); 10630744a2b0SRick Macklem } 10642145d321SEmmanuel Vadot 10652145d321SEmmanuel Vadot xo_close_container("operations"); 10662145d321SEmmanuel Vadot 10672145d321SEmmanuel Vadot if (printtitle) 10682145d321SEmmanuel Vadot xo_emit("{T:Server:}\n"); 10692145d321SEmmanuel Vadot xo_open_container("server"); 10702145d321SEmmanuel Vadot xo_emit("{T:Retfailed/%13.13s}{T:Faults/%13.13s}" 10712145d321SEmmanuel Vadot "{T:Clients/%13.13s}\n"); 10722145d321SEmmanuel Vadot xo_emit("{:retfailed/%13ju}{:faults/%13ju}{:clients/%13ju}\n", 10730744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srv_errs, 10740744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvrpc_errs, 10750744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvclients); 10762145d321SEmmanuel Vadot xo_emit("{T:OpenOwner/%13.13s}{T:Opens/%13.13s}" 10772145d321SEmmanuel Vadot "{T:LockOwner/%13.13s}{T:Locks/%13.13s}" 10782145d321SEmmanuel Vadot "{T:Delegs/%13.13s}\n"); 10792145d321SEmmanuel Vadot xo_emit("{:openowner/%13ju}{:opens/%13ju}{:lockowner/%13ju}" 10802145d321SEmmanuel Vadot "{:locks/%13ju}{:delegs/%13ju}\n", 10810744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvopenowners, 10820744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvopens, 10830744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvlockowners, 10840744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvlocks, 10850744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvdelegates); 10862145d321SEmmanuel Vadot xo_close_container("server"); 10872145d321SEmmanuel Vadot 10882145d321SEmmanuel Vadot if (printtitle) 10892145d321SEmmanuel Vadot xo_emit("{T:Server Cache Stats:}\n"); 10902145d321SEmmanuel Vadot xo_open_container("cache"); 10912145d321SEmmanuel Vadot xo_emit("{T:Inprog/%13.13s}{T:Idem/%13.13s}" 10922145d321SEmmanuel Vadot "{T:Non-idem/%13.13s}{T:Misses/%13.13s}" 10932145d321SEmmanuel Vadot "{T:CacheSize/%13.13s}{T:TCPPeak/%13.13s}\n"); 10942145d321SEmmanuel Vadot xo_emit("{:inprog/%13ju}{:idem/%13ju}{:nonidem/%13ju}" 10952145d321SEmmanuel Vadot "{:misses/%13ju}{:cachesize/%13ju}{:tcppeak/%13ju}\n", 10960744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_inproghits, 10970744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_idemdonehits, 10980744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_nonidemdonehits, 10990744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_misses, 11000744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_size, 11010744a2b0SRick Macklem (uintmax_t)ext_nfsstats.srvcache_tcppeak); 11022145d321SEmmanuel Vadot xo_close_container("cache"); 11032145d321SEmmanuel Vadot 11042145d321SEmmanuel Vadot xo_close_container("serverstats"); 11050744a2b0SRick Macklem } 11062145d321SEmmanuel Vadot 11072145d321SEmmanuel Vadot xo_close_container("nfsv4"); 11080744a2b0SRick Macklem } 11090744a2b0SRick Macklem 1110693957f8SRick Macklem static void 1111693957f8SRick Macklem compute_totals(struct nfsstatsv1 *total_stats, struct nfsstatsv1 *cur_stats) 1112693957f8SRick Macklem { 1113693957f8SRick Macklem int i; 1114693957f8SRick Macklem 1115693957f8SRick Macklem bzero(total_stats, sizeof(*total_stats)); 1116693957f8SRick Macklem for (i = 0; i < (NFSV42_NOPS + NFSV4OP_FAKENOPS); i++) { 1117693957f8SRick Macklem total_stats->srvbytes[0] += cur_stats->srvbytes[i]; 1118693957f8SRick Macklem total_stats->srvops[0] += cur_stats->srvops[i]; 1119693957f8SRick Macklem bintime_add(&total_stats->srvduration[0], 1120693957f8SRick Macklem &cur_stats->srvduration[i]); 1121693957f8SRick Macklem total_stats->srvrpccnt[i] = cur_stats->srvrpccnt[i]; 1122693957f8SRick Macklem } 1123693957f8SRick Macklem total_stats->srvstartcnt = cur_stats->srvstartcnt; 1124693957f8SRick Macklem total_stats->srvdonecnt = cur_stats->srvdonecnt; 1125693957f8SRick Macklem total_stats->busytime = cur_stats->busytime; 1126693957f8SRick Macklem 1127693957f8SRick Macklem } 1128693957f8SRick Macklem 1129bcdaa850SRick Macklem /* 1130bcdaa850SRick Macklem * Print a running summary of nfs statistics for the experimental client and/or 1131bcdaa850SRick Macklem * server. 1132bcdaa850SRick Macklem * Repeat display every interval seconds, showing statistics 1133bcdaa850SRick Macklem * collected over that interval. Assumes that interval is non-zero. 1134bcdaa850SRick Macklem * First line printed at top of screen is always cumulative. 1135bcdaa850SRick Macklem */ 1136722e2552SEdward Tomasz Napierala static void 1137693957f8SRick Macklem exp_sidewaysintpr(u_int interval, int clientOnly, int serverOnly, 1138693957f8SRick Macklem int newStats) 1139bcdaa850SRick Macklem { 1140693957f8SRick Macklem struct nfsstatsv1 nfsstats, lastst, *ext_nfsstatsp; 1141693957f8SRick Macklem struct nfsstatsv1 curtotal, lasttotal; 1142693957f8SRick Macklem struct timespec ts, lastts; 1143bcdaa850SRick Macklem int hdrcnt = 1; 1144bcdaa850SRick Macklem 1145bcdaa850SRick Macklem ext_nfsstatsp = &lastst; 1146693957f8SRick Macklem ext_nfsstatsp->vers = NFSSTATS_V1; 1147693957f8SRick Macklem if (nfssvc(NFSSVC_GETSTATS | NFSSVC_NEWSTRUCT, ext_nfsstatsp) < 0) 1148bcdaa850SRick Macklem err(1, "Can't get stats"); 1149693957f8SRick Macklem clock_gettime(CLOCK_MONOTONIC, &lastts); 1150693957f8SRick Macklem compute_totals(&lasttotal, ext_nfsstatsp); 1151bcdaa850SRick Macklem sleep(interval); 1152bcdaa850SRick Macklem 1153bcdaa850SRick Macklem for (;;) { 1154bcdaa850SRick Macklem ext_nfsstatsp = &nfsstats; 1155693957f8SRick Macklem ext_nfsstatsp->vers = NFSSTATS_V1; 1156693957f8SRick Macklem if (nfssvc(NFSSVC_GETSTATS | NFSSVC_NEWSTRUCT, ext_nfsstatsp) 1157693957f8SRick Macklem < 0) 1158bcdaa850SRick Macklem err(1, "Can't get stats"); 1159693957f8SRick Macklem clock_gettime(CLOCK_MONOTONIC, &ts); 1160bcdaa850SRick Macklem 1161bcdaa850SRick Macklem if (--hdrcnt == 0) { 1162693957f8SRick Macklem printhdr(clientOnly, serverOnly, newStats); 1163693957f8SRick Macklem if (newStats) 1164693957f8SRick Macklem hdrcnt = 20; 1165693957f8SRick Macklem else if (clientOnly && serverOnly) 1166bcdaa850SRick Macklem hdrcnt = 10; 1167bcdaa850SRick Macklem else 1168bcdaa850SRick Macklem hdrcnt = 20; 1169bcdaa850SRick Macklem } 1170693957f8SRick Macklem if (clientOnly && newStats == 0) { 1171693957f8SRick Macklem printf("%s %6ju %6ju %6ju %6ju %6ju %6ju %6ju %6ju", 1172bcdaa850SRick Macklem ((clientOnly && serverOnly) ? "Client:" : ""), 1173693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_GETATTR]), 1174693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_LOOKUP]), 1175693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_READLINK]), 1176693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_READ]), 1177693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_WRITE]), 1178693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_RENAME]), 1179693957f8SRick Macklem (uintmax_t)DELTA(rpccnt[NFSPROC_ACCESS]), 1180693957f8SRick Macklem (uintmax_t)(DELTA(rpccnt[NFSPROC_READDIR]) + 1181693957f8SRick Macklem DELTA(rpccnt[NFSPROC_READDIRPLUS])) 1182bcdaa850SRick Macklem ); 1183bcdaa850SRick Macklem if (widemode) { 1184bcdaa850SRick Macklem printf(" %s %s %s %s %s %s", 1185bcdaa850SRick Macklem sperc1(DELTA(attrcache_hits), 1186bcdaa850SRick Macklem DELTA(attrcache_misses)), 1187bcdaa850SRick Macklem sperc1(DELTA(lookupcache_hits), 1188bcdaa850SRick Macklem DELTA(lookupcache_misses)), 1189bcdaa850SRick Macklem sperc2(DELTA(biocache_reads), 1190bcdaa850SRick Macklem DELTA(read_bios)), 1191bcdaa850SRick Macklem sperc2(DELTA(biocache_writes), 1192bcdaa850SRick Macklem DELTA(write_bios)), 1193bcdaa850SRick Macklem sperc1(DELTA(accesscache_hits), 1194bcdaa850SRick Macklem DELTA(accesscache_misses)), 1195bcdaa850SRick Macklem sperc2(DELTA(biocache_readdirs), 1196bcdaa850SRick Macklem DELTA(readdir_bios)) 1197bcdaa850SRick Macklem ); 1198bcdaa850SRick Macklem } 1199bcdaa850SRick Macklem printf("\n"); 1200bcdaa850SRick Macklem } 1201693957f8SRick Macklem 1202693957f8SRick Macklem if (serverOnly && newStats) { 1203693957f8SRick Macklem long double cur_secs, last_secs, etime; 1204693957f8SRick Macklem long double mbsec; 1205693957f8SRick Macklem long double kb_per_transfer; 1206693957f8SRick Macklem long double transfers_per_second; 1207693957f8SRick Macklem long double ms_per_transfer; 1208693957f8SRick Macklem uint64_t queue_len; 1209693957f8SRick Macklem long double busy_pct; 1210693957f8SRick Macklem int i; 1211693957f8SRick Macklem 1212693957f8SRick Macklem cur_secs = ts.tv_sec + 1213693957f8SRick Macklem ((long double)ts.tv_nsec / 1000000000); 1214693957f8SRick Macklem last_secs = lastts.tv_sec + 1215693957f8SRick Macklem ((long double)lastts.tv_nsec / 1000000000); 1216693957f8SRick Macklem etime = cur_secs - last_secs; 1217693957f8SRick Macklem 1218693957f8SRick Macklem compute_totals(&curtotal, &nfsstats); 1219693957f8SRick Macklem 1220693957f8SRick Macklem for (i = 0; i < NUM_STAT_TYPES; i++) { 1221693957f8SRick Macklem compute_new_stats(&nfsstats, &lastst, 1222693957f8SRick Macklem STAT_TYPE_TO_NFS(i), etime, &mbsec, 1223693957f8SRick Macklem &kb_per_transfer, 1224693957f8SRick Macklem &transfers_per_second, 1225693957f8SRick Macklem &ms_per_transfer, &queue_len, 1226693957f8SRick Macklem &busy_pct); 1227693957f8SRick Macklem 1228693957f8SRick Macklem if (i == STAT_TYPE_COMMIT) { 1229693957f8SRick Macklem if (widemode == 0) 1230693957f8SRick Macklem continue; 1231693957f8SRick Macklem 1232693957f8SRick Macklem printf("%2.0Lf %7.2Lf ", 1233693957f8SRick Macklem transfers_per_second, 1234693957f8SRick Macklem ms_per_transfer); 1235693957f8SRick Macklem } else { 1236693957f8SRick Macklem printf("%5.2Lf %5.0Lf %7.2Lf ", 1237693957f8SRick Macklem kb_per_transfer, 1238693957f8SRick Macklem transfers_per_second, mbsec); 1239693957f8SRick Macklem if (widemode) 1240693957f8SRick Macklem printf("%5.2Lf ", 1241693957f8SRick Macklem ms_per_transfer); 1242693957f8SRick Macklem } 1243693957f8SRick Macklem } 1244693957f8SRick Macklem 1245693957f8SRick Macklem compute_new_stats(&curtotal, &lasttotal, 0, etime, 1246693957f8SRick Macklem &mbsec, &kb_per_transfer, &transfers_per_second, 1247693957f8SRick Macklem &ms_per_transfer, &queue_len, &busy_pct); 1248693957f8SRick Macklem 1249693957f8SRick Macklem printf("%5.2Lf %5.0Lf %7.2Lf %5.2Lf %3ju %3.0Lf\n", 1250693957f8SRick Macklem kb_per_transfer, transfers_per_second, mbsec, 1251693957f8SRick Macklem ms_per_transfer, queue_len, busy_pct); 1252693957f8SRick Macklem } else if (serverOnly) { 1253693957f8SRick Macklem printf("%s %6ju %6ju %6ju %6ju %6ju %6ju %6ju %6ju", 1254bcdaa850SRick Macklem ((clientOnly && serverOnly) ? "Server:" : ""), 1255693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_GETATTR]), 1256693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_LOOKUP]), 1257693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_READLINK]), 1258693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_READ]), 1259693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_WRITE]), 1260693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_RENAME]), 1261693957f8SRick Macklem (uintmax_t)DELTA(srvrpccnt[NFSV4OP_ACCESS]), 1262693957f8SRick Macklem (uintmax_t)(DELTA(srvrpccnt[NFSV4OP_READDIR]) + 1263693957f8SRick Macklem DELTA(srvrpccnt[NFSV4OP_READDIRPLUS]))); 1264bcdaa850SRick Macklem printf("\n"); 1265bcdaa850SRick Macklem } 1266693957f8SRick Macklem bcopy(&nfsstats, &lastst, sizeof(lastst)); 1267693957f8SRick Macklem bcopy(&curtotal, &lasttotal, sizeof(lasttotal)); 1268693957f8SRick Macklem lastts = ts; 1269bcdaa850SRick Macklem fflush(stdout); 1270bcdaa850SRick Macklem sleep(interval); 1271bcdaa850SRick Macklem } 1272bcdaa850SRick Macklem /*NOTREACHED*/ 1273bcdaa850SRick Macklem } 1274