Server Setup · 5 min read · Dec 04, 2025

Il Server Perfetto - Mandriva 2009.0 Free (i386) - Pagina 5

10 MySQL (5.0)

Per installare MySQL 5.0, eseguiamo semplicemente:

urpmi MySQL MySQL-client libmysql15-devel

Per impostazione predefinita, il networking non è abilitato nel pacchetto MySQL di Mandriva 2009.0, ma il networking è richiesto da ISPConfig. Possiamo cambiare questo commentando la riga skip-networking in /etc/my.cnf.

vi /etc/my.cnf

| [...] # Non ascoltare affatto su una porta TCP/IP. Questo può essere un miglioramento della sicurezza, # se tutti i processi che devono connettersi a mysqld vengono eseguiti sulla stessa macchina. # Tutte le interazioni con mysqld devono essere effettuate tramite socket Unix o pipe nominate. # Nota che utilizzare questa opzione senza abilitare le pipe nominate su Windows # (tramite l'opzione "enable-named-pipe") renderà mysqld inutile! # #skip-networking [...] |

Dopo, creiamo i collegamenti di avvio del sistema per MySQL…

chkconfig mysqld on

… e lo avviamo:

/etc/init.d/mysqld start

Ora controlla che il networking sia abilitato. Esegui

netstat -tap | grep mysql

L’output dovrebbe apparire così:

[root@server1 var]# netstat -tap | grep mysql  
tcp        0      0 *:mysql-im                     *:*                     LISTEN      3181/mysqlmanager  
tcp        0      0 *:mysql                         *:*                     LISTEN      3190/mysqld  
[root@server1 var]#

Successivamente, esegui

mysqladmin -u root password yourrootsqlpassword  
mysqladmin -h server1.example.com -u root password yourrootsqlpassword

per impostare una password per l’utente root (altrimenti chiunque può accedere al tuo database MySQL!).

11 Postfix Con SMTP-AUTH E TLS; Dovecot

Installa i pacchetti richiesti (Postfix, cyrus-sasl, Dovecot, ecc.) in questo modo:

urpmi cyrus-sasl libsasl2 libsasl2-devel libsasl2-plug-plain libsasl2-plug-anonymous libsasl2-plug-crammd5 libsasl2-plug-digestmd5 libsasl2-plug-gssapi libsasl2-plug-login postfix dovecot

Poi esegui:

postconf -e 'mydestination = /etc/postfix/local-host-names, localhost.$mydomain'  
postconf -e 'smtpd_sasl_local_domain ='  
postconf -e 'smtpd_sasl_auth_enable = yes'  
postconf -e 'smtpd_sasl_security_options = noanonymous'  
postconf -e 'broken_sasl_auth_clients = yes'  
postconf -e 'smtpd_sasl_authenticated_header = yes'  
postconf -e 'smtpd_recipient_restrictions = permit_sasl_authenticated,permit_mynetworks,reject_unauth_destination'  
postconf -e 'inet_interfaces = all'  
postconf -e 'mynetworks = 127.0.0.0/8'  
touch /etc/postfix/local-host-names

Poi impostiamo il nome host nella nostra installazione di Postfix (assicurati di sostituire server1 ed example.com con le tue impostazioni):

postconf -e 'mydomain = example.com'  
postconf -e 'myhostname = server1.$mydomain'

Modifica /etc/sasl2/smtpd.conf. Dovrebbe apparire così:

vi /etc/sasl2/smtpd.conf

| # File di configurazione della libreria SASL per postfix # tutti i parametri sono documentati in: # /usr/share/doc/cyrus-sasl/options.html # I parametri mech_list elencano i meccanismi sasl da utilizzare, # il default è tutti i meccanismi trovati. mech_list: plain login # Per autenticarsi utilizzando il demone saslauthd separato, (ad esempio per # utenti di sistema o ldap). Vedi anche /etc/sysconfig/saslauthd. pwcheck_method: saslauthd saslauthd_path: /var/lib/sasl2/mux # Per autenticarsi contro gli utenti memorizzati in sasldb. #pwcheck_method: auxprop #auxprop_plugin: sasldb #sasldb_path: /var/lib/sasl2/sasl.db |

Il meccanismo di autenticazione predefinito per saslauthd è pam, tuttavia su Mandriva 2009.0 sembra esserci un bug. Quando invii un’email, la prima passa, e non appena provi a inviare una seconda email, saslauthd muore. Puoi trovare messaggi come questo in /var/log/messages:

Oct  9 17:53:42 server1 saslauthd[4460]: server_exit     : master exited: 4460

Ho trovato la seguente soluzione alternativa: apri /etc/sysconfig/saslauthd…

vi /etc/sysconfig/saslauthd

… e cambia SASL_AUTHMECH da pam a shadow:

| # $Id: saslauthd.sysconfig,v 1.1 2001/05/02 10:55:48 wiget Exp $ # Meccanismo di autenticazione (per l'elenco vedere saslauthd -v) SASL_AUTHMECH=shadow # Nome host per il server IMAP remoto (se viene utilizzato il meccanismo di autenticazione rimap) # File di configurazione Ldap (se viene utilizzato il meccanismo di autenticazione ldap) SASL_MECH_OPTIONS= # Opzioni extra (per l'elenco vedere saslauthd -h) SASLAUTHD_OPTS= |

Crea il certificato SSL necessario per TLS:

mkdir /etc/postfix/ssl  
cd /etc/postfix/ssl/  
openssl genrsa -des3 -rand /etc/hosts -out smtpd.key 1024
chmod 600 smtpd.key  
openssl req -new -key smtpd.key -out smtpd.csr
openssl x509 -req -days 3650 -in smtpd.csr -signkey smtpd.key -out smtpd.crt
openssl rsa -in smtpd.key -out smtpd.key.unencrypted
mv -f smtpd.key.unencrypted smtpd.key  
openssl req -new -x509 -extensions v3_ca -keyout cakey.pem -out cacert.pem -days 3650

… e configura Postfix per TLS:

postconf -e 'smtpd_tls_auth_only = no'  
postconf -e 'smtp_use_tls = yes'  
postconf -e 'smtpd_use_tls = yes'  
postconf -e 'smtp_tls_note_starttls_offer = yes'  
postconf -e 'smtpd_tls_key_file = /etc/postfix/ssl/smtpd.key'  
postconf -e 'smtpd_tls_cert_file = /etc/postfix/ssl/smtpd.crt'  
postconf -e 'smtpd_tls_CAfile = /etc/postfix/ssl/cacert.pem'  
postconf -e 'smtpd_tls_loglevel = 1'  
postconf -e 'smtpd_tls_received_header = yes'  
postconf -e 'smtpd_tls_session_cache_timeout = 3600s'  
postconf -e 'tls_random_source = dev:/dev/urandom'

Successivamente dobbiamo configurare Dovecot per servire i protocolli imap, imaps, pop3 e pop3s. Apri /etc/dovecot.conf e regola i seguenti valori:

vi /etc/dovecot.conf

| [...] # Protocolli che vogliamo servire: imap imaps pop3 pop3s # Se vuoi solo utilizzare dovecot-auth, puoi impostarlo su "none". protocols = imap imaps pop3 pop3s [...] disable_plaintext_auth = no [...] pop3_uidl_format = %08Xu%08Xv [...] |

Ora dobbiamo dire al sistema di avviare Dovecot solo dopo che ntpd è stato avviato perché Dovecot non è molto indulgente se l’orario del sistema si sposta all’indietro mentre Dovecot è in esecuzione (vedi http://wiki.dovecot.org/TimeMovedBackwards). Questo potrebbe causare errori come il seguente nel tuo syslog:

Apr 9 19:29:18 server1 dovecot: Il tempo è appena tornato indietro di 17 secondi. Questo potrebbe causare molti problemi, quindi mi ucciderò ora. http://wiki.dovecot.org/TimeMovedBackwards

Sfortunatamente, su Mandriva Dovecot viene avviato prima di ntpd, quindi lo cambiamo in questo modo:

cd /etc/rc3.d  
mv S99ntpd S98ntpd  
mv S54dovecot S99dovecot  
cd /etc/rc4.d  
mv S99ntpd S98ntpd  
mv S54dovecot S99dovecot  
cd /etc/rc5.d  
mv S99ntpd S98ntpd  
mv S54dovecot S99dovecot

Poi creiamo i collegamenti di avvio del sistema per Postfix…

chkconfig postfix on

… e (ri)avviamo Postfix, saslauthd e Dovecot:

/etc/init.d/postfix restart  
/etc/init.d/saslauthd restart  
/etc/init.d/dovecot restart

Per vedere se SMTP-AUTH e TLS funzionano correttamente ora esegui il seguente comando:

telnet localhost 25

Dopo aver stabilito la connessione al tuo server di posta Postfix digita

ehlo localhost

Se vedi le righe

250-STARTTLS

e

250-AUTH PLAIN LOGIN

tutto va bene:

[root@server1 rc5.d]# telnet localhost 25  
Trying 127.0.0.1...  
Connected to localhost.localdomain (127.0.0.1).  
Escape character is '^]'.  
220 server1.example.com ESMTP Postfix (2.5.5) (Mandriva Linux)  
ehlo localhost  
250-server1.example.com  
250-PIPELINING  
250-SIZE 10240000  
250-VRFY  
250-ETRN  
250-STARTTLS  
250-AUTH PLAIN LOGIN  
250-AUTH=PLAIN LOGIN  
250-ENHANCEDSTATUSCODES  
250-8BITMIME  
250 DSN  
quit  
221 2.0.0 Bye  
Connection closed by foreign host.  
[root@server1 rc5.d]#

Digita

quit

per tornare alla shell del sistema.

11.1 Maildir

Dovecot utilizza il formato Maildir (non mbox), quindi se installi ISPConfig sul server, assicurati di abilitare Maildir sotto Management -> Server -> Settings -> Email. ISPConfig eseguirà quindi la configurazione necessaria.

Se non vuoi installare ISPConfig, allora devi configurare Postfix per consegnare le email alla Maildir di un utente (puoi anche farlo se usi ISPConfig - non fa male ;-)):

postconf -e 'home_mailbox = Maildir/'  
postconf -e 'mailbox_command ='  
/etc/init.d/postfix restart
Share: X/Twitter LinkedIn

Ricevi i nuovi post nella tua casella di posta.

Nessuno spam. Disiscriviti in qualsiasi momento.