DrupalInstall » Cronologia » Versione 13
Amministratore Truelite, 23-10-2006 16:22
| 1 | 1 | Amministratore Truelite | [[TracNav(TOC)]] |
|---|---|---|---|
| 2 | 13 | Amministratore Truelite | == Installare e configurare Drupal a livello di intero server == |
| 3 | 1 | Amministratore Truelite | |
| 4 | 13 | Amministratore Truelite | Benché sia disponibile anche nei pacchetti per Debian ed Ubuntu, la versione distribuita dal progetto stesso (a partire da http://www.drupal.org) è normalmente molto più aggiornata, e visto che essa fornisce anche un efficiente sistema di aggiornamento, alla fine la scelta di usare la versione ufficiale rispetto a quella della distribuzione è sostenibile in quanto il maggior carico di lavoro per la manutenzione è ridotto e viene abbondantemente bilanciato dalle maggiori funzionalità messe a disposizione. |
| 5 | 1 | Amministratore Truelite | |
| 6 | 13 | Amministratore Truelite | Il primo passo allora è quello di scaricare i sorgenti di Drupal e scompattarli nella directory di destinazione; nel nostro caso piazzeremo tutto sotto {{{/usr/share/local/drupal}}} con: |
| 7 | 1 | Amministratore Truelite | {{{ |
| 8 | cd |
||
| 9 | wget http://ftp.osuosl.org/pub/drupal/files/projects/drupal-4.7.x.tar.gz |
||
| 10 | cd /usr/share/local/drupal |
||
| 11 | tar -xvzf ~/drupal-4.7.x.tar.gz |
||
| 12 | mv drupal-4.7.x drupal |
||
| 13 | }}} |
||
| 14 | |||
| 15 | 12 | Amministratore Truelite | Occorre poi creare il database, nel caso specifico si è usato MySQL, (per l'impostazione iniziale del quale si veda [wiki:MySQLInitConf]) e creato un database apposito '''sitodrupal'''; poi si sono dati i privilegi di gestione per detto database ad un apposito utente con: |
| 16 | 1 | Amministratore Truelite | {{{ |
| 17 | mysqladmin -u root -p create sitodrupal |
||
| 18 | mysql -u root -p |
||
| 19 | ... |
||
| 20 | mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, |
||
| 21 | ALTER, CREATE TEMPORARY TABLES, LOCK TABLES ON sitodrupal.* TO |
||
| 22 | 'utentedrupal'@'localhost' IDENTIFIED BY 'passwordsegreta'; |
||
| 23 | }}} |
||
| 24 | 2 | Amministratore Truelite | fatto questo si sono create le tabelle con l'apposito script fornito Drupal: |
| 25 | {{{ |
||
| 26 | cd /usr/share/local/drupal |
||
| 27 | mysql -u utentedrupal -p sitodrupal < database/database.4.1.mysql |
||
| 28 | }}} |
||
| 29 | è modificato il file {{{sites/default/settings.php}}} impostando il valore: |
||
| 30 | {{{ |
||
| 31 | 1 | Amministratore Truelite | $db_url = 'mysql://utentedrupal:passwordsegreta@localhost/sitodrupal'; |
| 32 | 6 | Amministratore Truelite | }}} |
| 33 | |||
| 34 | Inoltre per la sicurezza dell'installazione è opportuno impostare dei permessi adeguati, questo significa assegnare a ''root'' tutti i file in modo che non siano modificabili da Apache, con qualcosa del tipo: |
||
| 35 | {{{ |
||
| 36 | chown -R root.root /usr/share/local/drupal |
||
| 37 | }}} |
||
| 38 | 8 | Amministratore Truelite | questo però non consentirà a Drupal di eseguire l'upload di file (ad esempio immagini) sul server. La caratteristica di Drupal infatti è che i suddetti file vengono tutti manenuti in una sotto directory {{{files}}} relativa a quella in cui si è installato il programma, che viene creata al primo upload. |
| 39 | 6 | Amministratore Truelite | |
| 40 | 8 | Amministratore Truelite | Il problema è che avendo installato il tutto sotto {{{/usr}}} e senza permesso di scrittura questo meccanismo non funzionerà; per questo sarà opportuno crare l'apposita directory sotto {{{/var}}} e dargli adeguati permessi, e poi usare un link simbolico; lo si è fatto con: |
| 41 | 6 | Amministratore Truelite | {{{ |
| 42 | mkdir /var/www/drupal/files |
||
| 43 | chmod 755 /var/www/drupal/files |
||
| 44 | 1 | Amministratore Truelite | chown www-data www-data /var/www/drupal/files |
| 45 | cd /usr/share/local/drupal |
||
| 46 | ln -s /var/www/drupal/files files |
||
| 47 | 13 | Amministratore Truelite | }}} |
| 48 | |||
| 49 | Un altro aspetto critico è quello della riscrittura delle URL in modo da renderle più gradevoli (e facili da ricordare). Questo viene abilitato da Drupal nella sezione '''administer -> setting''' nella sezione delle impostazioni generali. Perché funzioni però è necessario abilitare delle rewrite rule, che sono mantenute nel file {{{.htaccess}}} installato nella directory principale dei sorgenti. |
||
| 50 | |||
| 51 | Dato che l'uso di questi file comporta (giustificato quando l'installazione è nella home di un utente, non per una generale) un maggior carico di lavoro per il server (che li rilegge ad ogni accesso) si è preferito inserire la suddetta configurazione dentro la configurazione di Apache, con un qualcosa del tipo: |
||
| 52 | {{{ |
||
| 53 | # |
||
| 54 | # Apache/PHP/Drupal settings: |
||
| 55 | # |
||
| 56 | <Directory "/usr/local/share/drupal"> |
||
| 57 | |||
| 58 | # Protect files and directories from prying eyes. |
||
| 59 | <FilesMatch "(\.(engine|inc|install|module|sh|.*sql|theme|tpl(\.php)?|xtmpl)|code-style\.pl|Entries.*|Repository|Root)$"> |
||
| 60 | Order deny,allow |
||
| 61 | Deny from all |
||
| 62 | </FilesMatch> |
||
| 63 | |||
| 64 | # Set some options. |
||
| 65 | Options -Indexes |
||
| 66 | Options +FollowSymLinks |
||
| 67 | # Override PHP settings. More in sites/default/settings.php |
||
| 68 | # but the following cannot be changed at runtime. |
||
| 69 | # PHP 5, Apache 1 and 2 |
||
| 70 | <IfModule mod_php5.c> |
||
| 71 | php_value magic_quotes_gpc 0 |
||
| 72 | php_value register_globals 0 |
||
| 73 | php_value session.auto_start 0 |
||
| 74 | </IfModule> |
||
| 75 | |||
| 76 | # Reduce the time dynamically generated pages are cache-able. |
||
| 77 | <IfModule mod_expires.c> |
||
| 78 | ExpiresByType text/html A1 |
||
| 79 | </IfModule> |
||
| 80 | |||
| 81 | # Various rewrite rules. |
||
| 82 | <IfModule mod_rewrite.c> |
||
| 83 | RewriteEngine on |
||
| 84 | # If your site can be accessed both with and without the prefix www. |
||
| 85 | # you can use one of the following settings to force user to use only |
||
| 86 | one option: |
||
| 87 | # |
||
| 88 | # If you want the site to be accessed WITH the www. only, adapt and uncomment the following: |
||
| 89 | # RewriteCond %{HTTP_HOST} !^www\.example\.com$ [NC] |
||
| 90 | # RewriteRule .* http://www.example.com/ [L,R=301] |
||
| 91 | # |
||
| 92 | # |
||
| 93 | # If you want the site to be accessed only WITHOUT the www. , adapt and uncomment the following: |
||
| 94 | # RewriteCond %{HTTP_HOST} !^example\.com$ [NC] |
||
| 95 | # RewriteRule .* http://example.com/ [L,R=301] |
||
| 96 | |||
| 97 | # Modify the RewriteBase if you are using Drupal in a subdirectory and |
||
| 98 | # the rewrite rules are not working properly. |
||
| 99 | RewriteBase /drupal |
||
| 100 | |||
| 101 | # Rewrite current-style URLs of the form 'index.php?q=x'. |
||
| 102 | RewriteCond %{REQUEST_FILENAME} !-f |
||
| 103 | RewriteCond %{REQUEST_FILENAME} !-d |
||
| 104 | RewriteRule ^(.*)$ index.php?q=$1 [L,QSA] |
||
| 105 | </IfModule> |
||
| 106 | </Directory> |
||
| 107 | 2 | Amministratore Truelite | }}} |