Debian-swirl.png Versioni Compatibili

Tutte le versioni supportate di Debian

Introduzione

Dopo qualche mese di utilizzo di una Linux box, spesso si notano dei sostanziali rallentamenti. Magari abbiamo passato questi periodi installando e disinstallando applicazioni, provando programmi e configurazioni ed il sistema risente un po' di queste 'esperienze'. In questo HowTo vedremo di analizzare una soluzione molto comoda (sicuramente molto di più di quella classica di formattare e ricominciare da capo) per rimettere in sesto la nostra amata Debian.

Prevenire è meglio che curare

Penso che sia una cosa certa: poter lavorare su un sistema 'pulito' e 'pulibile' è sicuramente più comodo e divertente che su uno 'sporco' e mal gestito, soprattutto quando si tratta di pulizia o di interventi sul sistema! Iniziamo con la rassegna di applicazioni utili.

CheckInstall: deb da sorgenti

Checkinstall è una utilità che permette di creare dei pacchetti Debian partendo da sorgenti. Attenzione, però: non sono pacchetti completi, ma semplicemente aiutano a tenere traccia dei file installati dal programma, facilitando l'aggiornamento e la rimozione dello stesso. Iniziamo con l'installazione:

# apt-get install checkinstall

L'utilizzo è molto semplice ed intuitivo: la configurazione dei sorgenti (./configure --some-options) e la compilazione (make) devono venir svolte, mentre il comando

# make install

deve essere sostituito da:

# checkinstall

Ed il gioco è fatto! Durante l'esecuzione del programma verranno poste alcune domande, ad esempio il tipo di pacchetto (il programma permette di creare pacchetti deb, rpm, tgz (usati da Slackware)). Sono disponibili, opzionalmente, le seguenti direttive (anche se non mi è mai capitato di doverne fare uso):

-y, --default
accetta i valori di default (modalità non interattiva)
--pkgname=name
imposta il nome del pacchetto
--pkgversion=version
imposta la versione
-A, --arch, --pkgarch=arch
imposta l'architettura
--pkgrelease=release
imposta la release version
--pkggroup=group
imposta il gruppo a cui il pacchetto deve appartenere (doc, games, net, ecc)
--pakdir=directory
dove salvare il pacchetto
--maintainer=email_addr
il maintainer del pacchetto
--dpkgflags=flags
eventuali flag da passare a dpkg
--bk
esegue un backup dei file che verranno sovrascritti

Una volta completato il processo, il pacchetto verrà automaticamente installato.

  Nota Bene
Nel file di controllo del pacchetto non vengono segnate eventuali dipendenze, sostituzioni e/o conflitti, in quanto lo scopo di checkinstall è quello di tenere traccia dei file generati, e non di creare un pacchetto Debian ufficiale. Per questo motivo il pacchetto così creato non va redistribuito ma semplicemente utilizzato per uso personale!


Questa è la premessa per poter avere un sistema pulito, senza file 'orfani' che gironzolano per il sistema.

Debfoster

# apt-get install debfoster

Lo scopo di questo programma è di mostrare i pacchetti che non sono installati come dipendenze. Una volta individuato uno di questi pacchetti, verrà mostrata una lista con indicati i pacchetti 'bloccati' da questo.

Output d'esempio:

libxml-libxml-perl is keeping the following 3 packages installed:
libxml-libxml-common-perl libxml-namespacesupport-perl libxml-sax-perl
Keep libxml-libxml-perl? [Ynpsiuqx?], [H]elp:

Ora possiamo scegliere cosa fare:

Y
mantiene il pacchetto installato
n
rimuove il pacchetto segnalato
p
rimuove il pacchetto segnalato e tutti i pacchetti da lui trattenuti
s
salta la domanda
i
visualizza informazioni sul pacchetto
?
uguale a i
u
ripropone la domanda precedente
q
esce senza apportare alcuna modifica
x
esce e rimuove i pacchetti selezionati
h
visualizza la guida ai comandi

Che dire: uno strumento veramente potente!

Quando si procede alla pulizia con questo programma, però, è bene fare attenzione ad alcune cose, che potrebbero generare non pochi problemi:

  • tutte le informazioni mostrate non prendono in considerazione eventuali programmi compilati da sorgenti (con il classico make install o anche con checkinstall);
  • leggere con attenzione le librerie elencate come 'bloccate', in quanto qualche volta potrebbe essere indicata, per esempio, una libreria di sviluppo non necessaria all'esecuzione di altri programmi, ma indispensabile per la compilazione (libncurses5-dev, ad esempio).

Deborphan

# apt-get install deborphan

Questo programma, genera una lista di pacchetti 'orfani'. Per pacchetti 'orfani' indichiamo quelle librerie che non sono più necessarie, in quanto nessun pacchetto installato le indica come dipendenza.

  ATTENZIONE
Se si hanno programmi compilati da sorgente (in modo classico o con checkinstall) le dipendenze di quei pacchetti non saranno controllate, e si potrebbe incorrere in problemi di esecuzione di questi programmi!


