Accedi
Accedi

Che cos’è un daemon in informatica?

Che cos’è un daemon in informatica?
Hostman Team
Redattore tecnico
Sistema: Linux
23.10.2025
Reading time: 9 min

Il termine daemon deriva dalla mitologia greca antica, dove indicava un essere immateriale che influenzava il mondo umano.

In informatica, soprattutto nei sistemi operativi di tipo UNIX, un daemon è un processo in background che si esegue senza interazione diretta con l’utente. Non dipende da un terminale o da un’interfaccia grafica e in genere viene avviato all’avvio del sistema o in determinate condizioni.

Che cos’è un daemon

La funzione principale di un daemon è fornire servizi specifici ad altri processi o utenti. Ad esempio, un daemon può restare in ascolto su porte di rete in attesa di connessioni, monitorare eventi di sistema e rispondere quando vengono soddisfatte determinate condizioni, gestire attività pianificate (come cron), inviare e-mail (sendmail) e molto altro.

In Windows, l’equivalente più vicino a un daemon è un servizio (Service). La differenza principale risiede nel modo in cui vengono avviati, registrati, gestiti e configurati all’interno del sistema operativo. Tuttavia, lo scopo è lo stesso: garantire il funzionamento continuo in background di determinate funzioni o servizi.

Caratteristiche principali di un daemon

  • Esecuzione in background: gli utenti di solito non vedono un’interfaccia del daemon; non scrive sull’output standard (o lo reindirizza ai log) e non richiede input da tastiera.

  • Autonomo: un daemon viene avviato all’avvio del sistema, quando viene richiamato da un sistema di init (come systemd), oppure manualmente dall’utente (tramite script, cron, ecc.).

  • Lunga durata: idealmente un daemon viene eseguito indefinitamente, a meno che non si verifichi un errore critico o riceva un segnale di arresto esplicito.

  • Isolato: di solito viene eseguito sotto un account utente o gruppo separato per ridurre i privilegi, rendendo i servizi più sicuri e facili da gestire.

  • Logging: invece di utilizzare input/output standard, i daemon registrano le informazioni in file di log o nel logger di sistema (journald, syslog, ecc.), utile per il debug e la diagnostica.

Daemon in Linux

Storicamente, quasi tutte le attività di sistema in background in Linux sono implementate come daemon. Il sistema operativo ne include decine, ciascuno con una funzione specifica. Ecco alcuni esempi:

  • sshd (Secure Shell Daemon): resta in ascolto sulla porta 22 (per impostazione predefinita) e consente agli utenti remoti di connettersi tramite SSH crittografato. Senza sshd, l’accesso remoto al terminale sarebbe quasi impossibile.

  • cron: un daemon di pianificazione dei lavori. Controlla le voci del crontab ed esegue script o comandi secondo una pianificazione, come la pulizia dei log, l’invio di report o i controlli di sistema.

  • syslogd / rsyslog / journald: daemon di registrazione del sistema che raccolgono messaggi dal kernel, dalle utility, da altri daemon e applicazioni, e li salvano nei file di log o nel journal.

  • NetworkManager o Wicd: daemon che gestiscono le impostazioni di rete — automatizzano connessioni a reti cablate/wireless, switch, configurazioni VPN e altro.

Questi daemon vengono avviati all’avvio del sistema e registrati nel gestore dei servizi (ad esempio systemd). Restano in esecuzione fino allo spegnimento o riavvio del sistema. Gli utenti interagiscono con essi indirettamente — tramite file di configurazione, comandi da terminale (service, systemctl) o richieste di rete (se il daemon fornisce un’interfaccia HTTP/S, SSH o simile).

Come creare e gestire daemon

