Linux 中进程的 nice 值对程序的占用的影响测试

1. Linux 进程中的 nice 值

nice 值通过调整进程的优先级,间接控制 CPU 时间片的分配权重,从而实现对进程调度行为的精细控制。它是 Linux 系统中平衡实时任务与后台任务资源占用的核心工具之一。

优先级调整

核心机制:nice 值(范围 -20 到 19)直接控制进程的调度优先级。

低 nice 值(如 -20):表示高优先级,进程更容易被调度器选中,获得更多 CPU 时间片。

高 nice 值(如 19):表示低优先级,进程被调度的频率降低,CPU 时间片分配减少。

记忆:一个进程的 nice 值越高,说明对别的进程越 nice,别的进程运行得越好越快。

2. 代码

设计说明

  • 独立程序:高优先级和低优先级程序完全分离,便于独立运行和调试。
  • CPU 绑定:两个程序均绑定到 CPU 0,消除多核干扰。
  • 时间片观测:每秒打印计数器增量,反映时间片分配比例。

a. high_nice.cc

cpp 复制代码
#include <iostream>
#include <unistd.h>
#include <sys/resource.h>
#include <sched.h>
#include <atomic>
#include <thread>

// 绑定到指定 CPU 核
void bind_cpu(int cpu_id) {
    cpu_set_t mask;
    CPU_ZERO(&mask);
    CPU_SET(cpu_id, &mask);
    if (sched_setaffinity(0, sizeof(mask), &mask) < 0) {
        perror("sched_setaffinity");
        exit(1);
    }
}

// 设置进程的 nice 值
void set_nice(int niceness) {
    if (setpriority(PRIO_PROCESS, 0, niceness) < 0) {
        perror("setpriority");
        exit(1);
    }
}

std::atomic<long> counter(0);  // 全局计数器

void worker() {
    while (true) {
        counter++;  // 高速递增计数器
    }
}

void reporter() {
    long last = 0;
    while (true) {
        std::this_thread::sleep_for(std::chrono::seconds(1));
        long current = counter.load();
        std::cout << "[HIGH] Increment: " << current - last << std::endl;
        last = current;
    }
}

int main() {
    bind_cpu(0);         // 绑定到 CPU 0
    set_nice(-5);       // 设置最高优先级(需 root 权限)
    std::thread t1(worker);
    std::thread t2(reporter);
    t1.join();
    t2.join();
    return 0;
}

b. low_nice.cc

cpp 复制代码
#include <iostream>
#include <unistd.h>
#include <sys/resource.h>
#include <sched.h>
#include <atomic>
#include <thread>

// 绑定到指定 CPU 核
void bind_cpu(int cpu_id) {
    cpu_set_t mask;
    CPU_ZERO(&mask);
    CPU_SET(cpu_id, &mask);
    if (sched_setaffinity(0, sizeof(mask), &mask) < 0) {
        perror("sched_setaffinity");
        exit(1);
    }
}

// 设置进程的 nice 值
void set_nice(int niceness) {
    if (setpriority(PRIO_PROCESS, 0, niceness) < 0) {
        perror("setpriority");
        exit(1);
    }
}

std::atomic<long> counter(0);  // 全局计数器

void worker() {
    while (true) {
        counter++;  // 高速递增计数器
    }
}

void reporter() {
    long last = 0;
    while (true) {
        std::this_thread::sleep_for(std::chrono::seconds(1));
        long current = counter.load();
        std::cout << "[LOW]  Increment: " << current - last << std::endl;
        last = current;
    }
}

int main() {
    bind_cpu(0);         // 绑定到 CPU 0
    set_nice(10);        // 设置最低优先级
    std::thread t1(worker);
    std::thread t2(reporter);
    t1.join();
    t2.join();
    return 0;
}

c. Makefile

bash 复制代码
CPP = g++
CFLAGS = -std=c++11 -pthread -O2
TARGETS = high_nice low_nice

all: $(TARGETS)

high_nice: high_nice.cc
	$(CPP) $(CFLAGS) $< -o $@

low_nice: low_nice.cc
	$(CPP) $(CFLAGS) $< -o $@

clean:
	rm -f $(TARGETS)

运行:

bash 复制代码
make

# bash1
sudo ./high_nice

# bash2
sudo ./low_nice

3. 结果测试

nice 值为 -5 的占据 CPU 的 96%, nice 值为10 的占据 CPU 的3.7%。

相关推荐
Leon-Ning Liu37 分钟前
【真实经验分享】OGG抽取进程报错 ORA-07445 [kgherrordmp()+986] ORA-00600 [17114]分析步骤
运维·数据库
CCPC不拿奖不改名41 分钟前
Redis 工程化部署深度解析
linux·服务器·数据库·redis·深度学习·缓存·rag
QWEDDRFTG42 分钟前
运维长期经验总结:从故障倒推服务器电源线选购标准
运维·服务器
Mr.wangh1 小时前
聊天模型--流式传输
运维·服务器
有颜有货1 小时前
PMC生产排产的4种算法,一次讲清
java·服务器·前端
智恒百亿1 小时前
算力基建深度分析:国内服务器产业高强度迭代下的技术壁垒与全球化优势
服务器·人工智能·算力基建
fei_sun1 小时前
等价负载均衡(等价路由ECMP)
运维·负载均衡
楷哥爱开发1 小时前
降低网络爬虫成本:基础设施优化指南
服务器·开发语言·php
鱼很腾apoc2 小时前
【Linux】第7期 进程间通信 (IPC) 详解:管道 (匿名 / 命名) + System V
linux·服务器·c语言·学习·进程间通信·ipc
毒爪的小新2 小时前
踩坑实录 | RAG知识库完整搭建-Milvus2.4+BGE大中文AI模型嵌入
linux·人工智能·ai·milvus·rag