Per visualizzare una lista dei pacchetti 'orfani', è sufficiente lanciare il seguente comando:

# deborphan

Di default, Deborphan ricerca i pacchetti 'orfani' solo tra le librerie; in tal senso un'opzione interessante da passare al comando è --libdev, che genera una lista delle librerie di sviluppo (quelle che finiscono con -dev) non necessarie.

Per ottenere invece un elenco che comprenda altri tipi di pacchetti è necessario lanciare il comando con l'opzione --guess-foo sostituendo a foo una tra le seguenti:

  • common: cerca i pacchetti il cui nome termina in "-common";
  • data: effettua la ricerca tra i pacchetti di dati;
  • debug: effettua la ricerca tra le librerie di debug;
  • dev: effettua la ricerca tra le librerie di sviluppo (simile all'opzione --libdevel);
  • doc: effettua la ricerca nei pacchetti della documentazione;
  • dummy: effettua la ricerca nei pacchetti che contengono il termine "dummy" o "transitional" nella loro descrizione breve;
  • kernel: effettua la ricerca sui moduli del kernel;
  • interpreters: ricerca tutti i moduli di interpretazione.

Altre parole chiave da inserire insieme all'opzione --guess si trovano elencate nella pagina di manuale di Deborphan.
Infine, naturalmente:

# deborphan --guess-all

ricercherà pacchetti 'orfani' in tutto il sistema.

Se poi vi interessa sapere in che sezione si trova il pacchetto 'orfano' e la sua dimensione potete aggiungere:

# deborphan -sz --guess-all

Un'altra opzione molto interessante è quella che consente di elencare i file di configurazione dei pacchetti disinstallati rimasti sul sistema:

deborphan --find-config

Altre opzioni di Deborphan che ho trovato interessanti:

-P, --show-priority
mostra la priorità dei pacchetti trovati
-e, --exclude=LIST
esclude i pacchetti elencati in LIST (un elenco separato da virgole)

Per un elenco completo delle opzioni vi invito a leggere la pagina di manuale di Deborphan.

Naturalmente l'output di Deborphan va vagliato con attenzione: solo voi potete sapere se i pacchetti elencati sono realmente inutili. In questo senso vi consiglio di segnarvi, prima di iniziare le "grandi pulizie", le dipendenze dei pacchetti che avete installato manualmente onde evitare di rimuoverle accidentalmente.

È possibile fare in modo che apt-get legga la lista dei pacchetti generata da Deborphan:

# apt-get purge `deborphan`
# apt-get purge `deborphan --libdev`

Il comando "apt-get purge" ha la funzione di rimuovere il pacchetto specificato e anche tutti i suoi file di configurazione.

File di Configurazione

Eliminando i file di configurazione si libera spazio, e si mantiene più pulita la directory /etc.

Con il seguente comando è possibile rimuovere i file di configurazione che sono stati lasciati nel sistema dai pacchetti non rimossi attraverso il comando "apt-get purge" :

# dpkg --purge `dpkg -l | egrep "^rc" | cut -d' ' -f3`

Ecco una breve spiegazione dei comandi:

dpkg --purge listapacchetti

rimuove i file di configurazione di tutti i pacchetti indicati. La lista dei pacchetti è ottenuta tramite il comando:

`dpkg -l | egrep "^rc" | cut -d' ' -f3`

che genera la lista dei pacchetti che non sono stati rimossi completamente (cioè dei quali non sono stati rimossi i file di configurazione).

In dettaglio:

dpkg -l
Elenca tutti i pacchetti disponibili
egrep "^rc"
Visualizza solo quelle righe che iniziano con "rc" (stato che indica che il pacchetto è stato rimosso ma sono ancora presenti i file di configurazione)
cut -d' ' -f3
Restituisce solo il nome del pacchetto: usa come delimitatore (-d) di campo uno spazio (' ') e prende solo il terzo campo (-f3, field in inglese).

Stesso risultato si ottiene con l'uso di aptitude:

# aptitude search ~c

trova i pacchetti che hanno lasciato il file di configurazione nel sistema quando sono stati rimossi.

# aptitude purge ~c

elimina tali file, previa conferma.

Se si vuol cancellare i file di configurazione dei pacchetti rimossi ad ogni avvio del sistema, basta eseguire con i permessi di root:

# crontab -e

e inserire le righe:

PATH=/bin:/usr/bin:/sbin
@reboot if [ `dpkg -l | egrep "^rc" | wc -l` -ne 0 ]; then dpkg --purge `dpkg -l | egrep "^rc" | cut -d' ' -f3` >/dev/null 2>&1; fi 

bisogna aggiungere necessariamente la directory /sbin alla variabile PATH e questa deve precedere ogni cronjob.
Guardare a riguardo la guida su Cron.

Localepurge: rimuoviamo le lingue che non ci interessano

Spesso, non sono necessarie tutte le lingue che un pacchetto installa. Di solito ne bastano due:

  • en (lingua generale)
  • it_IT (lingua dell'utilizzatore)

Tra le varianti va scelta quella che viene usata nel proprio sistema (nel mio caso it_IT@euro e en_US)

Quindi, quelle superflue, potrebbero essere tranquillamente rimosse, liberando un po' di spazio inutile!

  NOTA BENE
è sconsigliabile rimuovere l'inglese, in quanto è la lingua di default del sistema:

per evitare problemi, lasciarla installata.


Durante la configurazione di localepurge, verrà mostrata una lista di lingue, dalla quale vanno selezionate solo quelle che non devono venir rimosse.

Una volta fatto questo, lanciando il comando

# localepurge

verranno eliminati i locales non necessari.

Ma non solo: quando si installerà uno o più pacchetti, a questi verranno automaticamente rimosse le localizzazioni che non erano state selezionate durante la configurazione del programma.

  Nota
Per chi avesse dei dubbi sull'efficacia di questa utility, ecco le statistiche sullo spazio liberato sul mio laptop (su cui ho appena installato Debian):
knio:/home/maxer# localepurge
localepurge: Disk space freed in /usr/share/locale: 109778K
localepurge: Disk space freed in /usr/share/man: 1940K

Total disk space freed by localepurge: 111718K


La cache di apt-get

Quando scarichiamo un pacchetto, questo viene salvato in /var/cache/apt/archives in modo da rendere più veloce il download in caso di reinstallazione, oppure per permettere il salvataggio di questi su CD (in caso di connessioni lente o a consumo). Però, ovviamente, occupano spazio e (dopo qualche mese, tra aggiornamenti e nuove installazioni) si arriva facilmente ad 1Gb di dati. Per risolvere questo problema, lo stesso apt-get ha due comandi che gestiscono la pulizia della cache dei pacchetti scaricati: clean e autoclean.

Vediamoli in dettaglio:

apt-get clean
rimuove tutti i pacchetti contenuti in /var/cache/apt/archives e in /var/cache/apt/archives/partial (eccezione fatta per i file di lock)
apt-get autoclean
come clean, tranne per il fatto che rimuove solo i pacchetti che non possono più essere scaricati (perché rimossi dai repository Debian, versioni non può scaricabili in quanto 'superate').
Se si utilizza clean, questo comando non è necessario.

La cache di apt-build

Le stesse cosa dette per apt-get, valgono anche per apt-build. Questo, infatti, una volta scaricati e compilati i sorgenti, non li rimuove. È facile, così, occupare svariati gigabyte di spazio con i sorgenti (e i risultati della compilazione). Apt-build, per effettuare pulizia, ci mette a disposizione 3 azioni:

clean-sources
esegue un debian/rules clean, che rimuove solamente i prodotti della compilazione;
clean-build
rimuove il contenuto della directory /var/cache/apt-build/build/ che contiene i sorgenti dei pacchetti ricompilati;
clean-repository
rimuove il contenuto della directory /var/cache/apt-build/repository/ che contiene i pacchetti ricompilati tramite apt-build.

Log

Può accadere che i file di log presenti nella directory /var/log/ crescano a dismisura e occupino più spazio del necessario.
Questo comportamento è dovuto alla mancata rotazione dei log attraverso logrotate che causa il loro inserimento in un unico file mai ruotato. Infatti lo script che si occupa della rotazione dei file è richiamato da Cron in base alle impostazioni presenti in /etc/crontab :

25 6 * * *  root    test -x /usr/sbin/anacron || ( cd / && run-parts --report /etc/cron.daily )

Come si vede, lo script /etc/cron.daily/logrotate viene eseguito da Cron ogni giorno alle 6.25 di mattina, quando la macchina, almeno per chi ne fa un uso di tipo desktop o lavorativo, è spenta.
Per eliminare questo problema, installare Anacron e aspettare la normale rotazione dei file di log, in quanto il file di dimensioni eccessive verrà all'inizio compresso ma non cancellato.

Home

Nella vostra home vengono creati i file di configurazione delle applicazioni, niente di strano, se non fosse che occupano spazio, spesso senza un motivo. Per vedere questi file/directory di configurazione è necessario usare ls seguito dalla opzione -a:

$ ls -a

Così facendo verranno mostrati i file/directory nascosti (in pratica quelli con un punto davanti). Una volta individuati dei file/directory appartenenti ad applicazioni non più presenti nel sistema, o non più utilizzate dal vostro utente, si può procedere alla rimozione con:

$ rm -r nome_dir

dove l'opzione -r indica la ricorsività dell'operazione, consentendo l'eliminazione delle directory.

Conclusione

Queste sono le tecniche base per tenere pulita una Debian, e sono quelle che applico regolarmente alle mie macchine... Diciamo che si avvertono i miglioramenti, soprattutto per quanto riguarda lo spazio risparmiato, che permette una miglior organizzazione dei dati all'interno del disco.




Guida scritta da: MaXeR   Debianized 20%
Estesa da:
MadameZou 20:36, 8 feb 2010 (CET)
S3v 15:44, 9 ott 2012 (CEST) (Log)
Verificata da:

Verificare ed estendere la guida | Cos'è una guida Debianized