Users should create a new instance of SystemInfo and use the getters from this class to access the platform-specific hardware and software interfaces using the respective get*()
methods. The interfaces in oshi.hardware
and oshi.software.os
provide cross-platform functionality. See the main()
method of SystemInfoTest for sample code.
Methods return a "snapshot" of current levels. To display values which change over time, it is intended that users poll for information no more frequently than approximately every second. Disk and file system calls may incur some latency and should be polled less frequently. CPU usage calculation precision depends on the relation of the polling interval to both system clock tick granularity and the number of logical processors.
The interfaces and classes in oshi.hardware
and oshi.software.os
are considered the OSHI API and are guaranteed to be compatible with the same major version. Differences between major versions can be found in the UPGRADING.md document.
Most, if not all, of the platform-specific implementations of these APIs in lower level packages will remain the same, although it is not intended that users access platform-specific code, and some changes may occur between minor versions, most often in the number of arguments passed to constructors or platform-specific methods. Supporting code in the oshi.driver
and oshi.util
packages may,
rarely, change between minor versions, usually associated with organizing package structure or changing parsing methods for
efficiency/consistency/ease of use.
Code in the platform-specific oshi.jna.*
packages is intended to be temporary and will be removed when that respective code is included in the JNA project.
OSHI 5.X is thread safe with the exceptions noted below. @Immutable
, @ThreadSafe
, and @NotThreadSafe
document
each class. The following classes are not thread-safe:
GlobalConfig
does not protect against multiple threads manipulating the configuration programmatically. However, these methods are intended to be used by a single thread at startup in lieu of reading a configuration file. OSHI gives no guarantees on re-reading changed configurations.PerfCounterQuery
andPerfCounterWildcardQuery
objects should only be used within the context of a single thread. These are only used internally in OSHI in these single-thread contexts and not intended for user use.- On non-Windows platforms, the
getSessions()
method on theOperatingSystem
interface uses native code which is not thread safe. While OSHI's methods employ synchronization to coordinate access from its own threads, users are cautioned that other operating system code may access the same underlying data structures and produce unexpected results, particularly on servers with frequent new logins.
Earlier versions do not guarantee thread safety, but as of version 4.6.0, intended use is thread safe.
Classes with setters on them are obviously not thread-safe unless the use of the setters is synchronized across threads.
In the case of the HWDiskStore
, this synchronization must extend to the HWPartition
objects
associated with that disk store.
Prior to version 4.1.0, there is no guarantee of thread safety and it should not be assumed.
OSHI 3.x is compatible with Java 7, but will not see any added features.
OSHI 4.x and 5.x require minimum Java 8 compatibility.
Future version requirements have not yet been finalized. Other than incremental changes, any significant improvements will likely require at least Java 11 and leverage modules.
OSHI has been implemented and tested on the following systems. Some features may work on earlier versions.
- Windows 7 and higher. (Nearly all features work on Vista and most work on Windows XP.)
- Mac OS X version 10.6 (Snow Leopard) and higher
- Linux (Most major distributions) Kernel 2.6 and higher
- Unix: Solaris 11 (SunOS 5.11) / FreeBSD 10
OSHI uses the latest version of JNA, which may conflict with other dependencies your project (or its parent) includes. If you experience issues with NoClassDefFound
errors for JNA artifacts, consider one or more of the following steps to resolve the conflict:
- Listing OSHI earlier (or first) in your dependency list
- Specifying the most recent version of JNA (both
jna
andjna-platform
artifacts) as a dependency - If you are using a parent (e.g., Spring Boot) that includes JNA as a dependency, override the
jna.version
property
Both OSHI and Hyperic's SIGAR (System Information Gatherer and Reporter) provide cross-platform operating system and hardware information, and are both used to support distributed system monitoring and reporting, among other use cases. The OSHI project was started, and development continues, to overcome specific shortcomings in SIGAR for some use cases. OSHI does have feature parity with nearly all SIGAR functions. Key differences include:
- Additional DLL SIGAR's implementation is primarily in native C, compiled separately for its supported operating systems. It therefore requires users to download an additional DLL specific to their operating system. This does have some advantages including faster native code routines, and availability of some native compiler intrinsics. In contrast, OSHI accesses native APIs using JNA, which does not require any additional platform-specific DLLs.
- Platform Coverage SIGAR (presently) supports a larger number of platforms, although some users have reported incompatibilities with recent architectures and Java versions. OSHI supports 99.5% of OS user share with support for Windows, Linux, macOS, FreeBSD, and Solaris, and would support additional Operating Systems if access to appropriate machines for development and testing were available.
- Language Coverage SIGAR has bindings for Java, .NET, and Perl. OSHI is specific for Java.
- Corporate Development SIGAR was developed professionally at Hyperic, later acquired by VMWare. OSHI's development has been entirely done by open source volunteers.
- Actively Maintained Project SIGAR is unmaintained, and apparently abandoned, with multiple independent forks by users fixing specific bugs/incompatibilities. The the last release was in 2010 and the last source commit was in 2015. OSHI is under active development as of 2020.
Yes, most of the Linux code works here and other Pi-specific code has been implemented but has seen limited testing. As the developers do not have a Pi to test on, users reporting issues should be prepared to help test solutions.
We'd love to. We need access to those operating systems which only run on their specific machines, and are not available in VMs. If you can offer such access, create an issue to notify the team of the possibility.
Unlikely without bribes such as a lifetime supply of coffee. But happy to advise someone else who wants to do so!
No.
Maybe! If you can contribute all the code to implement the feature, it will almost certainly be added. Even if you can't code but can provide pointers to where the information can be found cross-platform, your feature has a good chance. Otherwise, you can always submit an issue to ask, but are at the mercy of the developers' time, enthusiasm level, and the availability of documentation for the feature.