Go to main content

man pages section 1: User Commands

Exit Print View

Updated: July 2017
 
 

zonestat(1)

Name

zonestat - report active zone statistics

Synopsis

zonestat [-z zonelist] [-r reslist] [-n namelist] [-T u | d | i] 
   [-R reports] [-q] [-x] [-p [-P lines]] 
   [-S cols] interval [duration [report]]

Description

The zonestat utility reports on the cpu, memory, networking, and resource control utilization of the currently running zones. Each zone's utilization is reported both as a percentage of system resources and the zone's configured limits.

The zonestat utility prints a series of interval reports at the specified interval. It optionally also prints one or more summary reports at a specified interval.

The default output is a summary of cpu, physical, and virtual memory, and networking utilization. The –r option can be used to choose detailed output for specific resources.

Security

When run from within a non-global zone (NGZ), only processor sets visible to the NGZ are reported. The NGZ output includes all of other system resources, such as memory and limits.

For all reported resources, the NGZ's usage is output. Usage of each resource by the system, global zone, and all other zones, is reported as used by [system].

Inside a solaris-kz brand zone, only that zone's usage is visible.

For networking resources, only NGZ's usage is output. NGZs do not have visibility to other zones' networking resources and statistics.

proc_info privilege is required to use the zonestat utility. This privilege is a member of the basic privilege set.

Options

The following options are supported:

–n name[,name]

Specify a list resource names on which to report. For pset resources, this is the name of the processor set. For physical-memory, locked-memory, and virtual-memory resources, the only names are mem_default and vm_default. For network resources, this is name of a datalink.

