Class LinuxOperatingSystem
- All Implemented Interfaces:
OperatingSystem
-
Nested Class Summary
Nested classes/interfaces inherited from interface OperatingSystem
OperatingSystem.OSVersionInfo, OperatingSystem.ProcessFiltering, OperatingSystem.ProcessSorting -
Field Summary
FieldsModifier and TypeFieldDescription(package private) static final longprivate static final Stringprivate static final Stringstatic final booleanThis static field identifies if the gettid function is in the c library.static final booleanThis static field identifies if the syscall for gettid returns sane results.static final booleanThis static field identifies if the udev library can be loaded.private static final org.slf4j.Loggerprivate static final Stringprivate static final Stringprivate static final StringOS Name for manufacturerprivate static final Stringprivate static final longprivate static final int[]private static final Stringprivate static final longJiffies per second, used for process time counters.Fields inherited from class AbstractOperatingSystem
USE_WHO_COMMAND -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionAttempts to execute `lsb_release -a`private static StringfilenameToFamily(String name) Converts a portion of a filename (e.g.Makes a best effort to get the current thread.Instantiates aFileSystemobject.static longgetHz()Gets Jiffies per second, useful for converting ticks to milliseconds and vice versa.Instantiates aInternetProtocolStatsobject.Instantiates aNetworkParamsobject.static longGets Page Size, for converting memory stats from pages to bytesprivate static intgetParentPidFromProcFile(int pid) getParentPidsFromProcFiles(File[] pidFiles) getProcess(int pid) Gets information on a currently running processintGet the number of processes currently runningintGets the current process ID (PID).protected static StringLooks for a collection of possible distrib-release filenamesGets the all services on the system.Gets currently logged in users.longGet Unix time of boot.longGet the System up time (time since boot).intGet the number of threads currently runningintMakes a best effort to get the current thread ID (TID).parseRelease(String line, String splitLine) Helper method to parse version description line styleprotected intqueryBitness(int jvmBitness) Backup OS-specific query to determine bitness if previous checks failqueryChildProcesses(int parentPid) queryDescendantProcesses(int parentPid) queryProcessList(Set<Integer> descendantPids) readDistribRelease(String filename) Attempts to read /etc/distrib-release (for some value of distrib)Attempts to read /etc/lsb-releaseAttempts to read /etc/os-releaseMethods inherited from class AbstractOperatingSystem
getBitness, getChildProcesses, getChildrenOrDescendants, getChildrenOrDescendants, getDescendantProcesses, getFamily, getManufacturer, getProcesses, getVersionInfo, toStringMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface OperatingSystem
getCurrentProcess, getDesktopWindows, getProcesses, getProcesses, isElevated
-
Field Details
-
LOG
private static final org.slf4j.Logger LOG -
OS_RELEASE_LOG
- See Also:
-
LSB_RELEASE_A_LOG
- See Also:
-
LSB_RELEASE_LOG
- See Also:
-
RELEASE_DELIM
- See Also:
-
DOUBLE_QUOTES
- See Also:
-
FILENAME_PROPERTIES
- See Also:
-
HAS_UDEV
public static final boolean HAS_UDEVThis static field identifies if the udev library can be loaded. -
HAS_GETTID
public static final boolean HAS_GETTIDThis static field identifies if the gettid function is in the c library. -
HAS_SYSCALL_GETTID
public static final boolean HAS_SYSCALL_GETTIDThis static field identifies if the syscall for gettid returns sane results. -
USER_HZ
private static final long USER_HZJiffies per second, used for process time counters. -
PAGE_SIZE
private static final long PAGE_SIZE -
OS_NAME
OS Name for manufacturer -
BOOTTIME
static final long BOOTTIME -
PPID_INDEX
private static final int[] PPID_INDEX
-
-
Constructor Details
-
LinuxOperatingSystem
public LinuxOperatingSystem()Constructor for LinuxOperatingSystem.
-
-
Method Details
-
queryManufacturer
- Specified by:
queryManufacturerin classAbstractOperatingSystem
-
queryFamilyVersionInfo
- Specified by:
queryFamilyVersionInfoin classAbstractOperatingSystem
-
queryBitness
protected int queryBitness(int jvmBitness) Description copied from class:AbstractOperatingSystemBackup OS-specific query to determine bitness if previous checks fail- Specified by:
queryBitnessin classAbstractOperatingSystem- Parameters:
jvmBitness- The bitness of the JVM- Returns:
- The operating system bitness
-
getFileSystem
Description copied from interface:OperatingSystemInstantiates aFileSystemobject.- Returns:
- A
FileSystemobject.
-
getInternetProtocolStats
Description copied from interface:OperatingSystemInstantiates aInternetProtocolStatsobject.- Returns:
- a
InternetProtocolStatsobject.
-
getSessions
Description copied from interface:OperatingSystemGets currently logged in users.On macOS, Linux, and Unix systems, the default implementation uses native code (see
man getutxent) that is not thread safe. OSHI's use of this code is synchronized and may be used in a multi-threaded environment without introducing any additional conflicts. Users should note, however, that other operating system code may access the same native code.The
Who.queryWho()method produces similar output parsing the output of the Posix-standardwhocommand, and may internally employ reentrant code on some platforms. Users may opt to use this command-line variant by default using theoshi.os.unix.whoCommandconfiguration property.- Returns:
- A list of
OSSessionobjects representing logged-in users
-
getProcess
Description copied from interface:OperatingSystemGets information on a currently running process- Parameters:
pid- A process ID- Returns:
- An
OSProcessobject for the specified process id if it is running; null otherwise
-
queryAllProcesses
- Specified by:
queryAllProcessesin classAbstractOperatingSystem
-
queryChildProcesses
- Specified by:
queryChildProcessesin classAbstractOperatingSystem
-
queryDescendantProcesses
- Specified by:
queryDescendantProcessesin classAbstractOperatingSystem
-
queryProcessList
-
getParentPidsFromProcFiles
-
getParentPidFromProcFile
private static int getParentPidFromProcFile(int pid) -
getProcessId
public int getProcessId()Description copied from interface:OperatingSystemGets the current process ID (PID).- Returns:
- the Process ID of the current process
-
getProcessCount
public int getProcessCount()Description copied from interface:OperatingSystemGet the number of processes currently running- Returns:
- The number of processes running
-
getThreadId
public int getThreadId()Description copied from interface:OperatingSystemMakes a best effort to get the current thread ID (TID). May not be useful in a multithreaded environment. The thread ID returned may have been short lived and no longer exist.Thread IDs on macOS are not correlated with any other Operating System output.
- Returns:
- the Thread ID of the current thread if known, 0 otherwise.
-
getCurrentThread
Description copied from interface:OperatingSystemMakes a best effort to get the current thread. May not be useful in a multithreaded environment. The thread returned may have been short lived and no longer exist.On macOS, returns the oldest thread in the calling process.
- Returns:
- the current thread if known; an invalid thread otherwise.
-
getThreadCount
public int getThreadCount()Description copied from interface:OperatingSystemGet the number of threads currently running- Returns:
- The number of threads running
-
getSystemUptime
public long getSystemUptime()Description copied from interface:OperatingSystemGet the System up time (time since boot).- Returns:
- Number of seconds since boot.
-
getSystemBootTime
public long getSystemBootTime()Description copied from interface:OperatingSystemGet Unix time of boot.- Returns:
- The approximate time at which the system booted, in seconds since the Unix epoch.
-
getNetworkParams
Description copied from interface:OperatingSystemInstantiates aNetworkParamsobject.- Returns:
- A
NetworkParamsobject.
-
queryFamilyVersionCodenameFromReleaseFiles
-
readOsRelease
-
execLsbRelease
-
readLsbRelease
-
readDistribRelease
Attempts to read /etc/distrib-release (for some value of distrib)- Parameters:
filename- The /etc/distrib-release file- Returns:
- a triplet with the parsed family, versionID and codeName if file successfully read and " release " or " VERSION " found, null otherwise
-
parseRelease
Helper method to parse version description line style- Parameters:
line- a String of the form "Distributor release x.x (Codename)"splitLine- A regex to split on, e.g. " release "- Returns:
- a triplet with the parsed family, versionID and codeName
-
getReleaseFilename
Looks for a collection of possible distrib-release filenames- Returns:
- The first valid matching filename
-
filenameToFamily
-
getServices
Description copied from interface:OperatingSystemGets the all services on the system. The definition of what is a service is platform-dependent.- Returns:
- An array of
OSServiceobjects
-
getHz
public static long getHz()Gets Jiffies per second, useful for converting ticks to milliseconds and vice versa.- Returns:
- Jiffies per second.
-
getPageSize
public static long getPageSize()Gets Page Size, for converting memory stats from pages to bytes- Returns:
- Page Size
-