Per implementare un daemon, segui questi passaggi:

  1. Creazione del processo (fork): il processo padre chiama fork() e continua l’esecuzione del codice del daemon nel processo figlio.

  2. Scollegamento dal terminale di controllo (setsid): per evitare interferenze dell’utente (ad esempio la chiusura del terminale), il daemon chiama setsid() per avviare una nuova sessione e diventarne il leader.

  3. Chiusura dei descrittori di input/output standard: poiché il daemon non deve scrivere sullo schermo o attendere input, stdin, stdout e stderr vengono chiusi o reindirizzati ai file di log.

  4. Gestione dei segnali e logging: per supportare uno spegnimento pulito o il ricaricamento della configurazione, il daemon deve gestire i segnali (SIGTERM, SIGHUP, ecc.). La registrazione viene generalmente effettuata tramite syslog o file.

  5. Ciclo principale: dopo l’inizializzazione, il daemon entra nel ciclo principale: attende eventi, li gestisce e ripete finché non viene interrotto.

Vediamo come creare un daemon su Ubuntu 22.04 utilizzando un server cloud Hostman.

1. Scrivere il daemon in C

Crea un file chiamato mydaemon.c e inserisci il seguente codice:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <syslog.h>

int main() {
    // Aprire syslog
    openlog("mydaemon", LOG_PID, LOG_DAEMON);
    syslog(LOG_NOTICE, "Daemon started");

    // Ciclo infinito principale
    while (1) {
        // Attività in background: monitoraggio, gestione code, ecc.
        syslog(LOG_NOTICE, "Performing task...");
        sleep(60);
    }

    // Se il ciclo termina
    syslog(LOG_NOTICE, "Daemon stopped");
    closelog();

    return 0;
}

2. Compilare il programma

Aggiorna prima i pacchetti:

sudo apt update && sudo apt upgrade

Installa il compilatore GCC se non è già installato:

sudo apt install gcc

Compila il daemon:

gcc mydaemon.c -o mydaemon

3. Spostare l’eseguibile

Sposta il file binario in /usr/local/bin/, una posizione standard per le utility personalizzate:

mv mydaemon /usr/local/bin/mydaemon

4. Creare un servizio systemd

Crea un file di unità chiamato mydaemon.service:

sudo nano /etc/systemd/system/mydaemon.service

Inserisci il seguente contenuto:

[Unit]
Description=My Daemon
After=network.target

[Service]
Type=simple
ExecStart=/usr/local/bin/mydaemon
Restart=on-failure

[Install]
WantedBy=multi-user.target

Spiegazione dei campi:

  • Description: descrizione mostrata in systemctl status.
  • After=network.target: assicura che il daemon si avvii dopo che la rete è attiva.
  • Type=simple: il daemon non crea sottoprocessi, si esegue come un unico processo.
  • ExecStart: percorso all’eseguibile del daemon.
  • Restart=on-failure: riavvio automatico in caso di errore del daemon.
  • WantedBy=multi-user.target: fa partire il servizio nell’ambiente multiutente standard.

5. Avviare e monitorare il daemon

sudo systemctl daemon-reload          # Ricaricare la configurazione di systemd
sudo systemctl start mydaemon         # Avviare il daemon
sudo systemctl status mydaemon        # Verificare lo stato

Se tutto funziona, lo stato mostrerà active. Per visualizzare i log:

journalctl -u mydaemon.service -e

Esempi di utilizzo dei daemon

  • Server web

Il loro compito è restare in ascolto su una porta di rete (di solito 80 o 443), accettare richieste HTTP/HTTPS, generare una risposta (una pagina HTML, dati JSON, ecc.) e restituire il risultato al client. Nella maggior parte dei casi, un server web si avvia con il sistema e rimane in esecuzione fino allo spegnimento o a un comando di stop (es. systemctl stop nginx).

  • Daemon di database

MySQL/MariaDB, PostgreSQL, MongoDB — tutti questi sono daemon. Si avviano con il sistema e continuano a funzionare in background, accettando richieste da applicazioni client o servizi web. Questi daemon registrano l’attività, supportano la configurazione tramite file e sono gestiti con strumenti dedicati (o systemd).

  • Pianificatori di attività (cron, atd)

