]>
git.saurik.com Git - apple/network_cmds.git/blob - nfsstat.tproj/nfsstat.c
   2  * Copyright (c) 1999 Apple Computer, Inc. All rights reserved. 
   4  * @APPLE_LICENSE_HEADER_START@ 
   6  * "Portions Copyright (c) 1999 Apple Computer, Inc.  All Rights 
   7  * Reserved.  This file contains Original Code and/or Modifications of 
   8  * Original Code as defined in and that are subject to the Apple Public 
   9  * Source License Version 1.0 (the 'License').  You may not use this file 
  10  * except in compliance with the License.  Please obtain a copy of the 
  11  * License at http://www.apple.com/publicsource and read it before using 
  14  * The Original Code and all software distributed under the License are 
  15  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  16  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  17  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 
  18  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the 
  19  * License for the specific language governing rights and limitations 
  22  * @APPLE_LICENSE_HEADER_END@ 
  25  * Copyright (c) 1997 Apple Computer, Inc. All Rights Reserved 
  27  * Copyright (c) 1983, 1989, 1993 
  28  *      The Regents of the University of California.  All rights reserved. 
  30  * This code is derived from software contributed to Berkeley by 
  31  * Rick Macklem at The University of Guelph. 
  33  * Redistribution and use in source and binary forms, with or without 
  34  * modification, are permitted provided that the following conditions 
  36  * 1. Redistributions of source code must retain the above copyright 
  37  *    notice, this list of conditions and the following disclaimer. 
  38  * 2. Redistributions in binary form must reproduce the above copyright 
  39  *    notice, this list of conditions and the following disclaimer in the 
  40  *    documentation and/or other materials provided with the distribution. 
  41  * 3. All advertising materials mentioning features or use of this software 
  42  *    must display the following acknowledgement: 
  43  *      This product includes software developed by the University of 
  44  *      California, Berkeley and its contributors. 
  45  * 4. Neither the name of the University nor the names of its contributors 
  46  *    may be used to endorse or promote products derived from this software 
  47  *    without specific prior written permission. 
  49  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 
  50  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
  51  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 
  52  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 
  53  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 
  54  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 
  55  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 
  56  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
  57  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 
  58  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 
  60  *      @(#)nfsstat.c   8.2 (Berkeley) 3/31/95 
  64 #include <sys/param.h> 
  65 #include <sys/mount.h> 
  66 #include <sys/sysctl.h> 
  67 #include <nfs/rpcv2.h> 
  68 #include <nfs/nfsproto.h> 
  83 #define SHOW_SERVER 0x01 
  84 #define SHOW_CLIENT 0x02 
  85 #define SHOW_ALL (SHOW_SERVER | SHOW_CLIENT) 
  94 static int deadkernel 
= 0; 
  96 void intpr 
__P((u_long
, u_int
)); 
  97 void printhdr 
__P((void)); 
  98 void sidewaysintpr 
__P((u_int
, u_long
, u_int
)); 
  99 void usage 
__P((void)); 
 109         u_int display 
= SHOW_ALL
; 
 115         memf 
= nlistf 
= NULL
; 
 116         while ((ch 
= getopt(argc
, argv
, "M:N:w:sc")) != EOF
) 
 125                         interval 
= atoi(optarg
); 
 128                         display 
= SHOW_SERVER
; 
 131                         display 
= SHOW_CLIENT
; 
 140 #define BACKWARD_COMPATIBILITY 
 141 #ifdef  BACKWARD_COMPATIBILITY 
 143                 interval 
= atoi(*argv
); 
 152          * Discard setgid privileges if not the running kernel so that bad 
 153          * guys can't print interesting stuff from kernel memory. 
 155         if (nlistf 
!= NULL 
|| memf 
!= NULL
) { 
 160                 if ((kd 
= kvm_openfiles(nlistf
, memf
, NULL
, O_RDONLY
, 
 162                         errx(1, "kvm_openfiles: %s", errbuf
); 
 164                 if (kvm_nlist(kd
, nl
) != 0) { 
 165                         errx(1, "kvm_nlist: can't get names"); 
 170                 sidewaysintpr(interval
, nl
[N_NFSSTAT
].n_value
, display
); 
 172                 intpr(nl
[N_NFSSTAT
].n_value
, display
); 
 177  * Read the nfs stats using sysctl(3) for live kernels, or kvm_read 
 182         struct nfsstats 
*stp
; 
 185                 if(kvm_read(kd
, (u_long
)nl
[N_NFSSTAT
].n_value
, stp
, 
 191                 size_t buflen 
= sizeof *stp
; 
 194                 if (getvfsbyname("nfs", &vfc
) < 0) 
 195                         err(1, "getvfsbyname: NFS not compiled into kernel"); 
 197                 name
[1] = vfc
.vfc_typenum
; 
 198                 name
[2] = NFS_NFSSTATS
; 
 199                 if (sysctl(name
, 3, stp
, &buflen
, (void *)0, (size_t)0) < 0) { 
 206  * Print a description of the nfs stats. 
 209 intpr(nfsstataddr
, display
) 
 213         struct nfsstats nfsstats
; 
 215         readstats(&nfsstats
); 
 217         if (display 
& SHOW_CLIENT
) { 
 218                 printf("Client Info:\n"); 
 219                 printf("Rpc Counts:\n"); 
 220                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 221                        "Getattr", "Setattr", "Lookup", "Readlink", "Read", 
 222                        "Write", "Create", "Remove"); 
 223                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 224                        nfsstats
.rpccnt
[NFSPROC_GETATTR
], 
 225                        nfsstats
.rpccnt
[NFSPROC_SETATTR
], 
 226                        nfsstats
.rpccnt
[NFSPROC_LOOKUP
], 
 227                        nfsstats
.rpccnt
[NFSPROC_READLINK
], 
 228                        nfsstats
.rpccnt
[NFSPROC_READ
], 
 229                        nfsstats
.rpccnt
[NFSPROC_WRITE
], 
 230                        nfsstats
.rpccnt
[NFSPROC_CREATE
], 
 231                        nfsstats
.rpccnt
[NFSPROC_REMOVE
]); 
 232                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 233                        "Rename", "Link", "Symlink", "Mkdir", "Rmdir", 
 234                        "Readdir", "RdirPlus", "Access"); 
 235                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 236                        nfsstats
.rpccnt
[NFSPROC_RENAME
], 
 237                        nfsstats
.rpccnt
[NFSPROC_LINK
], 
 238                        nfsstats
.rpccnt
[NFSPROC_SYMLINK
], 
 239                        nfsstats
.rpccnt
[NFSPROC_MKDIR
], 
 240                        nfsstats
.rpccnt
[NFSPROC_RMDIR
], 
 241                        nfsstats
.rpccnt
[NFSPROC_READDIR
], 
 242                        nfsstats
.rpccnt
[NFSPROC_READDIRPLUS
], 
 243                        nfsstats
.rpccnt
[NFSPROC_ACCESS
]); 
 244                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 245                        "Mknod", "Fsstat", "Fsinfo", "PathConf", "Commit", 
 246                        "GLease", "Vacate", "Evict"); 
 247                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 248                        nfsstats
.rpccnt
[NFSPROC_MKNOD
], 
 249                        nfsstats
.rpccnt
[NFSPROC_FSSTAT
], 
 250                        nfsstats
.rpccnt
[NFSPROC_FSINFO
], 
 251                        nfsstats
.rpccnt
[NFSPROC_PATHCONF
], 
 252                        nfsstats
.rpccnt
[NFSPROC_COMMIT
], 
 253                        nfsstats
.rpccnt
[NQNFSPROC_GETLEASE
], 
 254                        nfsstats
.rpccnt
[NQNFSPROC_VACATED
], 
 255                        nfsstats
.rpccnt
[NQNFSPROC_EVICTED
]); 
 256                 printf("Rpc Info:\n"); 
 257                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 258                        "TimedOut", "Invalid", "X Replies", "Retries", "Requests"); 
 259                 printf("%9d %9d %9d %9d %9d\n", 
 260                        nfsstats
.rpctimeouts
, 
 262                        nfsstats
.rpcunexpected
, 
 264                        nfsstats
.rpcrequests
); 
 265                 printf("Cache Info:\n"); 
 266                 printf("%9.9s %9.9s %9.9s %9.9s", 
 267                        "Attr Hits", "Misses", "Lkup Hits", "Misses"); 
 268                 printf(" %9.9s %9.9s %9.9s %9.9s\n", 
 269                        "BioR Hits", "Misses", "BioW Hits", "Misses"); 
 270                 printf("%9d %9d %9d %9d", 
 271                        nfsstats
.attrcache_hits
, nfsstats
.attrcache_misses
, 
 272                        nfsstats
.lookupcache_hits
, nfsstats
.lookupcache_misses
); 
 273                 printf(" %9d %9d %9d %9d\n", 
 274                        nfsstats
.biocache_reads
-nfsstats
.read_bios
, 
 276                        nfsstats
.biocache_writes
-nfsstats
.write_bios
, 
 277                        nfsstats
.write_bios
); 
 278                 printf("%9.9s %9.9s %9.9s %9.9s", 
 279                        "BioRLHits", "Misses", "BioD Hits", "Misses"); 
 280                 printf(" %9.9s %9.9s\n", "DirE Hits", "Misses"); 
 281                 printf("%9d %9d %9d %9d", 
 282                        nfsstats
.biocache_readlinks
-nfsstats
.readlink_bios
, 
 283                        nfsstats
.readlink_bios
, 
 284                        nfsstats
.biocache_readdirs
-nfsstats
.readdir_bios
, 
 285                        nfsstats
.readdir_bios
); 
 287                        nfsstats
.direofcache_hits
, nfsstats
.direofcache_misses
); 
 289         if (display 
& SHOW_SERVER
) { 
 290                 printf("\nServer Info:\n"); 
 291                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 292                        "Getattr", "Setattr", "Lookup", "Readlink", "Read", 
 293                        "Write", "Create", "Remove"); 
 294                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 295                        nfsstats
.srvrpccnt
[NFSPROC_GETATTR
], 
 296                        nfsstats
.srvrpccnt
[NFSPROC_SETATTR
], 
 297                        nfsstats
.srvrpccnt
[NFSPROC_LOOKUP
], 
 298                        nfsstats
.srvrpccnt
[NFSPROC_READLINK
], 
 299                        nfsstats
.srvrpccnt
[NFSPROC_READ
], 
 300                        nfsstats
.srvrpccnt
[NFSPROC_WRITE
], 
 301                        nfsstats
.srvrpccnt
[NFSPROC_CREATE
], 
 302                        nfsstats
.srvrpccnt
[NFSPROC_REMOVE
]); 
 303                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 304                        "Rename", "Link", "Symlink", "Mkdir", "Rmdir", 
 305                        "Readdir", "RdirPlus", "Access"); 
 306                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 307                        nfsstats
