Introduzione
Cosa è un "server LAMP"?
Nonostante molti di voi sperano che sia qualcosa di commestibile ahimè le vostra speranze stanno per crollare.. (per la cronaca.. non ha nemmeno a che fare con l'illuminazione della vostra scrivania).
Un server LAMP è quello che comunemente viene chiamato Webserver e consiste nell'installazione di software per la visualizzazione di pagine web e gestione dinamica di database; nello specifico LAMP sta per Linux, Apache, MySQL and PHP il che ci da un'idea su quali sono i software che servono per la realizzazione di server di questo tipo.
Linux bhè... è GNU/Linux... leggendo il resto del blog capirete da soli di che si tratta!
Apache è un daemon ovvero un programma che gira in background e serve per supportare connessioni di tipo HTTP ((HyperText Transfer Protocol)) che sarebbe il protocollo che generalmente si utilizza per la navigazione su internet e ci permette di vedere sul nostro Browser le pagine HTML ((HyperText Markup Language)) avete presente quella estensione che a volte si vede alla fine dell'URL?
PHP ha una definizione che viene detta ricorsiva perché nella stessa definizione viene ripetuto il termine PHP ed infatti sta per "PHP Hypertext Preprocessor" e consente ai webmaster di creare webapplications e pagine dinamiche in quanto è un vero e proprio linguaggio di programmazione (volendo anche ad aggetti) che viene interpretato dal motore Zend.
MySQL è il DataBase ovvero una specie di BancaDati più nello specifico è un software che ci permette di amministrare agevolmente dati disposti in tabelle tramite l'esecuzione di query.
Ingredienti
1.Debian 4.0 (ETCH)
2.Un editor di testo da linea di comando visto che probabilmente ci lavoreremo da remoto (consiglio vivamente VIM)
3.Un po' di pazienza
Installazione dell'ambiente
Passiamo al sodo.
Verifichiamo il contenuto di /etc/apt/sources.list e vediamo se sono presenti i seguenti mirror:
##ETCH (Stable)
deb http://ftp.it.debian.org/debian/ etch main contrib non-free
deb-src http://ftp.it.debian.org/debian/ etch main contrib non-free
##SECURITY UPDATES (Etch)
deb http://security.debian.org/ etch/updates main contrib non-free
deb-src http://security.debian.org/ etch/updates main contrib non-free
e diamo un belaptitude update
e poiaptitude upgrade
Da root (ormai tutti sapete chi è root vero?) digitiamo:apt-get install apache2 apache2-mpm-prefork php5-mysql mysql-server php5 libapache2-mod-php5 php5-cgi php5-gd php5-cli phpmyadmin
Durante la fase di installazione apt vi chiederà delle cose come:
Should MySQL start on boot? (Il server MySQL deve essere lanciato in fase di avvio?)
Io consiglio di selezionare SI in modo da avere il database sempre funzionante nonostante il server venga riavviato.
Facendo ciò la nostra cara Debian GNU/Linux box installerà Apache2, PHP5, MySQL5 e vari moduli per Apache e PHP per interfacciarsi tra di loro e col database.
Se pensate che sia finita qui (nonostante gran parte del lavoro sia gi?à stato fatto) vi sbagliate di grosso! Adesso comincia il bello!
Configurazione
Configurazione di Apache2
Aprite il file /etc/apache2/apache2.conf con VIM scrivendo sempre da root:vim /etc/apache2/apache2.conf
e digitate "I" per passare alla modalità di inserimento del testo e scrivete nell'ultima riga:ServerName localhost
per scrivere i cambiamenti ed uscire premete il tasto Esc e scrivete::wq
la lettera w indica a VIM di scrivere le modifiche ed il comando q gli dice di uscire dopo averlo fatto; mi raccomando i : prima di wq.
Adesso che avete capito penso/spero quali sono le funzioni base di VIM mi limiterò a dire "scrivete" e "salvate".
Le directory che vi serviranno per l'amministrazione sono:/var/www che è impostata di default come webroot (vedremo in seguito come cambiarla)/etc/apache2 che contiene i files di configurazione di apache2/etc/apache2/sites-enabled e che contiene una serie di links simbolici ai files di configurazione degli hosts virtuali che si trovano in /etc/apache2/sites-available
Dei comandi utili per la gestione di apache sono:/etc/init.d/apache2 start/etc/init.d/apache2 stop/etc/init.d/apache2 restart
che rispettivamente lancia, ferma, riavvia il demone apache2 .
E' utile anche abilitare alcuni moduli tra cui ssl e rewrite per cui scriviamo sul trminale da root:a2enmod ssl rewrite
e poi riavviare il daemon digitando:/etc/init.d/apache2 restart
Configurazione di MySQL
Adesso ci occupiamo di cambiare la password dell'utente root di MySQL scrivendo da root:mysqladmin -u root password <lamiapassword>
ovviamente sostituendo <lamiapassword> con la vostra password preferita.
Spero che sia inutile dirvi di utilizzare caratteri maiuscoli e minuscoli, numeri e caratteri speciali come "@#][.," ecc..
Ritengo sia utile creare al volo un utente (diverso da root) da poter far accedere al database con privilegi limitati, ma lo vedremo tra un po'.
Dei comandi utili per la gestione del DataBase abbiamo:
/etc/init.d/mysql start/etc/init.d/mysql stop/etc/init.d/mysql restart
che rispettivamente, guarda un po', lancia, ferma e riavvia il daemon MySQL.
Varie
Da notare che durante l'installazione è stato installato anche phpmyadmin (l'ultima parola inserita nel comando che vi ho detto prima) che se volete potete anche omettere. PhpMyAdmin è uno script in php che serve per la gestione "grafica" del database MySQL senza aver bisogno dell'accesso via terminale alla macchina.
Test
Se avete eseguito correttamente i passi precedenti puntate il vostro browser preferito (spero si tratti di Iceweasel) suhttp://<indirizzolocaledelserver>/phpmyadmin
dove <indirizzolocaledelserver> dovrebbe essere qualcosa del tipo: 192.168.1.2 e dovreste vedere lo script phpmyadmin in esecuzione che vi chiede username e password (Username: root e Password: quellacheavetesceltoprima).
Se per caso vi si dovesse aprire una finestra di download per un file probabilmente avete sbagliato qualcosa nei passi precedenti per cui consiglio di rivedere accuratamente la guida.
Una volta eseguito il login da root prendete dimestichezza con la grafica e tornate nella home di phpmyadmin quindi aggiungete un utente cliccando su "Privilegi" e poi su "Aggiungi nuovo utente" e seguite le indicazioni per completare la procedura.
Da ora in poi vi consiglio vivamente di utilizzare il nuovo utente per effettuare gli accessi al database.
Nella prossima guida parlerò della configurazione nel dettaglio dei files degli hosts in Apache2 (che per intenderci sono quelli contenuti in /etc/apache2/sites-available)
Nessun commento:
Posta un commento