Il daemon cron controlla la tabella di pianificazione (crontab) ed esegue programmi negli orari o intervalli specificati dall’utente. Ciò consente di automatizzare backup, aggiornamenti di sistema, controlli di integrità e molte altre attività di routine.

atd è un daemon simile, ma esegue le attività solo una volta in un momento specifico (a differenza di cron, che le esegue periodicamente).

  • Servizi di accesso e controllo (sshd, xrdp)

sshd (Secure Shell Daemon) fornisce accesso remoto tramite il protocollo SSH. xrdp abilita connessioni desktop remote utilizzando il protocollo RDP. Agisce come daemon che ascolta le connessioni di rete su una porta specifica.

  • Daemon del sistema di init (systemd, init, Upstart)

Nei sistemi moderni, il ruolo del “daemon principale” è svolto da systemd (che sostituisce il vecchio sistema SysV init). systemd è il primo processo che parte dopo il kernel ed è responsabile dell’avvio e della gestione di tutti gli altri servizi e processi. Li avvia in parallelo e gestisce le loro dipendenze. In breve, systemd è esso stesso un daemon che “orchestra” tutti gli altri del sistema.

Vantaggi e svantaggi dei daemon

Vantaggi:

  • Automazione: i daemon permettono di automatizzare il comportamento del sistema — dalla risposta alle richieste di rete alla pianificazione di attività — senza intervento dell’utente.

  • Isolamento: l’esecuzione sotto account o gruppi separati e il distacco dal terminale aumentano la sicurezza, limitando i danni potenziali in caso di compromissione.

  • Funzionamento continuo: un daemon può continuare a fornire servizi (come un server web) senza interruzioni anche se l’utente si disconnette o chiude la console.

  • Gestibilità: Linux fornisce strumenti di sistema (es. systemd, script di init) per gestire centralmente tutti i daemon: avvio, arresto, riavvio e registrazione.

Svantaggi:

  • Complessità di debug: poiché i daemon funzionano in background e non mostrano output su console, il debug richiede log dettagliati e configurazioni più complesse (flag di debug, tracciamento, ecc.).

  • Rischi di sicurezza: se un daemon viene eseguito con privilegi elevati (ad esempio come root), una vulnerabilità può compromettere l’intero sistema. È consigliabile eseguirli con privilegi limitati.

  • Gestione delle dipendenze: alcuni daemon possono fallire se, ad esempio, necessitano dell’accesso alla rete prima che questa sia disponibile. I moderni sistemi di init risolvono questo problema, ma con i vecchi script SysV init era comune.

  • Maggior consumo di risorse: qualsiasi processo in esecuzione continua consuma risorse di sistema (memoria, CPU). Un numero eccessivo di daemon può ridurre le prestazioni, soprattutto su sistemi con risorse limitate.

Conclusione

I daemon sono una parte fondamentale dell’architettura dei sistemi operativi Linux, offrendo ampie capacità di automazione e servizi in background. Consentono agli amministratori di configurare in modo flessibile operazioni di rete, attività pianificate, logging, sistemi di sicurezza e molti altri componenti.

Scrivere un proprio daemon richiede la comprensione di processi, segnali, chiamate di sistema e particolare attenzione alla registrazione e alla sicurezza.

I moderni sistemi di init (in particolare systemd) hanno semplificato la gestione dei daemon e la logica dei servizi, rendendo la creazione di servizi personalizzati più strutturata e flessibile. Tuttavia, rimane un campo complesso che richiede progettazione accurata, debug e manutenzione costante.

Se cerchi una soluzione affidabile, performante ed economica per i tuoi flussi di lavoro, Hostman offre opzioni di Hosting VPS Linux, tra cui Debian VPS, Ubuntu VPS e VPS CentOS.

Sistema: Linux
23.10.2025
Reading time: 9 min

Simili

Sistema: Linux

Creazione di collegamenti simbolici in Linux: un tutorial passo dopo passo

