table of contents
- buster-backports 4.10.0-1~bpo10+1
- testing 4.10.0-1
- unstable 4.10.0-1
GETPRIORITY(2) | Linux Programmeurs Handleiding | GETPRIORITY(2) |
NAAM¶
getpriority, setpriority - krijg/zet programma in-rooster prioriteitSAMENVATTING¶
#include <sys/time.h>#include <sys/resource.h>
int getpriority(int welk, id_t
wie);
int setpriority(int welk, id_t wie, int
prio);
BESCHRIJVING¶
De in-rooster prioriteit van het proces, proces groep of gebruiker aangeduid door welk en wie wordt verkregen met de getpriority aanroep en wordt gezet met de setpriority aanroep.Welk is één van PRIO_PROCESS, PRIO_PGRP of PRIO_USER en who wordt geïnterpreteerd afhankelijk van welk (een proces identificeerder voor PRIO_PROCESS, proces groep identificeerder voor PRIO_PGRP, en een gebruiker ID voor PRIO_USER). Een nul waarde van wie duidt het huidige proces, proces groep of gebruiker aan.
Het prio argument is een waarde in het interval van -20 tot 19 (zie OPMERKINGEN hieronder), met -20 zijnde de hoogste prioriteit en 19 de laagste prioriteit. Pogingen om een prioriteit buiten het interval in te stellen worden stilzwijgend beperkt tot het interval. De standaard prioriteit is 0; lagere waarden geven een proces een hogere inroostering prioriteit.
De getpriority() aanroep geeft de hoogste prioriteit (laagste genummerde waarde) die één van de opgegeven processen geniet. De setpriority aanroep zet de prioriteiten van alle opgegeven processen naar de opgegeven waarde.
Traditioneel kon alleen een geprivilegieerd proces de prioriteit waarde verlagen (m.a.w. een hogere prioriteit instellen). Echter vanaf Linux 2.6.12 kan een niet-geprivilegieerd proces de prioriteit van een doel proces verlagen als dat een bruikbare RLIMIT_NICE zachte limiet heeft; zie getrlimit(2) voor details.
EIND WAARDE¶
Bij succes geeft setpriority de prioriteit van de aanroepende thread terug, en dat kan een negatief getal zijn. Bij een fout geeft het -1 terug en zet errno op de fout aan te geven. Omdat een succesvolle aanroep van getpriority() legitiem de waarde -1 kan teruggeven, is het nodig om errno te wissen vóór de aanroep, vervolgens nadien errno te controleren en bepalen of -1 een fout is of een legitieme waarde.setpriority geeft 0 terug bij succes. Bij een fout geeft het -1 terug en zet errno om de fout aan te geven.
FOUTEN¶
- EINVAL
- which was niet een van PRIO_PROCESS, PRIO_PGRP of PRIO_USER.
- ESRCH
- Geen proces gevonden dat de welk en who opgegeven waardes gebruikt.
In aanvulling op de bovenstaande fouten hierboven zal setpriority() falen als:
- EACCES
- De aanroeper probeerde een lagere prioriteit in te stellen (m.a.w. een hogere proces prioriteit), maar had niet het vereiste privilege (op Linux: had niet de CAP_SYS_NICE capaciteit).
- EPERM
- Een proces werd gevonden, maar nog zijn effectieve gebruiker ID kwam niet overeen met ofwel de effectieve of echte gebruiker ID van de aanroeper, en was niet gerechtigd (op Linux: had niet de CAP_SYS_NICE capaciteit). Maar zie OPMERKINGEN hieronder.
VOLDOET AAN¶
POSIX.1-2001, POSIX.1-2008, SVr4, 4.4BSD (deze functie aanroepen verschenen voor het eerst in 4.2BSD).OPMERKINGEN¶
Voor verdere details over de prioriteit waarde, zie sched(7).Opmerkinge: de toevoeging van het "autogroup" kenmerk in Linux 2.6.38 betekent dat de prioriteit waarde niet langer zijn traditioneel effect in veel omstandigheden heeft. Voor details, zie sched(7).
Een kind aangemaakt door fork(2) erft de prioriteit van zijn ouder. De prioriteit wordt doorgegeven langs execve(2).
De details van de conditie voor EPERM zijn afhankelijk van het systeem. Bovenstaande beschrijving is wat POSIX.1-2001 zegt en lijkt gevolgd te worden op alle System V-achtige systemen. Linux kernels voor 2.6.12 vereisten dat het echte of effectieve gebruiker ID van de aanroeper overeen kwamen met de echte gebruiker van het proces wie (in plaats van het effectieve gebruiker ID). Linux 2.6.12 en later vereiste dat het effectieve gebruiker ID van de aanroeper overeen kwam met het echte of effectieve gebruiker ID van het proces wie. Alle BSD-achtige systemen (SunOS 4.1.3, Ultrix 4.2, 4.3BSD, FreeBSD 4.3, OpenBSD-2.5,...) gedragen zich op dezelfde manier als Linux 2.6.12 en later.
Het aanroepen van <sys/time.h> is tegenwoordig niet nodig, maar verhoogd overdraagbaarheid. (Inderdaad, <sys/resource.h> gedefinieerd de rusage structure met velden van het type struct timeval gedefinieerd in <sys/time.h>.)
C library/kernel verschillen¶
In de kernel worden de prioriteit waarden gerepresenteerd gebruik makend van het interval 40...1 (omdat negatieve waarden fout codes zijn) en dit zijn de waarden gebruikt door de setpriority() en getpriority() systeem aanroepen. De glibc omwikkel functies voor deze systeem aanroepen handelen de vertaling tussen de gebruiker-omgeving en kernel representaties van de prioriteit waarde af volgens de formule unice = 20 - knice. (Daarom komt het kernel 40...1 interval overeen met het bereik -20...19 zoals gezien door de gebruiker.)BUGS¶
Volgens POSIX, is de prioriteit waarde een per-proces instelling. Echter onder de huidige Linux/NPTL implementatie van de POSIX threads, is de prioriteit waarde een per-thread attribute: verschillende threads in hetzelfde proces kunnen verschillende prioriteiten hebben. Overdraagbare applicaties moeten vermijden te vertrouwen op Linux gedrag, omdat dit in de toekomst aangepast kan worden aan de standaarden.ZIE OOK¶
nice(1), renice(1), fork(2), capabilities(7), sched(7)Documentation/scheduler/sched-nice-design.txt in de Linux kernel bron code (vanaf Linux 2.6.23)
COLOFON¶
Deze pagina is onderdeel van release 5.04 van het Linux man-pages-project. Een beschrijving van het project, informatie over het melden van bugs en de nieuwste versie van deze pagina zijn op https://www.kernel.org/doc/man-pages/ te vinden.VERTALING¶
De Nederlandse vertaling van deze handleiding is geschreven door Jos Boersema <joshb@xs4all.nl>, Mario Blättermann <mario.blaettermann@gmail.com> en Luc Castermans <luc.castermans@gmail.com>Deze vertaling is vrije documentatie; lees de GNU General Public License Version 3 of later over de Copyright-voorwaarden. Er is geen AANSPRAKELIJKHEID.
Indien U fouten in de vertaling van deze handleiding zou vinden, stuur een e-mail naar debian-l10n-dutch@lists.debian.org.
15 september 2017 | Linux |