【教程】Linux设置进程的优先级

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn]

如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~


关键指令

sudo chrt -f <优先级> <指令>

示例脚本

        当然也可以不是启动Python脚本,普通的指令都可以,可自行适当修改。

#!/bin/bash# 默认参数值
DEFAULT_CHRT_PRIORITY=99
# 必须是绝对路径
DEFAULT_PYTHON="/home/anaconda3/envs/abc/bin/python"
# 脚本名称
DEFAULT_SCRIPT="train.py"# 解析命令行参数
while getopts "c:p:s:" opt; docase $opt inc) CHRT_PRIORITY=$OPTARG ;;p) PYTHON=$OPTARG ;;s) SCRIPT=$OPTARG ;;\?) echo "Invalid option -$OPTARG" >&2 ;;esac
done# 设置默认值,如果没有提供参数
CHRT_PRIORITY=${CHRT_PRIORITY:-$DEFAULT_CHRT_PRIORITY}
PYTHON=${PYTHON:-$DEFAULT_PYTHON}
SCRIPT=${SCRIPT:-$DEFAULT_SCRIPT}# 启动训练脚本并设置实时调度策略和优先级
sudo chrt -f $CHRT_PRIORITY $PYTHON $SCRIPT# 获取并显示进程ID (PID)
SCRIPT_PID=$!
echo "Started script with PID: $SCRIPT_PID"

参数解释

  • CHRT_PRIORITY=10:设置实时调度策略的优先级为 10。
  • sudo chrt -f $CHRT_PRIORITY $PYTHON $SCRIPT:使用 SCHED_FIFO 调度策略和设置的优先级来启动 Python 脚本。
  • TRAIN_PID=$!:获取最后一个放到后台运行的进程的 PID。
  • echo "Started training script with PID: $TRAIN_PID":显示启动的进程的 PID。

使用示例

sudo bash script.sh -c 50 -p /path/to/your/python -s your_script.py

nice与chrt的区别

        这两个指令都可以用来调整进程的优先级,但略有区别。

nice 命令

  • 功能: nice 命令用于启动一个进程并设置其静态优先级(nice 值)。
  • 优先级范围: nice 值的范围从 -20 到 19,-20 表示最高优先级,19 表示最低优先级。默认值为 0。
  • 调度策略: nice 命令不会更改进程的调度策略,仅调整其在默认调度策略(通常是 CFS,即 Completely Fair Scheduler)中的优先级。
  • 使用场景: 适用于大多数普通用户程序,用于调整程序的优先级,以便系统更合理地分配资源。

chrt 命令

  • 功能: chrt 命令用于设置或更改进程的调度策略和实时优先级。
  • 调度策略: chrt 提供多种调度策略,包括 SCHED_OTHER、SCHED_FIFO、SCHED_RR、SCHED_BATCH、SCHED_IDLE 和 SCHED_DEADLINE。最常用的是实时调度策略 SCHED_FIFO 和 SCHED_RR。
  • 优先级范围: 实时优先级范围从 1 到 99,1 为最低优先级,99 为最高优先级。非实时调度策略通常使用 nice 值。
  • 使用场景: 适用于需要高优先级和严格调度的实时应用程序,例如音频处理、视频处理或其他时间敏感的任务。

非实时调度和实时调度策略的区别

非实时调度策略

        非实时调度策略适用于大多数普通用户程序,操作系统会尽量公平地分配 CPU 时间给所有进程。这些策略包括:

  • SCHED_OTHER: 这是默认的调度策略(也称为 CFS, Completely Fair Scheduler),用于普通进程。
  • SCHED_BATCH: 适用于批处理任务,减少交互性以提高吞吐量。
  • SCHED_IDLE: 适用于最低优先级的任务,只有在系统空闲时才运行。
特点
  • 公平性: 系统尽量公平地分配 CPU 时间给所有进程。
  • 交互性: 优先考虑交互式任务,确保良好的用户体验。
  • 适用性: 适用于大多数普通任务,不需要严格的时间限制。
实时调度策略

        实时调度策略用于需要严格时间限制的任务,保证高优先级任务能够在需要时及时执行。这些策略包括:

  • SCHED_FIFO (First In, First Out): 实时优先级策略,按照优先级顺序执行,具有相同优先级的进程按照先进先出的顺序执行。
  • SCHED_RR (Round Robin): 实时优先级策略,类似于 SCHED_FIFO,但在同一优先级上使用时间片轮转调度。
  • SCHED_DEADLINE: 最严格的实时调度策略,基于任务的绝对截止时间进行调度。
