Sysctl
Welcome to Sysctl. |
Kernel Competence | ||
---|---|---|
Sysctl | Kldstat | Third-party Kernel Modules |
Kernel Modules | FreeBSD Ports: Kld | Kenv |
Compiling a new GhostBSD kernel | ||
Back to the System |
Contents
Introduction
The sysctl utility retrieves kernel state and allows processes with appropriate privilege to set kernel state. The state to be retrieved or set is described using a “Management Information Base” (“MIB”) style name, described as a dotted set of components.
Usage
The information available from sysctl consists of integers, strings, and opaque types. The sysctl utility only knows about a couple of opaque types, and will resort to hexdumps for the rest. The opaque information is much more useful if retrieved by special purpose programs such as ps(1), systat(1), and netstat(1).
Some of the variables which cannot be modified during normal system operation can be initialized via loader(8) tunables. This can for example be done by setting them in loader.conf(5). Please refer to loader.conf(5) for more information on which tunables are available and how to set them.
Retrieve Kernel Information
Use sysctl plus the following sysctl variable NAME:
sysctl NAME
You will get the following examples:
Categories of Kernel information
The kernel information are organized in a tree format, called as management information base (MIB) with several categories. Compare the following list with the NAMEs above.
Category | Function |
---|---|
kern | Core kernel funktions and features |
vm | Virtual memory system |
vfs | Filesystem |
net | Networking |
debug | Debugging |
hw | Hardware |
machdep | Machine-depend settings |
user | Userland interface information |
p1003_1b | POSIX behavior |
dev | Device-specific information |
security | Security-specific kernel features |
Each of this categories have further subcategories. Each category is connected with its subcategories by making a string with a point between them.
Example: the category kern and its subcategory hostname give you: kern.hostname a unique sysctl variable.
Retrieve Definition of a sysctl Variable
If you like to know how is the sysctl variable defined, you have to use the following command:
sysctl -d NAME
Example:
sysctl -d kern.osreldate
You will get:
kern.osreldate: Kernel release date
For more sysctl options look at sysctl on the man pages.
Unfortunately not all sysctl variables provide definitions with -d.
More variables than in sysctl(8) exist and the best and likely only place to search for their deeper meaning is undoubtedly the source where they are defined.