I symlink, noti anche come collegamenti simbolici, sono simili ai collegamenti rapidi nel mondo Linux. Consentono di creare un nuovo nome (o collegamento) che punta a un altro file, una directory o qualsiasi oggetto all’interno del file system. Il loro principale vantaggio consiste nel ridurre la ridondanza, evitando la necessità di avere più copie dello stesso file. Quando si utilizza un symlink, le modifiche apportate al file originale si riflettono automaticamente su tutti i suoi collegamenti simbolici. Questo elimina la necessità di aggiornare manualmente più copie. Inoltre, i symlink offrono un modo flessibile per gestire le autorizzazioni di accesso. Ad esempio, diversi utenti con directory che puntano a sottoinsiemi di file possono limitare la visibilità oltre quanto consentito dalle autorizzazioni standard del file system. In sostanza, i symlink sono indispensabili per un’efficiente gestione e organizzazione dei file, semplificando gli aggiornamenti e il controllo degli accessi in sistemi complessi. Requisiti Per seguire questo tutorial, avrai bisogno di: Un server cloud, una macchina virtuale o un computer con un sistema operativo Linux. Su Hostman puoi distribuire un server con Ubuntu, CentOS o Debian in meno di un minuto. Creazione di collegamenti simbolici con il comando ln Il comando ln viene utilizzato per creare collegamenti simbolici in Linux. Segui questi passaggi: Apri una finestra del terminale. Vai nella directory in cui desideri creare il collegamento simbolico. Utilizza la seguente sintassi per creare un symlink: ln -s /path/to/source /path/to/symlink Sostituisci /path/to/source con il percorso reale del file o della directory da collegare e /path/to/symlink con il nome o la posizione desiderata del collegamento simbolico. Comprendere le opzioni del comando ln Il comando ln offre varie opzioni per personalizzare la creazione dei symlink:  -s: Crea un collegamento simbolico.  -f: Sovrascrive un symlink esistente.  -n: Considera le destinazioni del symlink come file normali. Esplora queste opzioni in base alle tue esigenze di collegamento. Creazione di collegamenti simbolici a file Per creare un symlink a un file, utilizza il comando ln con l’opzione -s. Ecco un esempio di come creare un collegamento simbolico a un file usando il comando ln. Il seguente comando crea un collegamento simbolico chiamato symlink_file nella directory corrente, puntando al file /path/to/file: ln -s /path/to/file /path/to/symlink_file Sostituisci /path/to/file con il percorso reale del file e /path/to/symlink_file con il nome desiderato del symlink. In questo esempio, il percorso del file è assoluto. È anche possibile creare un collegamento simbolico utilizzando un percorso relativo. Tuttavia, tieni presente che per far funzionare correttamente il symlink, qualsiasi processo che vi accede deve prima impostare la directory di lavoro corretta; in caso contrario, il collegamento potrebbe risultare non funzionante. Creazione di collegamenti simbolici a directory Puoi utilizzare il comando ln per creare un collegamento simbolico che punti a una directory. Ad esempio, il seguente comando crea un collegamento simbolico chiamato symlink_directory nella directory corrente, che punta alla directory /path/to/directory: ln -s /path/to/directory /path/to/symlink_directory Questo comando crea un collegamento simbolico chiamato symlink_directory nella tua posizione attuale, collegandolo alla directory /path/to/directory. Sovrascrivere forzatamente un collegamento simbolico Puoi utilizzare l’opzione -f con il comando ln. Ad esempio, se il percorso in un symlink è errato a causa di un errore di digitazione o se la destinazione è stata spostata, puoi aggiornare il collegamento in questo modo: ln -sf /path/to/new-reference-dir symlink_directory L’uso dell’opzione -f garantisce che il contenuto del vecchio symlink venga sostituito dalla nuova destinazione. Rimuove inoltre automaticamente eventuali file o symlink in conflitto. Se provi a creare un symlink senza l’opzione -f e il nome del symlink è già in uso, il comando non verrà eseguito. Verifica dei collegamenti simbolici Puoi visualizzare il contenuto di un symlink utilizzando il comando ls -l in Linux: ls -l symlink_directory L’output mostrerà il symlink e la sua destinazione: symlink_file -> /path/to/reference_file Qui, symlink_file è il nome del collegamento simbolico e punta al file /path/to/reference_file. ls -l /path/to/symlink L’output mostrerà il symlink e la sua destinazione. Buone pratiche per i collegamenti simbolici Usa nomi descrittivi per i collegamenti simbolici. Evita collegamenti circolari per prevenire malfunzionamenti del sistema. Aggiorna i symlink se cambia la posizione della destinazione. Casi d’uso dei collegamenti simbolici Gestione dei file di configurazione: Collegare file di configurazione tra sistemi. Controllo versione: Collegare simbolicamente librerie comuni per progetti di sviluppo. Backup dei dati: Creare symlink verso directory di backup. Problemi potenziali e risoluzione degli errori Problemi di autorizzazioni: Assicurati che le autorizzazioni appropriate siano impostate per la sorgente e il symlink. Collegamenti interrotti: Aggiorna i symlink se i file di destinazione vengono spostati o eliminati. Collegamenti tra filesystem: I symlink potrebbero non funzionare tra filesystem diversi. Conclusione I symlink sono preziosi per ottimizzare la gestione dei file e la manutenzione del sistema. Semplificano gli aggiornamenti tra più applicazioni che condividono un file comune, riducendo la complessità della manutenzione. Offrono inoltre un’alternativa a directory come /etc, che spesso richiedono accesso root per modificare i file. Gli sviluppatori trovano i symlink utili per passare senza problemi tra file di test locali e versioni di produzione. Seguendo questo tutorial, hai imparato a creare collegamenti simbolici in Linux. Sfrutta i symlink per una gestione efficiente dei file e una maggiore personalizzazione.
15 December 2025 · 5 min to read
Sistema: Linux