Dedicated-cpu processor sets can be specified by their pset name (SUNWtmp_zonename or by just their zonename.

Processor sets created by psrset can be specified by their pool pset name (SUNWlegacy_pset id), or just by their pset id.

In addition to a comma-separated list, multiple –n options can be specified to report on a set of resources.

–p

Parseable output.

Print output in stable, machine--parseable format. Individual fields are delimited with a colon (:). The line format is:

report type:resource:field[:field]*

If -T is specified each line is prefixed with a timestamp:

The report types are: report-total, report-average, report-high, and interval,

The resource types are: header, footer, summary, physical-memory, virtual-memory, locked-memory, processor-set, processes, lwps, sysv-shared-memory, sysv-shmids, sysv-semids, sysv-msgids, lofi , network.

The header resource is a special resource used to state the beginning of an interval or summary report. All output lines between header resources belong to the same report. Each header has a matching footer.

The remaining fields are resource type specific. See the zonestat utility output for details.

All existing output fields are stable. Future versions might introduce new report and resource types. Future versions might also add additional new fields to the end of existing output n lines.

Running in a global zone, the statistics provided for solaris-kz brand zones are from the host point of view, and may differ within the zone; see solaris-kz(5).

–P line[,line]

For parseable output, specify lines to output in parseable output. One or more of the following line types can be chosen:

header

For each interval, and summary report has a header, which prints details such as the interval and count information. After each report, and footer is also printed

resource

The lines describing each resource.

system

The utilization of each resource by the system. This includes the kernel, and any resource consumption not contributed to a specific zone. When zonestat is run from within a non-global-zone, this value is the aggregate resource consumed by the system and all other zones. system utilization for network resource type is not supported.

total

The total utilization of each resource.

zones

Lines detailing the per-zone utilization of each resource.

–q

Quiet mode. Only print summary reports (requires the –R option). All interval reports are omitted.

–r resource[,resource]

Specify resource types on which to report. The available resources are: physical-memory, virtual-memory, locked-memory, processor-set, processes, lwps, shm-memory , shm-ids, sem-ids, msg-ids, lofi, and network.

summary

A summary of cpu, physical-memory, virtual memory, and network usage.

memory

physical-memory, virtual-memory, and locked-memory.

psets

processor-set

default-pset

The default pset only.

limits

processes, lwps, lofi.

network

network datalinks.

sysv

shm-memory, shm-ids, sem-ids msg-ids.

all

All resource types.

By default the summary resource is printed.

In addition to a comma-separated list, multiple -r options can be specified to report on a set of resources types.

The system's cpus can be partitioned into processor sets (psets). By default, all cpus are in a single pset named pset_default.

Memory is not partition-able into sets. The zonestat utility output for these resources shows them as named mem_default and vm_default.

The all resource specifies that all resource types should be reported.

–R report[,report]

Print a summary report. The supported report types are described below. In addition to a comma-separated list, multiple -R options can be specified for a set of summary reports.

total

Prints a summary report detailing the following for each resource:

psets

Total cpu used since start of command invocation. The percent used for each zone includes time that a zone was not running. For instance, if a zone used 100% of the cpu while it was running, but the zone was halted for half of the intervals, then the summary report shows the zone used 50% of the cpu time.

memory, limits, sysv

Average resource used of all intervals reported since command invocation. This average factors in intervals in which a zone was not running. For example if a zone used on average of 100M of physical memory while it was running, and was only running for half the intervals, then the summary report shows that the zone used 50M of physical memory on average.

network

Sum of all bytes that are transmitted and received by all datalink utilizing physical bandwidth. The sum is calculated since start of command invocation and is normalized to number of bytes per second. The percentage used is based on total available bandwidth.

average

Similar to total, but only intervals in which a zone is running are factored in. For example, if a zone was only running for a single interval, and during that interval, the zone used 200M of virtual memory, then it's average virtual-memory is 200M, regardless of the number of intervals reported before the summary report.

high

Print a summary report detailing the highest usage of each resource and zone during any interval of the zonestat utility invocation.

–S col[,col]

Sort zones utilizing each resource.

The following sorting columns can be specified:

name

Sort alpha-numerically by zone name.

used

Sort by quantity of resource used. For networking resource, this is same as sort by bytes.

This is the default.

cap

Sort by configured cap.

pcap

Sort by percent of cap used.

shr

Sort by allocated share.

pshru

Sort by percent of share used.

bytes

Sort networking by total bytes transmitted and received.

prbyte

Sort networking by percentage of received bytes over the wire.

pobyte

Sort networking by percentage of transmitted bytes over the wire.

maxbw

Sort networking by percentage of bandwidth used.

cpu

Sort by cpu usage in the summary, This is the default.

physical-memory

Sort by physical memory usage in the summary.

virtual-memory

Sort by virtual memory usage in the summary.

network

Sort by network usage in the summary.

network

Sort by network usage in the summary.

–T u | d | i

Include timestamp of each report. The following formats are supported:

d

Standard date format. See date(1). This option is not valid with –p.

i

Time formatted as the ISO 8601 compliant format:

 YYYYMMDDThhmmssZ
u

A printed representation of the internal representation of time. See time(2). This is also known as unix time.

–x

Display an extended view with more detailed information. For example, when used with network resource, the extended view list details of each virtual datalink.

–z zonename[,zonename]

Specify a list of zones on which to report. By default all zones are reported.

In addition to a comma-separated list, multiple -z options can be specified to report on a set of zones. The output includes any resources which have usage by the specified zones.

Operands

The following operands are supported:

interval

Specifies the length in seconds to pause between each interval report. An interval of default uses the configured interval of the zones monitoring service. See zonestatd(1M).

interval is required. An interval of zero is not permitted. interval can be specified as [nh][nm][n s], such as 10s or 1m.

duration

Specifies the number of intervals to report. Defaults to infinity if not specified. The command duration is (interval * duration). A duration of zero is invalid. A value of inf can also be specified to explicitly choose infinity.

Duration can also be specified as [nh][nm][ns]. In this case, duration is interpreted as the duration of execution time. The actual duration is rounded up to the nearest multiple of the interval.

report

Specify the summary report period. For instance, a report of 4 produces reports every 4 intervals. If the command duration is not a multiple of report, then the last report is of any remaining intervals.

report can also be specified as [nh][nm][ns]. In this case, reports are output at the specified time period, rounded up to the nearest interval. If the command duration is not a multiple of report, then the last report is of any remaining intervals.

Requires –R. If –R is specified and report is not, the report period is the entire command duration, producing the specified reports at the end of execution.

OUTPUT

The following list defines the column heading of the command output:

SYSTEM-MEMORY

The total amount of memory available on the physical host.

SYSTEM-LIMIT

The maximum amount of resource available on the physical host.

CPUS

The number of cpus allocated to a processor set

ONLINE

Of the cpus allocated to a processor set, the number of cpus which can execute processes.

MIN/MAX

The minimum and maximum number of cpus which can be allocated to the processor set by the system.

ZONE

The zone using the resource. In addition to zone names, this column can also contain:

[total]

The total quantity of resource used system-wide.

[system]

The quantity of resource used by the kernel or in a manner not associated with any particular zone.

When zonestat is used within a non-global zone, [system] designates the aggregate resource used by the system and by all other zones.

For network resources, system usage of network is not available.

USED

The amount of resource used.

%USED

The amount of resource used as a percent of the total resource.

STLN

The amount of cpu time stolen from the zone. The Stolen Time is supported only by some zone brands. The value of Stolen Time reflects the time when the zone could not run due to the host using CPU resources for other purposes. For more information about Stolen Time refer to solaris-kz(5).

For the [system] row Stolen Time of the current system is reported. For the [total] row sum of Stolen Time of the current system and all the zones in the system is reported.

%STLN

The amount of cpu time stolen as a percent of the total cpu time available.

PCT

The amount of resource used as a percent of the total resource.

%PART

The amount of cpu used as a percentage of the total cpu in a processor-set to which the zone is bound. A zone can only have processes bound to multiple processor sets if it is the global zone, or if psrset(1M) psets are used. If multiple binding are found for a zone, it's %PART is the fraction used of all bound psets. For [total] and [system], %PART is the percent used of all cpus on the system.

CAP

If a zone is configured to have a cap on the given resource, the cap is displayed in this column.

%CAP

The amount of resource used as a percent of zone's configured cap.

SHRS

The number of shares allocated to the zone. For the [total] row, this is the total number of shares allocated to all zones sharing the resource. If a zone is not configured to use shares, and is sharing a resource with other zones that are configured to use shares, this column contains no-fss for the zone.

%SHRS

The fraction of the total shares allocated to the zone. For instance, if 2 zones share a processor set, each with 10 shares, then each zone has a %SHR of 50%.

%SHRU

Of the share allocated to the zone, the fraction of resource 100%. Because shares are only enforced when there is resource contention, it is possible for a zone to have a %SHRU in excess of 100%.

TOBYTES

The number of bytes transmitted and received by datalinks or virtual links.

PRBYTE

The number of received bytes that consumes physical bandwidth.

POBYTE

The number of transmitted bytes that consumes physical bandwidth.

%PRBYE

The percentage of available physical bandwidth used to receive PRBYTE.

%POBYE

The percentage of available physical bandwidth used to transmit POBYTE.

%PUSE

The sum of PRBYTE and POBYTE as a percent of the total available physical bandwidth.

LINK

The name of a datalink.

MAXBW

The maximum bandwidth configured on a datalink.

%MAXBW

The sum of all transmitted and received bytes as a percentage of configured maximum bandwidth.

Examples

Example 1 Using zonestat to Display a Summary of cpu and Memory Utilization

The following command shows a summary of cpu and memory utilization every 5 seconds:


 # zonestat 5 1
        SUMMARY   Cpus/Online: 4/4  Physical: 8063M  Virtual: 11.8G
                     ---CPU---   --PHYSMEM-- ---VMEM---  ---NET---
               ZONE  USED %PART  USED %USED  USED %USED PBYTE %PUSE
            [total]  0.23 5.76% 3211M 39.8% 4191M 34.6%  350M 18.7%     
           [system]  0.03 0.83% 2791M 34.6% 3890M 32.1%     -     -
        
        SUMMARY   Cpus/Online: 48/48   PhysMem: 95.9G    VirtMem: 99G
             ----------CPU---------- --PhysMem-- --VirtMem-- --PhysNet--
         ZONE     USED %PART  STLN %STLN USED %USED  USED %USED PBYTE %PUSE\
         [total]  2.04 4.27%  1.02 2.13% 29.4G 30.7% 31.1G 31.1% 228 0.00% 
        [system]  0.00 0.00%     -     - 12.6G 13.2% 30.3G 30.3% -     - 
          global  0.03 0.07%     -     -  542M 0.55%  657M 0.64% 228 0.00%
           zoneA  0.00 0.03%     -     -  117M 0.11%   99M 0.09% 0   0.00%
           zoneB  1.99 99.9%  1.02 51.0% 8265M 8.41% 3092K 0.00% 0   0.00%
              
Example 2 Using zonestat to Produce Parseable Output

The following command produces parseable output. It prints one line per zone using each pset resource for a 5 second interval:


# zonestat -p -P zones -r psets 5 1

Example 3 Using zonestat to Report on the Default pset

The following command reports on the default pset once a second for one minute:


# zonestat -r default-pset 1 1m

Example 4 Using zonestat to Report Total and High Utilization

The following command monitors silently at a 10 second interval for 24 hours, producing a total and high report every 1 hour:


# zonestat -q -R total,high 10s 24h 1h

Example 5 Using zonestat to Report Datalink Utilization

The following command reports on a datalink named e1000g0 at a 5 second interval for 5 times:


# zonestat -r network -n e1000g0 5 5

Exit Status

The following exit values are returned:

0

Successful completion.

1

An error occurred.

2

Invalid usage.

3

svc:system/zones_monitoring: default not running or not responding.

Attributes

See attributes(5) for descriptions of the following attributes:

ATTRIBUTE TYPE
ATTRIBUTE VALUE
Availability
system/zones
Interface Stability
See below.

Command invocation and parseable output is Committed. Human readable output (default output) is Uncommitted.

See Also

date (1) , prctl (1) , pooladm(1M), poolcfg(1M), psrset(1M), rcapadm(1M), zoneadm(1M), zonecfg(1M), zonestatd(1M), time(2), timezone(4), attributes(5), privileges(5), resource-controls(5), solaris-kz(5)

Notes

The zonestat utility depends on the zones monitoring service: svc/system/zonestat:default. If the zonestat service is stopped while the zonestat utility is running, the zonestat command invocation quits without printing additional reports. The reports (–R) is printed if zonestat is interrupted (by CTRL/c, SIGINT) before reaching the next report period.