Treballant amb les capacitats de Linux

Introducció

Les capacitats de Linux són atributs especials del nucli Linux que atorguen als processos i als executables binaris privilegis específics que normalment es reserven per als processos l'ID d'usuari efectiu és 0 (l'usuari root, i només l'usuari root, té l'UID 0).

Aquest article explicarà algunes de les capacitats disponibles, els seus usos i com configurar-les i eliminar-les. Tingueu en compte que la configuració de les capacitats dels executables pot posar en perill la seguretat del vostre sistema. Per tant, hauríeu de considerar provar en un sistema que no sigui de producció abans d'implementar les capacitats en producció.

Requisits previs

  • Un sistema Linux al qual teniu accés root (ja sigui mitjançant l'usuari root o un usuari amb accés sudo).

Explicació

Essencialment, l'objectiu de les capacitats és dividir el poder de l'"arrel" en privilegis específics, de manera que si s'explota un procés o binari que té una o més capacitats, el dany potencial es limita en comparació amb el mateix procés que s'executa com a root.

Les capacitats es poden configurar en processos i fitxers executables. Un procés resultant de l'execució d'un fitxer pot obtenir les capacitats d'aquest fitxer.

Les capacitats implementades a Linux són nombroses, i moltes s'han afegit des del seu llançament original. Alguns d'ells són els següents:

  • CAP_CHOWN: feu canvis a l'identificador d'usuari i a l'identificador de grup dels fitxers
  • CAP_DAC_OVERRIDE: Anul·lar DAC (Control d'accés discrecional). Per exemple, vto ignorar les comprovacions de permisos de lectura/escriptura/execució.
  • CAP_KILL: Omet les comprovacions de permisos per enviar senyals als processos.
  • CAP_SYS_NICE: Augmenta la bondat dels processos ( una explicació de la bondat es pot trobar aquí )
  • CAP_SYS_TIME: Configura el sistema i el rellotge de maquinari en temps real

Per a la llista completa, executeu man 7 capabilities.

Les capacitats s'assignen en conjunts, és a dir, "permès", "heretable", "efectiu" i "ambient" per als fils, i "permès", "heretable" i "efectiu" per als fitxers. Aquests conjunts defineixen diferents comportaments complexos, la seva explicació completa està fora de l'abast d'aquest article.

Quan configurem les capacitats al fitxer, gairebé sempre utilitzarem "permès" i "efectiu", per exemple CAP_DAC_OVERRIDE+ep. Observeu el +ep, que denota els conjunts esmentats anteriorment.

Treballant amb capacitats de fitxers

Paquets obligatoris

Hi ha dues eines principals, getcapi setcapque poden visualitzar i establir aquests atributs respectivament.

  • A Debian i Ubuntu, aquestes eines les proporciona el libcap2-binpaquet, que es pot instal·lar amb:apt install libcap2-bin
  • A CentOS i Fedora, el libcappaquet és necessari:yum install libcap
  • A Arch Linux, també els proporcionen libcap:pacman -S libcap

Capacitats de lectura

Per veure si un fitxer té alguna capacitat establerta, simplement podeu executar getcap /full/path/to/binary, per exemple:

 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

Si voleu esbrinar quines capacitats ja estan configurades al vostre sistema, podeu cercar tot el vostre sistema de fitxers de manera recursiva amb l'ordre següent:

getcap -r /

A causa del fet que els sistemes de fitxers virtuals (com ara /proc) no admeten aquestes operacions, l'ordre anterior produirà milers d'errors, de manera que per obtenir una sortida més neta, utilitzeu el següent:

getcap -r / 2>/dev/null 

Assignació i eliminació de capacitats

Per establir una capacitat concreta en un fitxer, utilitzeu setcap "capability_string" /path/to/file.

Per eliminar totes les capacitats d'un fitxer, utilitzeu setcap -r /path/to/file.

Per a la demostració, crearem un fitxer en blanc al directori actual, li donarem una capacitat i l'eliminarem. Comenceu amb el següent:

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

La segona ordre no produeix cap sortida, és a dir, aquest fitxer no té cap capacitat.

A continuació, configureu una capacitat per al fitxer:

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

"CAP_CHOWN+ep" es va utilitzar com a exemple, però qualsevol altre es pot assignar d'aquesta manera.

Ara, elimina totes les capacitats de testfile:

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

De nou, no hi haurà sortida, perquè "CAP_CHOWN+ep" s'ha eliminat.

Conclusió

Les capacitats tenen molts usos potencials i poden ajudar a reforçar la seguretat dels vostres sistemes. Si utilitzeu el bit SUID als vostres executables, penseu a substituir-lo per la capacitat específica necessària.


Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Introducció Lets Encrypt és un servei d'autoritat de certificació que ofereix certificats TLS/SSL gratuïts. El procés d'instal·lació està simplificat per Certbot,

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Utilitzeu un sistema diferent? Què és Tekkit Classic? Tekkit Classic és un modpack per al joc que tothom coneix i estima; Minecraft. Conté algunes de la ver

Creació dun bloc Jekyll a Ubuntu 16.04

Creació dun bloc Jekyll a Ubuntu 16.04

Utilitzeu un sistema diferent? Jekyll és una gran alternativa a WordPress per crear blocs o compartir contingut. No requereix cap base de dades i és molt fàcil

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Utilitzeu un sistema diferent? Si compres un servidor Debian, sempre hauríeu de tenir els darrers pedaços i actualitzacions de seguretat, tant si esteu adormit com si no.

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

PHP i els paquets relacionats són els components més utilitzats quan es desplega un servidor web. En aquest article, aprendrem a configurar PHP 7.0 o PHP 7.1 o

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Tres panells de control de servidor gratuïts (instal·lació ràpida)

Tres panells de control de servidor gratuïts (instal·lació ràpida)

1. Virtualmin/Webmin Virtualmin és un tauler de control d'allotjament web potent i flexible per a sistemes Linux i UNIX basat en la coneguda base web de codi obert

Configuració duna aplicació Yii a Ubuntu 14.04

Configuració duna aplicació Yii a Ubuntu 14.04

Yii és un framework PHP que permet desenvolupar aplicacions de manera més ràpida i senzilla. Instal·lar Yii a Ubuntu és senzill, ja que aprendràs exactament

Ús de Screen a Ubuntu 14.04

Ús de Screen a Ubuntu 14.04

Screen és una aplicació que permet l'ús múltiple de sessions de terminal dins d'una finestra. Això us permet simular diverses finestres de terminal on es fa

Configura el teu propi servidor DNS a Debian/Ubuntu

Configura el teu propi servidor DNS a Debian/Ubuntu

Aquest tutorial explica com configurar un servidor DNS amb Bind9 a Debian o Ubuntu. Al llarg de l'article, substituïu el vostre-nom-domini.com en conseqüència. Al th

Ús de Logrotate per gestionar fitxers de registre

Ús de Logrotate per gestionar fitxers de registre

Introducció Logrotate és una utilitat Linux que simplifica l'administració dels fitxers de registre. Normalment s'executa un cop al dia mitjançant un treball cron i gestiona la base de registres

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Configura Red5 Media Server a Ubuntu 16.04

Configura Red5 Media Server a Ubuntu 16.04

Utilitzeu un sistema diferent? Red5 és un servidor multimèdia de codi obert implementat a Java que us permet executar aplicacions Flash multiusuari com ara la transmissió en directe.

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

En aquest article, veurem com compilar i instal·lar la línia principal de Nginx des de les fonts oficials de Nginx amb el mòdul PageSpeed, que us permet

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Vanilla Forum a Ubuntu 16.04

Com instal·lar Vanilla Forum a Ubuntu 16.04

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació