Accedi
Accedi

Comandi systemctl riavviare, ricaricare e arrestare un servizio

Comandi systemctl riavviare, ricaricare e arrestare un servizio
JC Brian Refugia
Redattore tecnico
Sistema: Linux
11.12.2025
Reading time: 9 min

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

Image4

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.

Sistema: Linux
11.12.2025
Reading time: 9 min

Simili

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
Sistema: Linux

Come copiare file e directory in Linux

Quando inizi a lavorare con Linux, una delle attività essenziali che incontrerai è la gestione dei file. Che tu stia organizzando i tuoi documenti personali, migrando file di sistema o preparando backup completi, sapere come duplicare correttamente i file è fondamentale. Al centro di questo processo c’è il comando cp, uno strumento potente progettato per replicare facilmente file e directory. Questa guida è pensata per aiutarti a padroneggiare il comando cp. Esploreremo tutto: dalla copia di base dei file alla replicazione ricorsiva delle directory, insieme a consigli per preservare i metadati e prevenire la perdita accidentale di dati. Con esempi dettagliati, scenari reali e buone pratiche, acquisirai rapidamente la capacità di usare cp come un professionista di Linux. E se cerchi una soluzione affidabile, performante ed economica per i tuoi flussi di lavoro, Hostman offre opzioni di Hosting VPS Linux, tra cui VPS Debian, VPS Ubuntu e VPS CentOS. Esplorare il comando cp In Linux, il comando cp è il tuo strumento principale per copiare dati. La sua versatilità consente di gestire qualsiasi cosa: dalla copia di un singolo file al mirroring di strutture di directory complesse con sottocartelle annidate. A differenza dei gestori di file grafici, cp funziona interamente da terminale, offrendo un controllo preciso su ogni aspetto del processo di copia. Come funziona Nella sua forma più semplice, cp prende un file (o una directory) di origine e lo duplica in una nuova posizione. La sua flessibilità risiede però nelle opzioni: flag che permettono di modificare il comportamento del comando secondo le tue esigenze. Che si tratti di preservare i permessi, evitare sovrascritture accidentali o copiare interi alberi di directory, cp offre un’opzione per ogni scenario. Struttura di base del comando Il comando cp segue un formato semplice. Ecco la sintassi canonica: cp [options] source destination cp: il comando che avvia la copia. [options]: parametri aggiuntivi (flag) che controllano il comportamento del processo di copia. source: il file o la directory che desideri duplicare. destination: la posizione o il nome del file di destinazione. Questa struttura chiara rende cp un comando apprezzato sia dagli amministratori di sistema sia dagli utenti occasionali. Esplorare le opzioni principali La vera potenza di cp si rivela grazie alle sue numerose opzioni. Ecco alcune delle più utili: Copia ricorsiva (-r o -R): quando hai bisogno di copiare un’intera directory — comprese tutte le sue sottodirectory e i file — l’opzione ricorsiva è indispensabile. Indica a cp di attraversare l’intera struttura. Modalità interattiva (-i): la sicurezza prima di tutto! Questa opzione ti chiede conferma prima di sostituire un file esistente. È fondamentale quando lavori con dati importanti, poiché riduce il rischio di sovrascritture accidentali. Forzare la copia (-f): a volte è necessario ignorare gli avvisi e assicurarsi che il file venga copiato comunque. Questa opzione sostituisce i file esistenti senza chiedere conferma. Usala con cautela. Preservare gli attributi (-p): l’integrità dei file è importante, soprattutto quando si tratta di permessi, timestamp e informazioni sul proprietario. Questa opzione fa sì che la copia conservi tutti questi attributi. Output dettagliato (-v): se vuoi una visione chiara di ciò che sta accadendo durante il processo di copia, questa opzione mostra ogni passaggio nel terminale. È particolarmente utile quando copi molti file o durante il debug di operazioni complesse. Esempi pratici: copiare file Esaminiamo ora alcuni esempi pratici per vedere come queste opzioni si combinano nelle attività quotidiane. Copiare un singolo file Immagina di avere un file chiamato notes.txt e di voler creare una copia di backup nella stessa directory. Ti basta eseguire: cp notes.txt notes_backup.txt Questo comando crea una copia identica chiamata notes_backup.txt. Tuttavia, se esiste già un file con quel nome e vuoi evitare di sovrascriverlo senza conferma, puoi usare: cp -i notes.txt notes_backup.txt L’opzione -i ti assicura che venga richiesta una conferma prima di qualsiasi sovrascrittura. Trasferire file tra directory Se vuoi spostare un file in un’altra posizione, specifica la directory di destinazione. Ad esempio, per copiare report.pdf in una directory chiamata archive, usa: cp report.pdf /home/username/archive/ Assicurati che la directory di destinazione esista già; cp non la crea per te. Se non esiste, puoi crearla prima con il comando mkdir. Copiare più file contemporaneamente A volte potresti dover duplicare più file allo stesso tempo. Per copiare file1.txt, file2.txt e file3.txt in una directory chiamata backup, digita: cp file1.txt file2.txt file3.txt /home/username/backup/ Questo comando gestisce più file in un’unica operazione. Se hai molti file che seguono uno stesso schema — ad esempio tutti i file di log — puoi usare un carattere jolly: cp *.log /home/username/logs/ Questo indica a cp di copiare tutti i file che terminano con .log nella directory logs. Padroneggiare la copia ricorsiva delle directory Spesso il lavoro non riguarda un solo file, ma intere directory. Per copiare directory complete, è necessario usare la copia ricorsiva. Duplicare una directory in modo ricorsivo Supponiamo che tu voglia duplicare i contenuti di un sito web situato in /var/www/html per creare una copia di sicurezza. Il comando sarebbe: cp -r /var/www/html /backup/html_backup Qui, l’opzione -r indica a cp di copiare tutto all’interno di /var/www/html, incluse sottodirectory e file nascosti. Combinare copia ricorsiva e preservazione degli attributi Quando esegui il backup di directory, spesso è fondamentale mantenere permessi, timestamp e altri metadati. In questi casi, combina l’opzione ricorsiva con quella per preservare gli attributi: cp -rp /var/www/html /backup/html_backup Questo comando garantisce che ogni file presente in /var/www/html venga copiato in /backup/html_backup mantenendo tutti i suoi attributi originali. È una soluzione ideale per dati sensibili o configurazioni di sistema. Suggerimenti, trucchi e tecniche avanzate Ora che conosci le basi, esploriamo alcune strategie avanzate e buone pratiche per utilizzare il comando cp in modo ancora più efficace. Combinare le opzioni per una maggiore sicurezza È comune utilizzare più opzioni insieme per adattare il comportamento di cp. Ad esempio, per copiare una directory in modo sicuro preservando gli attributi e richiedendo conferma prima di sovrascrivere file esistenti, puoi usare: cp -rpi /data/source_directory /data/destination_directory Questa potente combinazione garantisce un processo di copia completo e sicuro. Gestire nomi di file con caratteri speciali I nomi dei file in Linux possono contenere spazi o caratteri speciali. Per assicurarti che vengano gestiti correttamente, racchiudili tra virgolette. Ad esempio: cp "My Important Document.txt" "My Important Document Copy.txt" Questo impedisce alla shell di interpretare gli spazi come separatori tra argomenti diversi. Evitare sovrascritture non intenzionali Per operazioni batch o script automatici, potresti voler impedire che file esistenti vengano sovrascritti. L’opzione -n (no-clobber) serve proprio a questo: cp -n *.conf /backup/configs/ Questo comando copia i file di configurazione solo se nel percorso di destinazione non esiste già un file con lo stesso nome. Usare la modalità dettagliata per il debug Quando lavori con un grande volume di file o devi analizzare un’operazione di copia, l’opzione dettagliata (-v) può essere estremamente utile: cp -rv /source/folder /destination/folder La modalità dettagliata mostra ogni file man mano che viene elaborato, offrendoti una visione chiara dell’operazione in corso e facilitando l’individuazione di eventuali problemi. Applicazioni e scenari reali Il comando cp non è utile solo per operazioni occasionali: è uno strumento fondamentale in numerosi contesti professionali. Amministrazione di sistema e backup Gli amministratori di sistema utilizzano spesso cp per creare copie di sicurezza prima di effettuare modifiche critiche alle configurazioni del sistema. Ad esempio: cp -rp /etc /backup/etc_backup Questo comando crea un backup completo della directory /etc, preservando tutte le impostazioni e i permessi di sistema. In caso di errore o guasto, tali backup risultano indispensabili. Migrazione dei dati e trasferimenti tra server Durante lo spostamento di dati tra server o diverse parti di una rete, cp assicura che tutti i file vengano copiati correttamente. Combinato con strumenti come rsync, può offrire soluzioni robuste per la migrazione dei dati. Sviluppo e test Gli sviluppatori duplicano spesso intere directory per creare ambienti di test o copie sandbox dei loro progetti. Che tu stia testando una nuova funzionalità o eseguendo il debug di un problema, copiare l’intero progetto preservando gli attributi può farti risparmiare tempo ed evitare potenziali errori. Buone pratiche per utilizzare cp in modo efficace Verificare i percorsi di destinazione: assicurati sempre che la directory di destinazione esista per evitare errori durante la copia. Usare la modalità interattiva per file critici: quando lavori con dati importanti, l’opzione -i può evitare sovrascritture accidentali richiedendo una conferma. Racchiudere tra virgolette i nomi dei file con spazi: assicurati che eventuali nomi contenenti spazi o caratteri speciali siano racchiusi tra virgolette. Pianificare una strategia di backup: esegui regolarmente backup delle directory essenziali utilizzando le opzioni ricorsive e di preservazione degli attributi. Combinare le opzioni in modo intelligente: usa combinazioni come -r, -p e -v per adattare cp alle tue esigenze, garantendo sicurezza e chiarezza nelle operazioni sui file. Considerazioni finali Il comando cp è un elemento fondamentale della gestione dei file in Linux. La sua semplicità nasconde una notevole potenza grazie alle numerose opzioni disponibili. Padroneggiando cp, non solo ottimizzi il tuo flusso di lavoro, ma proteggi anche i tuoi dati attraverso una gestione attenta degli attributi, copie ricorsive e automazioni ben progettate. Che tu sia un principiante nel mondo Linux o un utente esperto che desidera affinare le proprie competenze, le tecniche e gli esempi presentati in questa guida ti serviranno come riferimento affidabile per le attività di duplicazione dei file. Ricorda di consultare la pagina del manuale (man cp) per informazioni aggiuntive e opzioni avanzate. Sfrutta la versatilità del comando cp e presto scoprirai che gestire file e directory in Linux diventa una seconda natura.
28 November 2025 · 9 min to read
Servizi Webmail

Come inviare email in Linux dalla riga di comando con Sendmail e Mailx

Per chi gestisce server o lavora su attività di automazione, sapere come inviare email dal terminale Linux è essenziale. Questo approccio offre il pieno controllo sulle funzioni di posta elettronica ed elimina la necessità di programmi complessi. È particolarmente utile in scenari in cui velocità e semplicità sono fondamentali. Strumenti comuni come sendmail e mailx vengono spesso utilizzati per inviare messaggi, verificare impostazioni SMTP, automatizzare avvisi e integrarsi con script. Sono semplici ma efficaci — perfetti per informare i team sugli aggiornamenti del server, automatizzare report o testare configurazioni email. Questa guida è pensata per utenti che desiderano gestire la posta direttamente dal terminale. Copre l’installazione degli strumenti essenziali e approfondisce attività avanzate come l’invio di allegati e la configurazione degli strumenti di posta. Perché usare strumenti email da riga di comando? I due strumenti più utilizzati — sendmail e mailx — sono soluzioni affidabili per l’invio della posta in Linux e offrono numerosi vantaggi: Efficienza I client email tradizionali possono essere lenti e pesanti. Questi strumenti permettono invii rapidi e leggeri direttamente dal terminale. Automazione Si integrano facilmente con script shell, processi cron e strumenti di monitoraggio. È possibile automatizzare avvisi e notifiche ricorrenti. Risoluzione problemi SMTP Rendere più semplice il debug delle configurazioni SMTP. Questi comandi offrono visibilità sul processo di consegna e facilitano l’analisi di log ed errori. Flessibilità Che si tratti di inviare avvisi o generare report automatici, sendmail e mailx offrono versatilità per diverse esigenze operative. Prerequisiti Prima di utilizzare questi strumenti email nel Linux terminal, assicurati di avere: Accesso al terminale: in alcuni casi sono richiesti privilegi di root. Un server SMTP: necessario per testare l’invio delle email. Strumenti installati: verifica che sendmail e mailx siano presenti e funzionanti. Configurazione di un server SMTP I server SMTP sono indispensabili per l’invio di email. Esistono due categorie principali: Server SMTP esterni Server SMTP locali Server SMTP esterni Sono server di posta gestiti da provider terzi. Consentono l’invio di email verso destinatari esterni alla rete locale e garantiscono: consegna globale, autenticazione, crittografia, protezione antispam. Esempi Gmail Indirizzo: smtp.gmail.com Porta: 587 (TLS) o 465 (SSL) Outlook Indirizzo: smtp.office365.com Porta: 587 Questi server richiedono autenticazione (username, password o password specifiche app) e una connessione cifrata TLS/SSL. Nota: abbiamo già fornito una guida per configurare server SMTP esterni. Il comando per l’invio tramite Postfix rimane lo stesso: basta configurare le credenziali SMTP e sostituire l’indirizzo email con quello del provider scelto. Server SMTP locali Operano esclusivamente all’interno di una rete interna. Perfetti per: inviare email tra utenti locali (tom@office.local → jerry@office.local), attività di test e sviluppo, comunicazioni interne, ambienti che non richiedono accesso internet per la posta interna. Configurare un server SMTP locale 1. Installare Postfix sudo apt install postfix 2. Modificare la configurazione sudo nano /etc/postfix/main.cf Impostazioni principali: myhostname = mail.office.local mydomain = office.local myorigin = $mydomain inet_interfaces = loopback-only local_recipient_maps = proxy:unix:passwd.byname mydestination = $myhostname, localhost.$mydomain, localhost, $mydomain Riavviare Postfix: sudo systemctl restart postfix 3. Creare utenti di posta sudo adduser linux sudo adduser hostman Crea indirizzi come linux@office.local. Panoramica su sendmail sendmail è uno dei mail transfer agent (MTA) più diffusi in Linux. Funziona con server SMTP per inviare email da sistemi locali o script. Installazione di sendmail Debian/Ubuntu sudo apt install sendmail CentOS/Red Hat sudo yum install sendmail Avvio e abilitazione del servizio sudo systemctl start sendmail sudo systemctl enable sendmail Testare sendmail echo "Testing sendmail setup" | sendmail -v your-email@example.com Verifica dei messaggi ricevuti: mail Installare mailutils se necessario: sudo apt install mailutils Oppure: cat /var/mail/user Configurazione del file sendmail.mc sudo nano /etc/mail/sendmail.mc Esempio: definire il dominio: define(`confDOMAIN_NAME', `your_domain.com')dnl Rigenerare la configurazione: sudo m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf Se compare “permission denied”: sudo sh -c "m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf" Riavviare: sudo systemctl restart sendmail Inviare un’email con sendmail 1. Creare un file nano email.txt Contenuto: Subject: Test Email from Hostman This is a test email sent using sendmail on Linux. 2. Inviare sendmail recipient@example.com < email.txt 3. Verificare mail Inviare allegati con sendmail sendmail non supporta allegati nativamente; bisogna usare uuencode. Installare sharutils: sudo apt install sharutils Invio con allegato: ( echo "Subject: Email with attachment"; uuencode file.txt file.txt ) | sendmail recipient@example.com Verifica: mail Panoramica su mailx mailx è un'applicazione semplice ed efficace per gestire email via terminale. Fa parte del pacchetto mailutils nella maggior parte delle distribuzioni. Installare mailx Debian/Ubuntu sudo apt install mailutils Red Hat sudo yum install mailx Inviare email con mailx echo "This is the body of the email" | mailx -s "Test Email from Mailx" recipient@example.com Inviare allegati con mailx echo "Please find the attached document" | mailx -s "Email with Attachment" -A email.txt recipient@example.com Conclusione Inviare email dalla riga di comando in Linux è un metodo potente per automatizzare comunicazioni, diagnosticare server o testare configurazioni. Con sendmail e mailx, puoi gestire messaggi semplici o configurazioni avanzate con allegati. Questa guida fornisce istruzioni dettagliate per iniziare facilmente e migliorare il tuo flusso di lavoro.
26 November 2025 · 5 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