Projet

Général

Profil

Apache » Historique » Version 42

Patrice Nadeau, 2017-06-03 15:04

1 3 Patrice Nadeau
h1. Apache
2 1 Patrice Nadeau
3
Serveur de page Web
4
5 21 Patrice Nadeau
> Version 2.4
6
7 1 Patrice Nadeau
---
8
9
{{toc}}
10
11 3 Patrice Nadeau
h2. Installation
12 1 Patrice Nadeau
13
<pre><code class="bash">
14 29 Patrice Nadeau
# Installation
15 31 Patrice Nadeau
zypper install apache2
16 29 Patrice Nadeau
# Activation au démarrage
17 5 Patrice Nadeau
systemctl enable apache2.service
18 1 Patrice Nadeau
# Démarrer Apache :
19 26 Patrice Nadeau
systemctl start apache2.service
20 1 Patrice Nadeau
</code></pre>
21
22
Ouvrir dans le pare-feu :
23
<pre><code class="bash">
24
yast firewall services add service=service:apache2 zone=EXT
25
</code></pre>
26
27
L’emplacement des fichier du serveur est _/srv/www/htdocs_.
28
29
h2. Modules supplémentaires
30 32 Patrice Nadeau
> La configuration d'Apache doit être relue lors de l'activation d'un module
31 1 Patrice Nadeau
32 33 Patrice Nadeau
La liste des modules actifs peut être listé avec
33 32 Patrice Nadeau
<pre><code class="bash">
34
a2enmod -l
35
</code></pre>
36
37
h3. Version
38 31 Patrice Nadeau
39
Inclut dans Apache
40 1 Patrice Nadeau
<pre><code class="bash">
41
a2enmod mod_version
42 31 Patrice Nadeau
</code></pre>
43
44
h3. PHP
45
46
Support pour PHP
47
<pre><code class="bash">
48
zypper install apache2-mod_php5
49 1 Patrice Nadeau
a2enmod mod_php5
50 33 Patrice Nadeau
</code></pre>
51
52
h3. Proxy
53
54 35 Patrice Nadeau
Redirection de serveur
55 33 Patrice Nadeau
<pre><code class="bash">
56
a2enmod proxy 
57
a2enmod proxy_http
58 30 Patrice Nadeau
</code></pre>
59
60 36 Patrice Nadeau
h2. HTTPS
61
62 40 Patrice Nadeau
Serveur sécurisé
63 36 Patrice Nadeau
64 1 Patrice Nadeau
h3. SSL
65 40 Patrice Nadeau
66 41 Patrice Nadeau
h4. Self-certificate
67 39 Patrice Nadeau
68 36 Patrice Nadeau
Générer les clés
69
<pre><code class="bash">
70
openssl req -new > new.ssl.csr
71
openssl rsa -in privkey.pem -out new.cert.key
72
openssl x509 -in new.ssl.csr -out new.cert.cert -req -signkey new.cert.key -days 365
73
cp new.cert.cert /etc/ssl/certs/server.crt
74 1 Patrice Nadeau
cp new.cert.key /etc/ssl/private/server.key
75 41 Patrice Nadeau
</code></pre>
76
77
h4. letsencrypt.org
78
79 42 Patrice Nadeau
Certificats gratuits d'une durée de 90 jours.
80
Le renouvellement automatique peut être programmé.
81
82 41 Patrice Nadeau
<pre><code class="bash">
83
wget https://dl.eff.org/certbot-auto
84
chmod a+x certbot-auto
85
./certbot-auto --apache certonly
86 39 Patrice Nadeau
</code></pre>
87
88
h3. Apache
89
90
Vérifier qu'Apache supporte SSL
91
<pre><code class="bash">
92
a2enmod -l
93
</code></pre>
94
95
Si le module *ssl* n’apparaît pas, l'activer
96
<pre><code class="bash">
97
a2enmod ssl
98 36 Patrice Nadeau
</code></pre>
99
100 37 Patrice Nadeau
Modifier le fichier _/etc/apache2/default-server.conf_
101 36 Patrice Nadeau
<pre><code class="php">
102
Listen 443
103
<VirtualHost *:443>
104
    SSLEngine on
105
    SSLCertificateFile /etc/ssl/certs/server.crt
106
    SSLCertificateKeyFile /etc/ssl/private/server.key