Comandi systemctl riavviare, ricaricare e arrestare un servizio

Per i sistemi operativi Linux, systemctl è un gestore di sistema e servizi utilizzato principalmente per amministrare i servizi e le loro configurazioni. Fa parte di systemd, che gestisce anche altre funzioni a livello di sistema, la gestione dei processi e l’avvio del sistema. Mantenere un sistema affidabile ed efficiente richiede la conoscenza della gestione dei servizi. I comandi restart, reload e stop sono tra i più importanti; ognuno svolge una funzione specifica nella gestione dei servizi. Questo tutorial illustra nel dettaglio questi comandi, la loro sintassi, i casi d’uso e include esempi pratici per aiutare gli utenti a comprenderli e a gestire i sistemi in modo più efficace. Comprendere la gestione dei servizi con systemctl La maggior parte delle moderne distribuzioni Linux utilizza systemctl come strumento principale per la gestione dei servizi di sistema, una componente essenziale per mantenere un ambiente Linux stabile. systemctl, parte della suite systemd, aiuta gli amministratori ad abilitare, disabilitare, monitorare e controllare i servizi. Padroneggiare systemctl può migliorare la reattività, le prestazioni e l’affidabilità del sistema. Un servizio — o un insieme di processi che operano in background per fornire funzionalità di sistema come rete, condivisione file o hosting di applicazioni — è definito servizio nel contesto Linux. Sebbene questi servizi possano essere gestiti manualmente, in genere vengono avviati automaticamente all’avvio del sistema. I servizi critici, come server web, database e strumenti di rete, devono essere gestiti correttamente per garantirne la disponibilità e il funzionamento efficiente. Gli amministratori di sistema possono ridurre i tempi di inattività ricaricando o riavviando i servizi tramite i comandi systemctl, senza interferire con le attività generali del sistema. Garantire che i servizi siano disponibili dopo un riavvio è possibile tramite i comandi enable/disable che automatizzano l’avvio dei servizi. Monitorare lo stato dei servizi e i log permette di diagnosticare rapidamente eventuali problemi. Grazie alla sua versatilità, systemctl è uno strumento essenziale per la gestione dei servizi in qualsiasi sistema Linux. Avviare un servizio con systemctl Avviare un servizio in Linux con systemctl è un’operazione semplice ma essenziale per controllare diversi processi in background, come server web, database o servizi di rete. Un servizio deve essere avviato dall’utente e autorizzato a svolgere la sua funzione prevista. Per avviare un servizio, utilizza il seguente comando. sudo systemctl start <nome_del_servizio> Dove: sudo: concede i privilegi amministrativi necessari per avviare il servizio. systemctl: il comando Linux utilizzato per gestire i servizi. start: il comando che comunica al sistema di avviare il servizio. <nome_del_servizio>: il nome del servizio (ad esempio apache2, nginx, ssh ecc.) che l’utente desidera avviare. Esempio: sudo systemctl start apache2 Questo comando indica al servizio Apache di avviarsi. Se il servizio era già in esecuzione, non si noterà alcun effetto. Se invece non era attivo, il comando lo avvierà. Riavviare un servizio con systemctl Per gli amministratori di sistema Linux, riavviare un servizio utilizzando systemctl è fondamentale, poiché il servizio viene prima interrotto e poi avviato nuovamente. Questo è particolarmente utile durante la risoluzione di problemi o dopo modifiche alla configurazione o aggiornamenti software. Riavviare un servizio garantisce che utilizzi la configurazione o il codice più recente. Usa il seguente comando per riavviare un servizio. sudo systemctl restart <nome_del_servizio> Esempio: sudo systemctl restart apache2 Questo comando interrompe il servizio Apache e poi lo riavvia. È particolarmente utile se sono state apportate modifiche al file di configurazione e si desidera applicarle. Riavviare un servizio può aiutare a risolvere problemi temporanei o liberare risorse. Se un servizio non funziona correttamente, spesso il riavvio è sufficiente per risolvere il problema. Ricaricare la configurazione di un servizio con systemctl In Linux, un servizio può applicare nuove modifiche alla configurazione senza essere completamente interrotto e riavviato, utilizzando il comando di ricaricamento di systemctl. Questo è particolarmente utile quando vengono apportate piccole modifiche alla configurazione e non si desidera interrompere il funzionamento del servizio. Usa il seguente comando per ricaricare un servizio. sudo systemctl reload <nome_del_servizio> Esempio: sudo systemctl reload apache2 Questo comando applica le modifiche apportate al file di configurazione di Apache senza riavviare completamente il server, riducendo al minimo le interruzioni per gli utenti. Il ricaricamento è un’opzione più delicata rispetto al riavvio, poiché non interrompe le connessioni attive né i processi in esecuzione. Arrestare i servizi con systemctl Esegui il seguente comando per arrestare un servizio in esecuzione. Se un servizio è configurato per avviarsi automaticamente all’avvio del sistema, arrestarlo interromperà solo le operazioni correnti, ma non impedirà il suo riavvio al successivo riavvio del sistema. Questo semplice comando systemctl stop consente agli utenti di terminare i processi senza influire sul comportamento del servizio durante l’avvio. sudo systemctl stop <nome_del_servizio> Esempio: sudo systemctl stop apache2 Verificare lo stato dei servizi con systemctl Monitorare e verificare che i servizi funzionino correttamente è una delle attività più importanti nell’amministrazione di sistemi Linux. Con il comando systemctl è possibile visualizzare informazioni dettagliate sullo stato di un servizio, come se è attivo, inattivo o se ha riscontrato problemi. Dopo aver riavviato o ricaricato un servizio, verificarne lo stato consente di confermare che sia tornato operativo come previsto. Usa il seguente comando per visualizzare lo stato corrente di un servizio. sudo systemctl status <nome_del_servizio> Esempio: sudo systemctl status apache2 Il comando status fornisce informazioni dettagliate sul servizio, che solitamente includono: Active State:  indica se il servizio è in esecuzione (active), fermo o in errore. Loaded State:  indica se il file di unità (file di configurazione) del servizio è caricato in memoria. Main PID:  mostra l’ID del processo principale del servizio. Recent Logs: mostra le voci di registro più recenti relative al servizio, utili per la diagnosi dei problemi. Risoluzione dei problemi comuni Possono verificarsi diversi problemi durante la gestione dei servizi Linux con systemctl, tra cui arresti imprevisti, errori di avvio o problemi di configurazione. Risolvere questi problemi in modo efficace è essenziale per mantenere prestazioni e stabilità del sistema. Di seguito sono riportati i problemi più comuni e i passaggi di risoluzione corrispondenti. Il comando sudo systemctl start restituisce un errore o non avvia il servizio come previsto. Per ottenere informazioni dettagliate sulla causa del problema, esegui sudo systemctl status <nome_del_servizio>. Utilizza journalctl per visualizzare i log di sistema relativi al servizio e identificare eventuali problemi sottostanti. Il comando systemctl status mostra la causa dell’errore. Cerca righe come "Main PID exited" o "Job for <nome_del_servizio> failed" per comprendere il problema. Spesso il riavvio del servizio può risolvere problemi temporanei. Un servizio non si avvia automaticamente dopo il riavvio del sistema. Assicurati che il servizio sia configurato per avviarsi automaticamente. Esegui il comando sudo systemctl is-enabled. Se non è abilitato, abilitalo con systemctl enable <nome_del_servizio>. Il servizio non si avvia o non esegue determinate azioni a causa di errori di autorizzazione. Verifica che il servizio disponga delle autorizzazioni necessarie per accedere ai file e alle directory richiesti. Ad esempio, i server web devono poter leggere i file di configurazione e le cartelle del sito. Verifica inoltre che il servizio venga eseguito con l’utente o il gruppo corretto. Alcuni servizi devono essere eseguiti da un utente specifico indicato nel file di unità. Il servizio si avvia con una configurazione errata o le modifiche apportate al file di unità non vengono applicate. Esegui sudo systemctl daemon-reload dopo aver modificato un file di unità per ricaricare la gestione di systemd. Assicurati che il file di unità corrisponda alla configurazione prevista e che si trovi in /lib/systemd/system/ o /etc/systemd/system/. Queste procedure di risoluzione dei problemi possono aiutarti a correggere la maggior parte dei problemi comuni legati ai servizi gestiti tramite systemctl in Linux. La stabilità e la buona salute del sistema possono essere mantenute controllando regolarmente i log e lo stato dei servizi. Conclusione In conclusione, gli amministratori di sistema devono conoscere bene l’utilizzo di systemctl per gestire i servizi su Linux. Questo strumento offre una vasta gamma di funzionalità avanzate per controllare, monitorare e risolvere i problemi dei servizi in modo efficiente. Comprendere i comandi fondamentali — tra cui ricaricare, arrestare, riavviare e verificare lo stato dei servizi — consente di garantire che le funzioni essenziali del sistema operino senza difficoltà. Che si tratti di servizi di rete, database o server web, sapere come usare systemctl permette di mantenere un ambiente Linux stabile ed efficiente. Inoltre, la capacità di affrontare problemi comuni come servizi malfunzionanti, errori di autorizzazione o problemi di configurazione contribuisce a ridurre i tempi di inattività e a preservare l’affidabilità del sistema. L’integrazione di systemctl con journalctl consente un’analisi completa dei log, facilitando una diagnosi e una risoluzione dei problemi rapide. Puoi provare il nostro affidabile VPS Linux per i tuoi progetti.
11 December 2025 · 9 min to read
Sistema: Linux

Come elencare gli utenti in Linux

L’amministrazione e la sicurezza di un sistema Linux richiedono un monitoraggio e una gestione attenta degli utenti. Sapere chi sta utilizzando il sistema e quali azioni sta eseguendo è fondamentale per mantenere sicurezza ed efficienza su server e computer Linux. Questa guida illustra diversi metodi per verificare gli utenti in Linux, sia tramite terminale che tramite interfaccia grafica (in particolare Gnome). Le tecniche descritte aiutano a ottenere informazioni sui profili utente, sulle loro attività, sulla cronologia degli accessi e altro ancora. Esistono vari modi per elencare gli account utente. Di seguito mostriamo come accedere alla lista degli utenti Linux tramite terminale o interfaccia grafica. Terminale In questa sezione analizziamo i metodi per visualizzare gli utenti Linux tramite riga di comando. File /etc/passwd Il file /etc/passwd contiene informazioni su tutti gli utenti registrati nel sistema. Ogni riga rappresenta un account utente e include: nome utente, password (indicata come x), UID, GID, informazioni GECOS, directory home e shell di login. Per visualizzare il contenuto del file: cat /etc/passwd Puoi anche modificarlo usando un editor di testo come nano o vim. Se utilizzi un server cloud Hostman con un utente non amministratore, il file potrebbe avere un aspetto simile a questo: (Esempio visivo nel documento originale) Le password non sono memorizzate qui, ma nel file /etc/shadow, per motivi di sicurezza. Per mostrare solo i nomi degli utenti: sed 's/:.*//' /etc/passwd Comando who Il comando who mostra la lista degli utenti attivi, includendo: nome utente terminale utilizzato data e ora del login indirizzo IP (se disponibile) who Per elencare solamente i nomi degli utenti attualmente collegati: users Differenza: who → informazioni dettagliate users → semplice elenco degli utenti connessi Comando w Il comando w fornisce una panoramica dettagliata degli utenti attivi, mostrando: cosa stanno facendo l’ora del login la durata della sessione il carico del sistema Esegui: w Comando last Il comando last mostra la cronologia degli accessi degli utenti, incluse data, ora e provenienza delle connessioni. È utile per monitorare attività sospette o comportamenti anomali. last Comando lastlog Il comando lastlog visualizza l’ultimo accesso per ogni utente: lastlog Interfaccia grafica Per chi preferisce usare strumenti grafici, ecco come visualizzare gli utenti in sistemi Linux con ambiente Gnome. Strumenti simili non sono più supportati in KDE Plasma. Gnome offre almeno due modi per accedere alla lista utenti. Menu “Utenti” Apri Impostazioni dal menu di sistema. Seleziona la scheda Utenti. Fai clic su Sblocca nell’angolo in alto a destra (ti verrà chiesta la password). Nella parte superiore vedrai l’elenco degli utenti; sotto troverai i dettagli e le impostazioni dell’account selezionato. Utility “Utenti” aggiuntiva È possibile installare lo strumento aggiuntivo gnome-system-tools: sudo apt install gnome-system-tools (Su altre distribuzioni: dnf per Fedora, pacman per Arch, ecc.) Dopo l’installazione: Apri la ricerca del sistema. Digita Utenti. Avvia l’utility appena installata. Potrai visualizzare e modificare: gli account esistenti il tipo di account la password altri parametri avanzati Riepilogo Per elencare gli utenti via terminale: /etc/passwd — contiene informazioni sugli account who — mostra gli utenti attivi con dettagli w — visualizza attività attuali e stato del sistema last — cronologia degli accessi lastlog — ultimo login per ogni utente Per sistemi Linux con Gnome: menu Utenti utility gnome-system-tools Controllare chi accede al tuo sistema e quali operazioni esegue permette di individuare rapidamente problemi e migliorare la gestione complessiva del sistema. Usa il metodo più adatto alle tue esigenze.
11 December 2025 · 4 min to read

Hai domande,
commenti o dubbi?

I nostri professionisti sono disponibili per assisterti in ogni momento,
che tu abbia bisogno di aiuto o non sappia da dove iniziare.
Inviaci un'email
Hostman's Support