Arbeide med Linux-funksjoner

Introduksjon

Linux-funksjoner er spesielle attributter i Linux-kjernen som gir prosesser og binære kjørbare spesifikke rettigheter som normalt er reservert for prosesser hvis effektive bruker-ID er 0 (rotbrukeren, og bare rotbrukeren, har UID 0).

Denne artikkelen vil forklare noen av de tilgjengelige funksjonene, deres bruk og hvordan du setter og fjerner dem. Vær oppmerksom på at innstilling av funksjoner på kjørbare filer har potensial til å kompromittere sikkerheten til systemet ditt. Som sådan bør du vurdere å teste på et ikke-produksjonssystem før du implementerer funksjoner i produksjonen.

Forutsetninger

  • Et Linux-system som du har root-tilgang på (enten via root-brukeren eller en bruker med sudo-tilgang).

Forklaring

I hovedsak er målet med kapasiteter å dele opp kraften til 'root' i spesifikke privilegier, slik at hvis en prosess eller binær som har en eller flere muligheter blir utnyttet, er den potensielle skaden begrenset sammenlignet med den samme prosessen som kjører som root.

Muligheter kan settes på prosesser og kjørbare filer. En prosess som er et resultat av kjøringen av en fil kan få egenskapene til den filen.

Mulighetene implementert på Linux er mange, og mange har blitt lagt til siden den opprinnelige utgivelsen. Noen av dem er som følger:

  • CAP_CHOWN: Gjør endringer i bruker-ID og gruppe-ID for filer
  • CAP_DAC_OVERRIDE: Overstyr DAC (Discretionary Access Control). For eksempel, vto omgå lese/skrive/utføre tillatelseskontroller.
  • CAP_KILL: Omgå tillatelsessjekker for å sende signaler til prosesser.
  • CAP_SYS_NICE: Øk hyggeligheten til prosesser ( En forklaring på hyggeligheten finner du her )
  • CAP_SYS_TIME: Still inn systemet og sanntids maskinvareklokke

For hele listen, kjør man 7 capabilities.

Egenskaper tildeles i sett, nemlig "tillatt", "arvelig", "effektiv" og "omgivende" for tråder, og "tillatt", "arvelig" og "effektiv" for filer. Disse settene definerer forskjellig kompleks atferd, deres fulle forklaring er utenfor rammen av denne artikkelen.

Når vi angir funksjoner på fil, vil vi nesten alltid bruke "tillatt" og "effektiv", for eksempel CAP_DAC_OVERRIDE+ep. Legg merke til +ep, som angir de nevnte settene.

Arbeid med filfunksjoner

Nødvendige pakker

Det er to hovedverktøy, getcapog setcapsom kan henholdsvis se og angi disse attributtene.

  • På Debian og Ubuntu leveres disse verktøyene av libcap2-binpakken, som kan installeres med:apt install libcap2-bin
  • På CentOS og Fedora er libcappakken nødvendig:yum install libcap
  • På Arch Linux leveres de libcapogså av:pacman -S libcap

Leseevner

For å se om en fil har noen funksjonssett, kan du ganske enkelt kjøre getcap /full/path/to/binary, for eksempel:

 root@demo:~# getcap /usr/bin/ping
 /usr/bin/ping = cap_net_raw+ep
 root@demo:~# getcap /usr/bin/rcp
 /usr/bin/rcp = cap_net_bind_service+ep

Hvis du vil finne ut hvilke funksjoner som allerede er satt på systemet ditt, kan du søke i hele filsystemet ditt rekursivt med følgende kommando:

getcap -r /

På grunn av det faktum at virtuelle filsystemer (som /proc) ikke støtter disse operasjonene, vil kommandoen ovenfor produsere tusenvis av feil, så for en renere utgang, bruk følgende:

getcap -r / 2>/dev/null 

Tilordne og fjerne evner

For å angi en bestemt funksjon på en fil, bruk setcap "capability_string" /path/to/file.