107
</VirtualHost>
108
</code></pre>
109
110 38 Patrice Nadeau
Relire la configuration d'Apache
111
<pre><code class="bash">
112
systemctl reload apache2.service
113
</code></pre>
114
115 3 Patrice Nadeau
h2. Serveurs virtuels
116 1 Patrice Nadeau
117 19 Patrice Nadeau
Apache permet de rediriger les demandes d’accès vers 
118
* différents répertoires sur le même serveur 
119
* différents port
120
* un autre serveur
121
122 17 Patrice Nadeau
Très utile pour rediriger les requêtes à partir d'internet avec un seule adresse IP publique (NAT(Network Address Translation)).
123
124
125 18 Patrice Nadeau
Si le fichier _/etc/apache2/vhosts.d/vhost.conf_ n'existe pas, le créer à partir du gabarit de base
126 17 Patrice Nadeau
<pre><code class="bash">
127
cd /etc/apache2/vhosts.d/
128
cp vhost.template vhost.conf
129
</code></pre>
130
131 8 Patrice Nadeau
h3. Redirection vers un dossier différent.
132 6 Patrice Nadeau
133 16 Patrice Nadeau
Ex. : On veux diriger _helpdesk.domain.tld_ vers le dossier _/srv/www/htdocs/helpdesk_ et  _wiki.domain.tld_ vers le dossier _/srv/www/htdocs/wiki_
134 15 Patrice Nadeau
<pre><code class="php">
135
<VirtualHost *:80>
136 16 Patrice Nadeau
        ServerName helpdesk.domain.tld
137
        DocumentRoot /srv/www/htdocs/hepdesk
138 15 Patrice Nadeau
        ServerAdmin admin@domain.tld
139 16 Patrice Nadeau
        <Directory "/srv/www/htdocs/helpdesk">
140 25 Patrice Nadeau
                #Order allow,deny #Since Apache 2.4
141 22 Patrice Nadeau
                Require all granted
142 15 Patrice Nadeau
         </Directory>
143
</VirtualHost>
144
145
<VirtualHost *:80>
146
        ServerName wiki.domain.tld
147
        DocumentRoot /srv/www/htdocs/wiki
148
        ServerAdmin admin@domain.tld
149
        <Directory "/srv/www/htdocs/wiki">
150 25 Patrice Nadeau
                #Order allow,deny # since Apache 2.4
151 22 Patrice Nadeau
                Require all granted
152 1 Patrice Nadeau
         </Directory>
153
</VirtualHost>
154
</code></pre>
155
156
Modifier les items suivants :
157
* *ServerAdmin* : L'adresse de courriel de l'administrateur
158 4 Patrice Nadeau
* *ServerName* : Le FQDN(Fully Qualified Domain Name) du serveur
159 1 Patrice Nadeau
* *DocumentRoot* : L'emplacement des fichiers du site web
160 7 Patrice Nadeau
161
h3. Redirection vers un serveur différent
162
163 34 Patrice Nadeau
> Les modules _proxy_ et _proxy_http_ doivent déjà être actifs
164 11 Patrice Nadeau
165 12 Patrice Nadeau
Modifier le fichier _/etc/apache2/vhosts.d/vhost.conf_ 
166 13 Patrice Nadeau
Ex. : On veux rediriger le service _service_ vers le serveur _server1_
167 14 Patrice Nadeau
<pre><code class="php">
168 12 Patrice Nadeau
<VirtualHost *:80>
169
        ServerName service.domaine.com
170 28 Patrice Nadeau
        ProxyPreserveHost On
171 12 Patrice Nadeau
        ProxyPass / http://serveur1.domaine.com/
172
        ProxyPassReverse / http://serveur1.domaine.com/
173 13 Patrice Nadeau
        ServerAdmin admin@domaine.com
174 12 Patrice Nadeau
</VirtualHost>
175 11 Patrice Nadeau
176 12 Patrice Nadeau
</code></pre>
177 11 Patrice Nadeau
178 7 Patrice Nadeau
h3. Activation des changements
179 1 Patrice Nadeau
180
Relire la configuration d'Apache
181
<pre><code class="bash">
182 27 Patrice Nadeau
systemctl reload apache2.service
183 1 Patrice Nadeau
</code></pre>
184
185
Commandes
186 10 Patrice Nadeau
* _apache2ctl -S_ : liste les serveurs virtuels