.srvrpccnt
[NFSPROC_RENAME
], 
 308                        nfsstats
.srvrpccnt
[NFSPROC_LINK
], 
 309                        nfsstats
.srvrpccnt
[NFSPROC_SYMLINK
], 
 310                        nfsstats
.srvrpccnt
[NFSPROC_MKDIR
], 
 311                        nfsstats
.srvrpccnt
[NFSPROC_RMDIR
], 
 312                        nfsstats
.srvrpccnt
[NFSPROC_READDIR
], 
 313                        nfsstats
.srvrpccnt
[NFSPROC_READDIRPLUS
], 
 314                        nfsstats
.srvrpccnt
[NFSPROC_ACCESS
]); 
 315                 printf("%9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s %9.9s\n", 
 316                        "Mknod", "Fsstat", "Fsinfo", "PathConf", "Commit", 
 317                        "GLease", "Vacate", "Evict"); 
 318                 printf("%9d %9d %9d %9d %9d %9d %9d %9d\n", 
 319                        nfsstats
.srvrpccnt
[NFSPROC_MKNOD
], 
 320                        nfsstats
.srvrpccnt
[NFSPROC_FSSTAT
], 
 321                        nfsstats
.srvrpccnt
[NFSPROC_FSINFO
], 
 322                        nfsstats
.srvrpccnt
[NFSPROC_PATHCONF
], 
 323                        nfsstats
.srvrpccnt
[NFSPROC_COMMIT
], 
 324                        nfsstats
.srvrpccnt
[NQNFSPROC_GETLEASE
], 
 325                        nfsstats
.srvrpccnt
[NQNFSPROC_VACATED
], 
 326                        nfsstats
.srvrpccnt
[NQNFSPROC_EVICTED
]); 
 327                 printf("Server Ret-Failed\n"); 
 328                 printf("%17d\n", nfsstats
.srvrpc_errs
); 
 329                 printf("Server Faults\n"); 
 330                 printf("%13d\n", nfsstats
.srv_errs
); 
 331                 printf("Server Cache Stats:\n"); 
 332                 printf("%9.9s %9.9s %9.9s %9.9s\n", 
 333                        "Inprog", "Idem", "Non-idem", "Misses"); 
 334                 printf("%9d %9d %9d %9d\n", 
 335                        nfsstats
.srvcache_inproghits
, 
 336                        nfsstats
.srvcache_idemdonehits
, 
 337                        nfsstats
.srvcache_nonidemdonehits
, 
 338                        nfsstats
.srvcache_misses
); 
 339                 printf("Server Lease Stats:\n"); 
 340                 printf("%9.9s %9.9s %9.9s\n", 
 341                        "Leases", "PeakL", "GLeases"); 
 342                 printf("%9d %9d %9d\n", 
 343                        nfsstats
.srvnqnfs_leases
, 
 344                        nfsstats
.srvnqnfs_maxleases
, 
 345                        nfsstats
.srvnqnfs_getleases
); 
 346                 printf("Server Write Gathering:\n"); 
 347                 printf("%9.9s %9.9s %9.9s\n", 
 348                        "WriteOps", "WriteRPC", "Opsaved"); 
 349                 printf("%9d %9d %9d\n", 
 350                        nfsstats
.srvvop_writes
, 
 351                        nfsstats
.srvrpccnt
[NFSPROC_WRITE
], 
 352                        nfsstats
.srvrpccnt
[NFSPROC_WRITE
] - nfsstats
.srvvop_writes
); 
 356 u_char  signalled
;                      /* set if alarm goes off "early" */ 
 359  * Print a running summary of nfs statistics. 
 360  * Repeat display every interval seconds, showing statistics 
 361  * collected over that interval.  Assumes that interval is non-zero. 
 362  * First line printed at top of screen is always cumulative. 
 365 sidewaysintpr(interval
, off
, display
) 
 370         struct nfsstats nfsstats
, lastst
; 
 374         (void)signal(SIGALRM
, catchalarm
); 
 376         (void)alarm(interval
); 
 377         bzero((caddr_t
)&lastst
, sizeof(lastst
)); 
 384                 readstats(&nfsstats
); 
 385                 if (display 
& SHOW_CLIENT
) 
 386                   printf("Client: %8d %8d %8d %8d %8d %8d %8d %8d\n", 
 387                     nfsstats
.rpccnt
[NFSPROC_GETATTR
]-lastst
.rpccnt
[NFSPROC_GETATTR
], 
 388                     nfsstats
.rpccnt
[NFSPROC_LOOKUP
]-lastst
.rpccnt
[NFSPROC_LOOKUP
], 
 389                     nfsstats
.rpccnt
[NFSPROC_READLINK
]-lastst
.rpccnt
[NFSPROC_READLINK
], 
 390                     nfsstats
.rpccnt
[NFSPROC_READ
]-lastst
.rpccnt
[NFSPROC_READ
], 
 391                     nfsstats
.rpccnt
[NFSPROC_WRITE
]-lastst
.rpccnt
[NFSPROC_WRITE
], 
 392                     nfsstats
.rpccnt
[NFSPROC_RENAME
]-lastst
.rpccnt
[NFSPROC_RENAME
], 
 393                     nfsstats
.rpccnt
[NFSPROC_ACCESS
]-lastst
.rpccnt
[NFSPROC_ACCESS
], 
 394                     (nfsstats
.rpccnt
[NFSPROC_READDIR
]-lastst
.rpccnt
[NFSPROC_READDIR
]) 
 395                     +(nfsstats
.rpccnt
[NFSPROC_READDIRPLUS
]-lastst
.rpccnt
[NFSPROC_READDIRPLUS
])); 
 396                 if (display 
& SHOW_SERVER
) 
 397                   printf("Server: %8d %8d %8d %8d %8d %8d %8d %8d\n", 
 398                     nfsstats
.srvrpccnt
[NFSPROC_GETATTR
]-lastst
.srvrpccnt
[NFSPROC_GETATTR
], 
 399                     nfsstats
.srvrpccnt
[NFSPROC_LOOKUP
]-lastst
.srvrpccnt
[NFSPROC_LOOKUP
], 
 400                     nfsstats
.srvrpccnt
[NFSPROC_READLINK
]-lastst
.srvrpccnt
[NFSPROC_READLINK
], 
 401                     nfsstats
.srvrpccnt
[NFSPROC_READ
]-lastst
.srvrpccnt
[NFSPROC_READ
], 
 402                     nfsstats
.srvrpccnt
[NFSPROC_WRITE
]-lastst
.srvrpccnt
[NFSPROC_WRITE
], 
 403                     nfsstats
.srvrpccnt
[NFSPROC_RENAME
]-lastst
.srvrpccnt
[NFSPROC_RENAME
], 
 404                     nfsstats
.srvrpccnt
[NFSPROC_ACCESS
]-lastst
.srvrpccnt
[NFSPROC_ACCESS
], 
 405                     (nfsstats
.srvrpccnt
[NFSPROC_READDIR
]-lastst
.srvrpccnt
[NFSPROC_READDIR
]) 
 406                     +(nfsstats
.srvrpccnt
[NFSPROC_READDIRPLUS
]-lastst
.srvrpccnt
[NFSPROC_READDIRPLUS
])); 
 409                 oldmask 
= sigblock(sigmask(SIGALRM
)); 
 414                 (void)alarm(interval
); 
 422         printf("        %8.8s %8.8s %8.8s %8.8s %8.8s %8.8s %8.8s %8.8s\n", 
 423             "Getattr", "Lookup", "Readlink", "Read", "Write", "Rename", 
 424             "Access", "Readdir"); 
 429  * Called if an interval expires before sidewaysintpr has completed a loop. 
 430  * Sets a flag to not wait for the alarm. 
 441         (void)fprintf(stderr
, 
 442             "usage: nfsstat [-cs] [-M core] [-N system] [-w interval]\n");