特点
  • 确定性: 高优先级任务可以在需要时及时执行,具有较高的响应性。
  • 严格性: 确保实时任务在规定时间内完成。
  • 适用性: 适用于音频处理、视频处理、机器人控制等需要实时响应的任务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/853742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

38、基于卷积神经网络(CNN)的车牌自动识别系统(matlab)

1、原理及流程 1&#xff09;原理 CNN&#xff08;卷积神经网络&#xff09;是一种深度学习模型&#xff0c;可以用于图像识别和分类任务。车牌自动识别系统的原理基本上就是使用CNN模型对车牌图像进行处理和识别。 首先&#xff1a;系统需要收集大量的含有车牌的图像数据作…

cmake target_include_directories 详解

在 CMake 中&#xff0c;target_include_directories 命令用于向特定目标&#xff08;如可执行文件或库&#xff09;添加包含目录&#xff0c;以便编译器能够找到特定目标所需的头文件。 基本语法 target_include_directories(target_name[SYSTEM] [BEFORE]directory1[direct…

什么是知识图谱

文章目录 知识图谱概念知识图谱的发展历史知识图谱的价值知识图谱概念 知识图谱是一种用图模型来描述知识和建模世界万物之间的关联关系的技术方法。知识图谱由节点和边组成。节点可以是实体,如一个人、一本书等,或是抽象的概念,如人工智能、知识图谱等。边可以是实体的属性…

八股操作系统和计算机网络

5.线程间的同步的方式有哪些&#xff1f; 6.PCB(不熟悉) 进程状态 什么是僵尸进程和孤儿进程&#xff1f; 进程调度算法 死锁的理解 举个发生死锁的例子 解决死锁的方式 内存管理做了哪些事情 什么是内存碎片 常见的内存管理 段表通过什么数据结构实现地址映射 分段机制为什么会…

平板消解加热台-温度均匀,防腐蚀-实验室化学分析

DBF系列防腐电热板 是精致路合金加热板块表面经进口高纯实验级PFATeflon氟塑料防腐不粘处理&#xff0c;专为实验室设计的电加热产品&#xff0c;是样品前处理中&#xff0c;加热、消解、煮沸、蒸酸、赶酸等处理的得力助手。可以满足物理、化学、生物、环保、制药、食品、饮品…

星型、环型、总线型和网状型拓扑结构是什么意思?

拓扑结构&#xff08;Topology&#xff09;是指对象在保持某些基本性质不变的情况下&#xff0c;不考虑距离和角度等几何细节的形状和空间关系。换句话说&#xff0c;拓扑结构研究的是物体在连续变形&#xff08;如拉伸、压缩、扭曲等&#xff09;下保持不变的性质。这一点不太…

黑马头条Minio报错non-xml response from server错误的解决方法

今天在写项目的时候&#xff0c;想测试minio上传文件功能是否正常&#xff0c; 但是每次都出现non-xml response from server的错误。 自己也在网上找了很多解决方法&#xff0c;大部分是说用户名和密码的配置问题&#xff0c;但是检查后发现并没有错误。 最后发现是自己的dock…

允许长单词和数字换行

title: 允许长单词和数字换行 date: 2024-06-15 20:18:15 tags: vue3 当文字的张度大于盒子的最大长度&#xff0c;但是由于它是一串数字或者是一串英文字母&#xff0c;通常是不会默认换行的。 在输入的时候我们会经常遇见这样的问题&#xff0c;这个时候就要重新定义一下样…

【Kafka专栏 14】Kafka如何维护消费状态跟踪:数据流界的“GPS”

作者名称&#xff1a;夏之以寒 作者简介&#xff1a;专注于Java和大数据领域&#xff0c;致力于探索技术的边界&#xff0c;分享前沿的实践和洞见 文章专栏&#xff1a;夏之以寒-kafka专栏 专栏介绍&#xff1a;本专栏旨在以浅显易懂的方式介绍Kafka的基本概念、核心组件和使用…

Bio-Info每日一题:Rosalind-07-Mendel‘s First Law(孟德尔第一定律 python实现)

