ulimit is a tool in Linux that limits the use of process resources, and supports setting file size, file descriptors, number of processes, memory, and CPU time. 1. Common options include -f (file size), -n (file descriptor), -u (number of processes), -v (virtual memory), -t (CPU time), and -l (locked memory). 2. Supports soft limits (-S, currently in effect but cannot exceed hard limits) and hard limits (-H, set by root). 3. The temporary setting fails after restarting. Persistence needs to be written to the script under /etc/security/limits.conf or /etc/profile.d/. The systemd service also needs to add the Limit parameter to the service file. 4. Pay attention to permission issues (ordinary users cannot increase hard limits), effective scope (only the current shell and subsequent processes), verification method (ulimit -a or /proc/
In Linux systems, if you want to limit the resources a process can use (such as memory, number of open files, CPU time, etc.), ulimit
is a very practical tool. It can be set directly through the shell, without the need for additional software installation, and is suitable for quick configuration.
1. Common resource restrictions and meanings
Before using ulimit
, first understand some common resource restriction options:
-
-f
: Maximum file size (unit is KB) -
-n
: The maximum number of file descriptors that can be opened -
-u
: The maximum number of processes that can be run by the user -
-v
: Upper limit for virtual memory usage (unit is KB) -
-t
: CPU usage time upper limit (unit is seconds) -
-l
: Lock the upper limit of memory size
These restrictions can be set in the current shell session and affect the process started later. For example:
ulimit -v 2000000 # Restrict the maximum virtual memory of the process to 2GB
But it should be noted that the setting of ulimit
is only valid for the current session and fails after restarting. If you want to persist, you need to write to the configuration file (I will talk about it later).
2. Set soft and hard limits
There are two modes ulimit
: soft limit and hard limit :
- Soft limit: The currently effective limit value can be reduced or increased by the user, but cannot exceed the hard limit.
- Hard limit: The upper limit set by the root user cannot break through.
You can use -S
or -H
to set soft or hard limits respectively. For example:
ulimit -S -n 1024 # Set soft limits, open up to 1024 files ulimit -H -n 2048 # Set hard limits, allow up to 2048 files
It is usually recommended to set hard limits first and soft limits, otherwise it may fail due to permission issues.
3. Persist ulimit configuration
The temporary setting of ulimit
only takes effect on the current terminal, and restart or new terminal will be invalid. To allow the restrictions to take effect for a long time, you can write settings to the system configuration file:
If you only want to set it for a certain user, modify
/etc/security/limits.conf
Example:
username soft nofile 1024 username hard nofile 2048
If you want to set it for all users, you can create a new
.sh
file under/etc/profile.d/
and add theulimit
command, for example:ulimit -n 1024 ulimit -v 2000000
Note: Some services may be started by systemd, and they will not read the shell configuration file. They need to add the parameter
LimitNOFILE=1024
to the service file separately.
4. Things to note in practical application
- Permission issue : Only root users can increase the hard limit, and ordinary users can only lower or maintain the original settings.
- Effective scope :
ulimit
affects the process started by the current shell. If it is a background service or daemon, special processing may be required. - Verify whether it is effective : You can use
ulimit -a
to view all current restrictions, or check/proc/<pid>/limits</pid>
to confirm the limitations of the specific process. - Risk of excessive limits : Setting too low limits may cause program crashes or functional abnormalities, such as database connection failure, logs not being written in, etc.
Basically that's it. By mastering these key points, you can flexibly control the use of process resources.
The above is the detailed content of How to limit the resources a process can use with ulimit?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

LXD is described as the next-generation container and virtual machine manager that offers an immersive for Linux systems running inside containers or as virtual machines. It provides images for an inordinate number of Linux distributions with support

Firefox browser is the default browser for most modern Linux distributions such as Ubuntu, Mint, and Fedora. Initially, its performance might be impressive, however, with the passage of time, you might notice that your browser is not as fast and resp

When encountering DNS problems, first check the /etc/resolv.conf file to see if the correct nameserver is configured; secondly, you can manually add public DNS such as 8.8.8.8 for testing; then use nslookup and dig commands to verify whether DNS resolution is normal. If these tools are not installed, you can first install the dnsutils or bind-utils package; then check the systemd-resolved service status and configuration file /etc/systemd/resolved.conf, and set DNS and FallbackDNS as needed and restart the service; finally check the network interface status and firewall rules, confirm that port 53 is not

If you find that the server is running slowly or the memory usage is too high, you should check the cause before operating. First, you need to check the system resource usage, use top, htop, free-h, iostat, ss-antp and other commands to check CPU, memory, disk I/O and network connections; secondly, analyze specific process problems, and track the behavior of high-occupancy processes through tools such as ps, jstack, strace; then check logs and monitoring data, view OOM records, exception requests, slow queries and other clues; finally, targeted processing is carried out based on common reasons such as memory leaks, connection pool exhaustion, cache failure storms, and timing task conflicts, optimize code logic, set up a timeout retry mechanism, add current limit fuses, and regularly pressure measurement and evaluation resources.

As a system administrator, you may find yourself (today or in the future) working in an environment where Windows and Linux coexist. It is no secret that some big companies prefer (or have to) run some of their production services in Windows boxes an

Frankly speaking, I cannot recall the last time I used a PC with a CD/DVD drive. This is thanks to the ever-evolving tech industry which has seen optical disks replaced by USB drives and other smaller and compact storage media that offer more storage

In Linux systems, 1. Use ipa or hostname-I command to view private IP; 2. Use curlifconfig.me or curlipinfo.io/ip to obtain public IP; 3. The desktop version can view private IP through system settings, and the browser can access specific websites to view public IP; 4. Common commands can be set as aliases for quick call. These methods are simple and practical, suitable for IP viewing needs in different scenarios.

Built on Chrome’s V8 engine, Node.JS is an open-source, event-driven JavaScript runtime environment crafted for building scalable applications and backend APIs. NodeJS is known for being lightweight and efficient due to its non-blocking I/O model and