For å fjerne alle funksjoner fra en fil, bruk setcap -r /path/to/file.

For demonstrasjon lager vi en tom fil i gjeldende katalog, gir den en mulighet og fjerner den. Start med følgende:

root@demo:~# touch testfile
root@demo:~# getcap testfile

Den andre kommandoen produserer ingen utdata, noe som betyr at denne filen ikke har noen funksjon.

Deretter setter du en funksjon for filen:

root@demo:~# setcap "CAP_CHOWN+ep" testfile
root@demo:~# getcap testfile
testfile = cap_chown+ep

"CAP_CHOWN+ep" ble brukt som et eksempel, men alle andre kan tilordnes på denne måten.

Fjern nå alle funksjoner fra testfile:

root@demo:~# setcap -r testfile
root@demo:~# getcap testfile

Igjen, det blir ingen utgang, fordi "CAP_CHOWN+ep" ble fjernet.

Konklusjon

Funksjoner har mange potensielle bruksområder og kan bidra til å stramme sikkerheten til systemene dine. Hvis du bruker SUID-biten på de kjørbare filene dine, bør du vurdere å erstatte den med den spesifikke egenskapen som trengs.


Sett opp Cacti på Debian Jessie

Sett opp Cacti på Debian Jessie

Introduksjon Cacti er et åpen kildekode overvåkings- og grafverktøy som er fullt basert på RRD-data. Gjennom Cacti kan du overvåke nesten alle typer enheter

Installer Lets Encrypt SSL på ett-klikks WordPress-appen

Installer Lets Encrypt SSL på ett-klikks WordPress-appen

Introduksjon Lets Encrypt er en sertifikatmyndighetstjeneste som tilbyr gratis TLS/SSL-sertifikater. Installasjonsprosessen forenkles av Certbot,

Sett opp iRedMail på Debian Wheezy

Sett opp iRedMail på Debian Wheezy

Bruker du et annet system? Denne opplæringen viser deg hvordan du installerer gruppevaren iRedMail på en ny installasjon av Debian Wheezy. Du bør bruke en serve

Tre gratis serverkontrollpaneler (hurtiginstallasjon)

Tre gratis serverkontrollpaneler (hurtiginstallasjon)

1. Virtualmin/Webmin Virtualmin er et kraftig og fleksibelt kontrollpanel for webhotell for Linux- og UNIX-systemer basert på den velkjente Open Source-nettbasen

Bruker skjermen på Ubuntu 14.04

Bruker skjermen på Ubuntu 14.04

Skjerm er et program som tillater flere bruk av terminalsesjoner i ett vindu. Dette lar deg simulere flere terminalvinduer der det ma

Bruke Logrotate til å administrere loggfiler

Bruke Logrotate til å administrere loggfiler

Introduksjon Logrotate er et Linux-verktøy som forenkler administrasjonen av loggfiler. Den kjører vanligvis en gang om dagen via en cron-jobb, og administrerer loggbasen

Installere Docker CE på Ubuntu 16.04

Installere Docker CE på Ubuntu 16.04

Bruker du et annet system? Docker er en applikasjon som gjør det mulig å distribuere programmer som kjøres som containere. Det ble skrevet i det populære Go-programmet

Patching the Dirty Cow Exploit på CentOS

Patching the Dirty Cow Exploit på CentOS

Hva er Dirty Cow (CVE-2016-5195)? Dirty Cow-sårbarheten utnyttes gjennom hvordan Linux behandler kode. Det gjør det mulig for en uprivilegert bruker å gai

Konfigurer en ikke-rootbruker med Sudo Access på Ubuntu

Konfigurer en ikke-rootbruker med Sudo Access på Ubuntu

Å ha bare én bruker, som er root, kan være farlig. Så la oss fikse det. Vultr gir oss friheten til å gjøre som vi vil med våre brukere og våre servere

Installer Adminer på Debian/Ubuntu

Installer Adminer på Debian/Ubuntu