&#x1f389; 进入生物信息学的世界&#xff0c;与Rosalind一起探索吧&#xff01;&#x1f9ec; Rosalind是一个在线平台&#xff0c;专为学习和实践生物信息学而设计。该平台提供了一系列循序渐进的编程挑战&#xff0c;帮助用户从基础到高级掌握生物信息学知识。无论你是初…

53. QT插件开发--插件(动态库so)的调用与加载

1. 说明 在使用QT进行插件库的开发之后,还需要将这个插件库程序生成的so动态链接库加载到主程序框架中进行使用,才能达到主程序的模块化开发的效果。在前一篇文章插件创建中介绍了如何在QT中开发插件库,并提供外部接口调用。本篇博客的主要作用是模拟在主程序框架中加载动态…

深度学习Day-20:DenseNet算法实战 乳腺癌识别

&#x1f368; 本文为&#xff1a;[&#x1f517;365天深度学习训练营] 中的学习记录博客 &#x1f356; 原作者&#xff1a;[K同学啊 | 接辅导、项目定制] 一、 基础配置 语言环境&#xff1a;Python3.8编译器选择&#xff1a;Pycharm深度学习环境&#xff1a; torch1.12.1c…

Prometheus PromQL

前言&#xff1a; PromQL是Prometheus的查询语言&#xff0c;用于从Prometheus服务器中获取和处理时间序列数据。它采用了类似SQL的语法&#xff0c;但专门设计用于处理指标数据。PromQL具有灵活的查询能力&#xff0c;可以对指标进行过滤、聚合、计算和变换&#xff0c;以生成…

在表格中渲染轮播图的方法;

效果图&#xff1a;代码&#xff1a; shop()function shop() {// render()$.ajax({url: "http://jingxun.zhbbll.asia/pc/Commodity/shop_list", //要请求的后端地址type: "GET", //数据发送的方式(POST或者GET)dataType: JSON,headers: {token: token,id…

双Token方案实现Token自动续期(基于springboot+vue前后端分离项目)

文章目录 前言一、双Token方案介绍1. 令牌类型与功能2.双Token方案的优点3.实现流程 二、具体实现1.后端实现1.1 jwt工具类1.2 响应工具类1.3 实体类1.4 过滤器1.5 controller1.6 启动类 2、前端实现2.1 登录页面2.2 index页面2.3 请求拦截器和响应拦截器 效果展示 前言 更多j…

Elasticsearch 第一期:基础的基础概念

前言 Elasticsearch&#xff08;弹性搜索&#xff09; &#xff0c;简称为ES&#xff0c; 它是一个开源的高扩展的分布式全文检索引擎&#xff0c;它提供的功能主要分为&#xff1a;实时存储&#xff0c;实时分析搜索&#xff1b;本身扩展性很好&#xff0c;可以扩展到上百台服…

Java并发编程:利用CompletableFuture优化异步任务

在现代Java应用开发中&#xff0c;能够有效地处理异步任务是提升性能和用户体验的关键。Java 8引入的CompletableFuture提供了强大的工具&#xff0c;使得管理复杂的异步逻辑变得更简单。本文将探讨CompletableFuture的功能、用法及其在实际项目中的应用。 ### CompletableFut…

LeetCode 1731, 151, 148

目录 1731. 每位经理的下属员工数量题目链接表要求知识点思路代码 151. 反转字符串中的单词题目链接标签思路代码 148. 排序链表题目链接标签Collections.sort()思路代码 归并排序思路代码 1731. 每位经理的下属员工数量 题目链接 1731. 每位经理的下属员工数量 表 表Emplo…

【星座运势】本周财运分析,巨蟹座财富潜力大开!

大家好&#xff01;今天我们来谈谈巨蟹座本周的财富运势。经过调查和数据分析&#xff0c;我发现巨蟹座这周的财运潜力很大&#xff01;接下来&#xff0c;我将用通俗易懂的语言&#xff0c;通过代码说明&#xff0c;向大家展示巨蟹座的财富运势。 首先&#xff0c;我们需要通…

Java面试题:Redis哨兵模式

哨兵集群(sentinel) 实现主从集群的自动故障恢复 主从节点之间实现数据同步 哨兵的作用 监控 哨兵会不断检查主节点和从节点是否按照预期工作 自动故障恢复 如果主节点故障,哨兵会将从节点提升为主节点 当故障实例回复后以新的主节点为主 通知 哨兵充当Redis客户端的…