Adminer er et lett alternativ til phpMyAdmin. Til sammenligning er dens totale pakkestørrelse 400 KB, mot 4,2 MB med phpMyAdmin. I motsetning til phpMyAdmin, som

Slik installerer du GoAccess på Ubuntu 16.04

Slik installerer du GoAccess på Ubuntu 16.04

Bruker du et annet system? GoAccess er en åpen kildekode-nettlogganalysator. Du kan bruke den til analyse av logger på sanntidsbasis i enten terminalen eller

Konfigurer Nagios på Ubuntu: Del 1 - Nagios Server

Konfigurer Nagios på Ubuntu: Del 1 - Nagios Server

Denne artikkelen er en del av en todelt serie om installasjon og konfigurering av Nagios på Ubuntu 14.04. Del 1: Nagios Server Del 2: Oversikt over ekstern vert Nagio

Sett opp tidssone og NTP på Ubuntu 14.04

Sett opp tidssone og NTP på Ubuntu 14.04

Vultr-servere kan ikke distribueres med tidssonen/datoen/klokkeslettet du trenger på serveren din. Heldigvis kan vi manuelt stille inn tidssonen for å forhindre problemer

Distribuer en Meteor-applikasjon på Ubuntu

Distribuer en Meteor-applikasjon på Ubuntu

Denne artikkelen vil lede deg gjennom distribusjon av Meteor-appen din til en Vultr VPS som kjører Ubuntu 14.04. Det kan også fungere på andre Linux-distribusjoner (forsøk a

Arbeide med Linux-funksjoner

Arbeide med Linux-funksjoner

Introduksjon Linux-funksjoner er spesielle attributter i Linux-kjernen som gir prosesser og binære kjørbare spesifikke rettigheter som er normale

Høy tilgjengelighet ved bruk av privat nettverk på Ubuntu 16.04 med Keepalived

Høy tilgjengelighet ved bruk av privat nettverk på Ubuntu 16.04 med Keepalived

Noen arkitekturer med høy tilgjengelighet krever en flytende IP-adresse. Denne funksjonaliteten er tilgjengelig på Vultr-plattformen når privat nettverk har bee

Konfigurer bare SFTP-brukerkontoer på Ubuntu 14

Konfigurer bare SFTP-brukerkontoer på Ubuntu 14

Innledning Enkelte scenarier krever at du oppretter brukere med lese- og skrivetilgang til en enkelt katalog kun via FTP. Denne artikkelen vil vise deg hvordan t

Slik konfigurerer du Node.js Persistent-applikasjoner på Ubuntu 16.04

Slik konfigurerer du Node.js Persistent-applikasjoner på Ubuntu 16.04

Node.js-applikasjoner er populære for deres evne til å skalere. Å kjøre flere samtidige prosesser på flere servere gir lavere ventetid og større oppetid

Overvåk enhetene dine ved å bruke LibreNMS på Ubuntu 16.04

Overvåk enhetene dine ved å bruke LibreNMS på Ubuntu 16.04

Bruker du et annet system? LibreNMS er et fullverdig åpen kildekode-nettverksovervåkingssystem. Den bruker SNMP for å hente data fra forskjellige enheter. En variant

Stopp DHCP fra å endre resolv.conf

Stopp DHCP fra å endre resolv.conf

For DHCP-brukere kan det hende du trenger å redigere /etc/resolv.conf for å bruke andre navneservere. Deretter, etter en periode (eller etter en omstart av systemet)

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.

DDOS-angrep: en kort oversikt

DDOS-angrep: en kort oversikt

Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.

Har du noen gang lurt på hvordan hackere tjener penger?

Har du noen gang lurt på hvordan hackere tjener penger?

Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.

Evolusjon av datalagring – infografikk

Evolusjon av datalagring – infografikk

Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.

Funksjonaliteter til Big Data Reference Architecture Layers

Funksjonaliteter til Big Data Reference Architecture Layers

Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer