SlideShare una empresa de Scribd logo
1 de 59
Descargar para leer sin conexión
327
Apache HTTP Server
El Servidor HTTP Apache es un servidor Web de tecnología Open Source sólido y para uso comercial
desarrollado por Apache Software Foundation (http://www.apache.org/). Red Hat Enterprise Linux
incluye el Servidor HTTP Apache versión 2.2 así como también una serie de módulos de servidor
diseñados para mejorar su funcionalidad.
El archivo de configuración predeterminado instalado en el Servidor HTTP Apache funciona sin
necesidad de modificarlo, en la mayor parte de los casos. Este capítulo da una idea general de las
directrices dentro de este archivo de configuración (/etc/httpd/conf/httpd.conf) para ayudar
a aquellos que requieren una configuración personalizada o que necesitan convertir un archivo de
configuración del formato más antiguo del Servidor HTTP Apache versión 1.3.
Advertencia
If using the graphical HTTP Configuration Tool (system-config-httpd ), do not hand
edit the Apache HTTP Server's configuration file as the HTTP Configuration Tool
regenerates this file whenever it is used.
22.1. Servidor HTTP Apache Versión 2.2
There are important differences between the Apache HTTP Server 2.2 and version 2.0 (version 2.0
shipped with Red Hat Enterprise Linux 4 and earlier). This section reviews some of the features of
Apache HTTP Server 2.2 and outlines important changes. If you are upgrading from version 1.3, you
should also read the instructions on migrating from version 1.3 to version 2.0. For instructions on
migrating a version 1.3 configuration file to the 2.0 format, refer to Sección 22.2.2, “Migración de los
Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0”.
22.1.1. Características del Servidor HTTP Apache Versión 2.2
El Servidor HTTP Apache Versión 2.2 presenta las siguientes mejoras sobre las versión 2.0:
• Módulos de cacheo mejorados (mod_cache, mod_disk_cache, mod_mem_cache).
• Una nueva estructura para el soporte de autenticación y autorización que remplaza los módulos de
autenticación proporcionados en las versiones anteriores.
• Soporte para balanceo de carga proxy (mod_proxy_balancer)
• soporte para manejo de archivos grandes (más grandes de 2 GB) en plataformas de 32 bits.
Se han realizado los siguientes cambios a la configuración httpd predeterminada:
• Los módulos mod_cern_meta y mod_asis ya no se cargan por defecto.
• Ahora el módulo mod_ext_filter se cargapor defecto.
Si actualiza desde un lanzamiento previo de Red Hat Enterprise Linux, la configuración
httpd necesitará actualizarse para httpd 2.2. Para obtener más información refiérase a http://
httpd.apache.org/docs/2.2/upgrading.html.
328
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
22.2. Migración de los Archivos de Configuración del
Servidor HTTP Apache
22.2.1. Migración de los Archivos de Configuración del Servidor
HTTP Apache Versión 2.0.
This section outlines migration from version 2.0 to 2.2. If you are migrating from version 1.3, please
refer to Sección 22.2.2, “Migración de los Archivos de Configuración del Servidor HTTP Apache de la
Versión 1.3 a la 2.0”.
• Los archivos de configuración y los scripts de inicialización de la versión 2.0 necesitan ajustes
mínimos particularmente en los nombres de los módulos los cuales pueden haber cambiado. Los
módulos de terceros que servían en la versión 2.0 también sirven en la versión 2.2 pero necesitan
ser recompilados antes de que los cargue. Los módulos claves que se deben observar son los
módulos de autenticación y autorización. Para cada unos de los módulos que ha sido renombrado
será necesario actualizarla línea LoadModule
1
.
• El módulo mod_userdir sólamente actuará bajo pedidos si proporciona una directiva UserDir
indicando un nombre de directorio. Si desea mantener los procedimientos utilizados en la versión
2.0 añada la directiva UserDir public_html en su archivo de configuración.
• Para habilitar SSL, edite el archivo httpd.conf añadiendo las directivas necesarias mod_ssl.
Utilice apachectl start ya que apachectl startssl no se encuentra disponibleen la
versión 2.2. Puede ver un ejemplo de la configuración SSL para httpd en conf/extra/httpd-
ssl.conf.
• Para probar su configuración se le aconseja que utilice service httpd configtest la cual
detectará errores de configuración.
Para obtener más información sobre como actualizar desde la versión 2.0 a la 2.2 puede ir a http://
httpd.apache.org/docs/2.2/upgrading.html.
22.2.2. Migración de los Archivos de Configuración del Servidor
HTTP Apache de la Versión 1.3 a la 2.0
Esta sección detalla la migración de un archivo de configuración del Servidor HTTP Apache versión
1.3 para el Servidor HTTP Apache versión 2.0 lo pueda utilizar.
Si está actualizando a Red Hat Enterprise Linux 5 desde Red Hat Enterprise Linux 2.1 tenga en
cuenta que el nuevo archivo de configuración para el paquete del Servidor HTTP Apache versión 2.0
es instalado como /etc/httpd/conf/httpd.conf.rpmnew y no se toca la versión original 1.3
httpd.conf. Depende absolutamente de usted si decide utilizar el nuevo archivo de configuración
y migrar los viejos cambios o si utilizar el archivo ya existente como base y modificarlo para que se
adapte; sin embargo, algunas partes del archivo se han cambiado más que otras y lo mejor es llegar a
un punto intermedio. Los archivos de configuración para ambas versiones la 1.3 y la 2.0 están dividos
en tres secciones.
Si el archivo /etc/httpd/conf/httpd.conf es una versión modificada de la versión por defecto
recién instalada y ha guardado una copia del original, entonces le será más fácil invocar el comando
diff, como se muestra a continuación (conectándose como root):
329
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
diff -u httpd.conf.orig httpd.conf | less
Este comando subraya los cambios realizados. Si no tiene una copia del archivo original, cójalo del
paquete RPM usando los comandos rpm2cpio y cpio, como en el ejemplo siguiente:
rpm2cpio apache-<version-number>.i386.rpm | cpio -i --make
In the above command, replace <version-number> with the version number for the apache
package.
Finalmente, es útil saber que el Servidor HTTP Apache tiene un modo de prueba para verificar si hay
errores en la configuración. Para ello, escriba el siguiente comando:
apachectl configtest
22.2.2.1. Configuración del entorno a nivel global
La sección del entorno global del archivo de configuración contiene directrices que afectan la
operación general del Servidor HTTP Apache como por ejemplo el número de peticiones que puede
manejar al mismo tiempo y la ubicación de varios archivos que usa. Esta sección requiere un gran
número de cambios y por ello se recomienda que base esta sección en el archivo de configuración del
Servidor HTTP Apache versión 2.0 y que migre sus configuraciones anteriores a este.
22.2.2.1.1. Interfaces y vinculación de puertos
Ya no existen las directrices BindAddress y Port; porque quedan recogidas en la directriz Listen.
Si tenía configurado el Puerto 80 en el archivo de configuración de la versión 1.3, debe cambiarlo a
Listen 80 en el archivo de configuración 2.0. Si el valor del Puerto estaba configurado a un valor
diferente que 80, tiene que poner el número del puerto a los contenidos de la directriz ServerName.
Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3:
Port 123 ServerName www.example.com
Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura:
Listen 123 ServerName www.example.com:123
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mpm_common.html#listen
• http://httpd.apache.org/docs-2.0/mod/core.html#servername
22.2.2.1.2. Regulación del tamaño del pool de servidores
Cuando el Servidor HTTP Apache acepta peticiones, este despacha procesos hijo o hilos para que los
manejen. Este grupo de procesos o hilos es conocido como un pool de servidores. Bajo el Servidor
HTTP Apache versión 2.0 se ha abstraído la responsabilidad de crear y mantener estos pool de
servidores a un grupo de módulos llamados Módulos de Procesos Múltiples (MPMs). A diferencia
de otros módulos, el Servidor HTTP Apache sólamente puede cargar un módulo del grupo MPM.
330
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
Hay tres módulos MPM incluidos con la versión 2.0: prefork, worker, y perchild. Actualmente,
únicamente están disponibles los MPMs prefork y worker, aunque el MPM perchild estará
disponible más adelante.
El comportamiento del Servidor HTTP Apache 1.3 original ha sido movido al MPM prefork. El MPM
prefork acepta las mismas directrices que el Servidor HTTP Apache versión 1.3 por tanto, las
siguientes directrices se pueden migrar directamente:
• StartServers
• MinSpareServers
• MaxSpareServers
• MaxClients
• MaxRequestsPerChild
El MPM worker implementa un servidor multi-proceso y multi-hilos proporcionando una mayor
escalabilidad. Cuando este utilizando este MPM, los hilos manejan las peticiones conservando
recursos del sistema y permitiendo servir a grandes números de peticiones de manera eficiente.
Aún cuando algunas de las directrices aceptadas por el MPM worker son las mismas que aquellas
aceptadas por el MPM prefork los valores para esas directrices no deberían ser transferidos
directamente desde una instalación del Servidor HTTP Apache versión 1.3. Es mejor utilizar los
valores por defecto como una guía y luego experimentar para determinar los valores que funcionan
mejor.
Importante
Para utilizar el MPM worker, cree el archivo /etc/sysconfig/httpd y añada la
directriz siguiente:
HTTPD=/usr/sbin/httpd.worker
For more on the topic of MPMs, refer to the following documentation on the Apache Software
Foundation's website:
• http://httpd.apache.org/docs-2.0/mpm.html
22.2.2.1.3. Soporte del Dynamic Shared Object (DSO) (Objeto dinámico
compartido)
Se tienen que realizar muchos cambios aquí, por eso se recomienda que para modificar la
configuración del Servidor HTTP Apache 1.3 para adaptarse a la versión 2.0 (al contrario de migrar
los cambios en la configuración de la versión 2.0) copie esta sección del archivo de configuración del
Servidor HTTP Apache 2.0.
Aquellos que no deseen copiar la sección desde la configuración del Servidor HTTP Apache versión
2.0 deberían tomar en cuenta lo siguiente:
• Las directrices AddModule y ClearModuleList ya no existen. Estas directrices eran usadas
para asegurarse de que se pudiesen activar los módulos en el orden correcto. El Servidor HTTP
331
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
Apache versión 2.0 permite a los módulos especificar su orden, eliminando la necesidad de estas
dos directrices.
• El orden de las líneas LoadModule ya no es relevante en la mayoría de los casos.
• Se han añadido muchos módulos, otros han sido eliminados, renombrado, dividido o incorporados
con otros.
• Ya no son necesarias las líneas LoadModule para los módulos empaquetados en sus propios
RPMs (mod_ssl, php, mod_perl y similares) ya que se pueden encontrar en sus archivos
relevantes dentro del directorio /etc/httpd/conf.d/.
• Las definiciones HAVE_XXX ya no existen.
Importante
Si se está modificando el archivo original, por favor tenga en cuenta que es de suma
importancia que httpd.conf contenga la directriz siguiente:
Include conf.d/*.conf
La omisión de esta directriz podría resultar en la falla de todos los módulos
enpaquetados en sus propios RPMs (tales como mod_perl, php y mod_ssl).
22.2.2.1.4. Otros cambios en el entorno global
The following directives have been removed from Apache HTTP Server 2.0's configuration:
• ServerType — El Servidor HTTP Apache se puede ejecutar sólamente como ServerType
standalone por lo que esta directriz es irrelevante.
• AccessConfig y ResourceConfig — Se han eliminado estas directrices porque su funcionalidad
aparece ya en la directriz Include. Si las directrices AccessConfig y ResourceConfig son
configuradas, entonces reemplácelas por las directrices Include.
Para asegurarse que estos archivos se lean en el orden de las antiguas directrices, las directrices
Include se deberían colocar al final de httpd.conf, con la correspondiente a ResourceConfig
precediendo la que corresponde a AccessConfig. Si se estan usando los valores por defecto,
inclúyalos explícitamente como archivos conf/srm.conf y conf/access.conf.
22.2.2.2. Configuración del servidor principal
The main server configuration section of the configuration file sets up the main server, which responds
to any requests that are not handled by a virtual host defined within a <VirtualHost> container.
Values here also provide defaults for any <VirtualHost> containers defined.
Las directrices utilizadas en esta sección han cambiado ligeramente respecto a las del Servidor
HTTP Apache versión 1.3 y la versión 2.0. Si la configuración del servidor principal está altamente
personalizada, le será más fácil modificar el archivo de configuración existente para que se
adapte a la versión 2.0 del Servidor HTTP Apache. Los usuarios con secciones del servidor
principal ligeramente personalizadas deberían migrar sus cambios al archivo de configuración 2.0
predeterminado.
332
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
22.2.2.2.1. Asignaciones UserDir
La directriz UserDir se usa para habilitar URLs tales como http://example.com/~bob/
para mapear a un subdirectorio dentro del directorio home del usuario bob tal como /home/bob/
public_html/. Un efecto secundario de esta característica es que un potencial atacante puede
determinar si un nombre de usuario dado se encuentra en el sistema; por esta razón la configuración
por defecto para el Servidor HTTP Apache desactiva esta directriz.
Para habilitar la asignación de UserDir, cambie la directriz en httpd.conf desde:
UserDir disable
a lo siguiente:
UserDir public_html
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_userdir.html#userdir
22.2.2.2.2. Logging
Se han eliminado las siguientes directrices de conexión:
• AgentLog
• RefererLog
• RefererIgnore
Sin embargo, las conexiones agent y referrer estan disponibles usando las directrices CustomLog y
LogFormat.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#customlog
• http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#logformat
22.2.2.2.3. Índice de directorios
Se ha eliminado la directriz FancyIndexing. La misma funcionalidad se encuentra ahora en
FancyIndexing option dentro de la directriz IndexOptions.
La opción VersionSort para la directriz IndexOptions causa que los archivos conteniendo
números de versiones sean ordenados de una forma más natural. Por ejemplo, httpd-2.0.6.tar
aparece antes de httpd-2.0.36.tar en una página de índices de directorio.
Las directrices predeterminadas ReadmeName y HeaderName han sido cambiadas desde README y
HEADER a README.html y HEADER.html.
333
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#indexoptions
• http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#readmename
• http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#headername
22.2.2.2.4. Negociación de contenido
La directriz CacheNegotiatedDocs toma ahora el argumento on o off. Las instancias existentes
de CacheNegotiatedDocs deberían ser cambiadas con CacheNegotiatedDocs on.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_negotiation.html#cachenegotiateddocs
22.2.2.2.5. Documentos de error
To use a hard-coded message with the ErrorDocument directive, the message should be enclosed
in a pair of double quotation marks ", rather than just preceded by a double quotation mark as
required in Apache HTTP Server 1.3.
Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3:
ErrorDocument 404 "The document was not found
Para migrar la configuración de ErrorDocument al Servidor HTTP Apache versión 2.0, utilice la
siguiente estructura:
ErrorDocument 404 "The document was not found"
Observe las dobles comillas en la directriz ErrorDocument del ejemplo anterior.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/core.html#errordocument
22.2.2.3. Configuración de host virtuales
The contents of all <VirtualHost> containers should be migrated in the same way as the main
server section as described in Sección 22.2.2.2, “Configuración del servidor principal”.
Importante
Observe que la configuración de las máquinas virtuales SSL/TLS se han quitado del
archivo de configuración del servidor principal al archivo /etc/httpd/conf.d/
ssl.conf.
334
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
• http://httpd.apache.org/docs-2.0/vhosts/
22.2.2.4. Módulos y el Servidor HTTP Apache 2.0
En la versión 2.0 del Servidor HTTP Apache el sistema de módulos se ha cambiado para permitir
que los módulos se encadenen o se combinen en maneras nuevas e interesantes. Los scripts CGI
(Common Gateway Interface), por ejemplo, pueden generar documentos HTMLinterpretados por
el servidor que luego pueden ser procesados por mod_include. Esto abre una gran cantidad de
posibilidades en lo que se refiere a cómo los módulos pueden combinarse para lograr una meta
determinada.
La forma en que esto funciona es que cada petición es servidapor exáctamente un módulo handler
seguido por cero o más módulos filtro.
Bajo el Servidor HTTP Apache 1.3, por ejemplo, un script Perl es manejado completamentepor el
módulo Perl (mod_include). En la versión 2.0 del Servidor HTTP Apache la petición la gestiona
inicialmente el módulo principal — que sirve archivos estáticos — y que es luego filtrado por
mod_perl.
Exactamente cómo utilizar esto y otras de las nuevas características del Servidor HTTP Apache
2.0, están más allá del alcance de este documento; sin embargo, el cambio tiene ramificaciones si
ha usado la directriz PATH_INFO para un documento que es gestionado por un módulo que ahora
se implementa como un filtro, pues cada uno contiene información del recorrido del nombre del
archivo verdadero. El módulo principal, que inicialmente manejaba la petición, no entiende por
defecto PATH_INFO y devuelve el error 404 Not Found para las peticiones que contienen dicha
información. Como alternativa puede utilizar la directriz AcceptPathInfo para obligar al módulo
principal a que acepte peticiones con PATH_INFO.
A continuación se presenta un ejemplo de esta directriz:
AcceptPathInfo on
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/core.html#acceptpathinfo
• http://httpd.apache.org/docs-2.0/handler.html
• http://httpd.apache.org/docs-2.0/filter.html
22.2.2.4.1. El módulo suexec
En el Servidor HTTP Apache 2.0, el módulo mod_suexec utiliza la directriz SuexecUserGroup en
vez de las directrices User y Group, la cual se utiliza para configurar hosts virtuales. Las directrices
User y Group también se pueden utilizar en general, pero no para la configuración de hosts virtuales.
Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3:
<VirtualHost vhost.example.com:80> User someone Group somegroup </VirtualHost>
Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura:
335
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
<VirtualHost vhost.example.com:80> SuexecUserGroup someone somegroup </VirtualHost>
22.2.2.4.2. El módulo mod_ssl
The configuration for mod_ssl has been moved from the httpd.conf file into the /etc/httpd/
conf.d/ssl.conf file. For this file to be loaded, and for mod_ssl to work, the statement Include
conf.d/*.conf must be in the httpd.conf file as described in Sección 22.2.2.1.3, “Soporte del
Dynamic Shared Object (DSO) (Objeto dinámico compartido)”.
Las directrices ServerName en las máquinas virtuales SSL tienen que especificar el número del
puerto.
Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3:
<VirtualHost _default_:443> # General setup for the virtual host ServerName
ssl.example.name ... </VirtualHost>
Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura:
<VirtualHost _default_:443> # General setup for the virtual host ServerName ssl.host.name:443
... </VirtualHost>
It is also important to note that both the SSLLog and SSLLogLevel directives have been removed.
The mod_ssl module now obeys the ErrorLog and LogLevel directives. Refer to ErrorLog and
LogLevel for more information about these directives.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_ssl.html
• http://httpd.apache.org/docs-2.0/vhosts/
22.2.2.4.3. El módulo mod_proxy
Proxy access control statements are now placed inside a <Proxy> block rather than a <Directory
proxy:>.
La funcionalidad de caché del antiguo mod_proxy se ha dividido en tres módulos siguientes:
• mod_cache
• mod_disk_cache
• mod_mem_cache
Estos generalmente usan directrices similares a las versiones anteriores del módulo mod_proxy,
pero se recomienda que verifique cada directriz antes de migrar cualquier configuración caché.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
336
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
• http://httpd.apache.org/docs-2.0/mod/mod_proxy.html
22.2.2.4.4. El módulo mod_include
The mod_include module is now implemented as a filter and is therefore enabled differently. Refer to
Sección 22.2.2.4, “Módulos y el Servidor HTTP Apache 2.0” for more about filters.
Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3:
AddType text/html .shtml AddHandler server-parsed .shtml
Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura:
AddType text/html .shtml AddOutputFilter INCLUDES .shtml
Note that the Options +Includes directive is still required for the <Directory> container or in a
.htaccess file.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_include.html
22.2.2.4.5. Los módulos mod_auth_dbm y mod_auth_db
El Servidor HTTP Apache 1.3 soportaba dos módulos de autenticación, mod_auth_db y
mod_auth_dbm que usaba las bases de datos Berkeley y DBM respectivamente. Estos módulos
se han combinado en un único módulo que se llama mod_auth_dbm en el Servidor HTTP
Apache 2.0, que puede acceder a diferentes formatos de bases de datos. Para migrar desde
mod_auth_db los archivos de configuración se tienen que ajustar reemplazando AuthDBUserFile
y AuthDBGroupFile con los equivalentes: AuthDBMUserFile y AuthDBMGroupFile. También, se
debe añadir la directriz AuthDBMType DB para indicar el tipo de archivo de base de datos en uso.
El siguiente ejemplo muestra una configuración mod_auth_db de ejemplo para el Servidor HTTP
Apache 1.3:
<Location /private/> AuthType Basic AuthName "My Private Files" AuthDBUserFile /var/www/authdb
require valid-user </Location>
Para migrar esta configuración a la versión 2.0 del Servidor HTTP Apache 2.0 utilice la siguiente
estructura:
<Location /private/> AuthType Basic AuthName "My Private Files" AuthDBMUserFile /var/www/
authdb AuthDBMType DB require valid-user </Location>
Observe que la directriz AuthDBMUserFile también puede ser usada en archivos .htaccess.
El script Perl dbmmanage que se utiliza para manipular bases de datos de nombres de usuarios y
contraseñas ha sido reemplazado por htdbm en el Servidor HTTP Apache 2.0. El programa htdbm
ofrece una funcionalidad equivalente y como mod_auth_dbm puede operar en una variedad de
337
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
formatos de bases de datos; la opción -T se puede usar en la línea de comandos para especificar el
formato a utilizar.
Tabla 22.1, “Migración del dbmmanage a htdbm” shows how to migrate from a DBM-format database
to htdbm format using dbmmanage.
Action comando dbmmanage (1.3) comando equivalente htdbm
(2.0)
Añade un usuario a la base de
datos (usando la contraseña
dada)
Añade un usuario a la base de
datos ( le pide la contraseña)
Eliminar el usuario de la base
de datos
dbmmanage authdb add
username password
dbmmanage authdb
adduser username
dbmmanage authdb delete
username
htdbm -b -TDB authdb
username password
htdbm -TDB authdb
username
htdbm -x -TDB authdb
username
Listar usuarios en la base de
datos
dbmmanage authdb view htdbm -l -TDB authdb
Verificar una contraseña dbmmanage authdb check
username
Tabla 22.1. Migración del dbmmanage a htdbm
htdbm -v -TDB authdb
username
Las opciones -m y -s trabajan con dbmmanage y con htdbm, permitiendo el uso de los algortimos
MD5 o SHA1 para las contraseñas hashing, respectivamente.
Cuando cree una nueva base de datos con htdbm, use la opción -c.
For more on this topic, refer to the following documentation on the Apache Software Foundation's
website:
• http://httpd.apache.org/docs-2.0/mod/mod_auth_dbm.html
22.2.2.4.6. El módulo mod_perl
The configuration for mod_perl has been moved from httpd.conf into the file /etc/httpd/
conf.d/perl.conf. For this file to be loaded, and hence for mod_perl to work, the statement
Include conf.d/*.conf must be included in httpd.conf as described in Sección 22.2.2.1.3,
“Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)”.
Las ocurrencias del Apache:: en el httpd.conf tienen que ser sustituídas por ModPerl::.
Además, se ha cambiado el modo en que se registran los manejadores.
Ejemplo de configuración del Servidor HTTP Apache 1.3 mod_perl:
<Directory /var/www/perl> SetHandler perl-script PerlHandler Apache::Registry Options +ExecCGI
</Directory>
Este es el equivalente del mod_perl para el Servidor HTTP Apache 2.0:
<Directory /var/www/perl> SetHandler perl-script PerlResponseHandler ModPerl::Registry Options
+ExecCGI </Directory>
338
Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0
La mayoría de los módulos para mod_perl 1.x deberían funcionar sin modificación con los módulos
mod_perl 2.x. Los módulos XS requieren recompilación y quizás algunas modificaciones menores
de Makefile.
22.2.2.4.7. El módulo mod_python
Configuration for mod_python has moved from httpd.conf to the /etc/httpd/conf.d/
python.conf file. For this file to be loaded, and hence for mod_python to work, the statement
Include conf.d/*.conf must be in httpd.conf as described in Sección 22.2.2.1.3, “Soporte del
Dynamic Shared Object (DSO) (Objeto dinámico compartido)”.
22.2.2.4.8. PHP
The configuration for PHP has been moved from httpd.conf into the file /etc/httpd/conf.d/
php.conf. For this file to be loaded, the statement Include conf.d/*.conf must be in
httpd.conf as described in Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto
dinámico compartido)”.
Nota
Cualquier directriz de configuración PHP utilizada en el Servidor HTTP Apache 1.3
ahora es completamente compatible cuando se migra al Servidor HTTP Apache 2.0
en Red Hat Enterprise Linux 5.
En PHP 4.2.0 y posterior, el conjunto predeterminado de variables predefinidas que están disponibles
en el ámbito global, han cambiado. Las entradas individuales y las variables del servidor, por defecto,
ya no se colocan directamente en el ámbito global. Este cambio puede hacer que se rompan los
scripts. Cámbiese al antiguo comportamiento colocando register_globals a On en el archivo /
etc/php.ini.
Para mayor información sobre estos temas, consulte los siguientes sitios web:
• http://www.php.net/release_4_1_0.php
22.2.2.4.9. El módulo mod_authz_ldap
Red Hat Enterprise Linux ships with the mod_authz_ldap module for the Apache HTTP Server. This
module uses the short form of the distinguished name for a subject and the issuer of the client SSL
certificate to determine the distinguished name of the user within an LDAP directory. It is also capable
of authorizing users based on attributes of that user's LDAP directory entry, determining access to
assets based on the user and group privileges of the asset, and denying access for users with expired
passwords. The mod_ssl module is required when using the mod_authz_ldap module.
Importante
El módulo mod_authz_ldap no valida un usuario a un directorio LDAP usando un
hash de contraseña encriptada. Esta funcionalidad es proporcionada por el módulo
experimental mod_auth_ldap. Consulte la documentación en línea de
mod_auth_ldap en http://httpd.apache.org/docs-2.0/mod/mod_auth_ldap.html para
más detalles sobre el estatus de este módulo.
El archivo /etc/httpd/conf.d/authz_ldap.conf configura al módulo mod_authz_ldap.
339
Arrancar y detener httpd
Refer to /usr/share/doc/mod_authz_ldap-<version>/index.html (replacing <version>
with the version number of the package) or http://authzldap.othello.ch/ for more information on
configuring the mod_authz_ldap third party module.
22.3. Arrancar y detener httpd
After installing the httpd package, review the Apache HTTP Server's documentation available online
at http://httpd.apache.org/docs/2.2/.
El RPM de httpd instala el script /etc/init.d/httpd, el cual se puede acceder usando el
comando /sbin/service.
Iniciando httpd utilizandoel script de control apachectl configura las variables del entorno en
/etc/sysconfig/httpd e inicia httpd. También puede configurar las variables del entorno
utilizando el script de inicialización.
Para arrancar el servidor utilizando el script de control apachectl como tipo root:
apachectl start
También puede arrancar httpd utilizando /sbin/service httpd start. Esto inicia httpd
pero no configura las variables del entorno. Si está utilizando la directriz predeterminada Listen en
httpd.conf, la cual es el puerto 80, necesitará contar con privilegios de usuario root para iniciar el
servidor apache.
Para detener el servidor, como root escriba:
apachectl stop
También puede detener httpd utilizando /sbin/service httpd stop. La opción restart es
una manera más rápida de detener y luego iniciar el Servidor HTTP Apache.
Para reiniciar el servidor como root escriba:
apachectl restart
or:
/sbin/service httpd restart
Apache presentará un mensaje en la consola o en el ErrorLog si encuentra un error al iniciar.
Por defecto, el servicio httpd no inicia automáticamente al momento de arranque. Si quiere
que Apache inicie al momento de arranque necesitará añadir una llamada a apachectl en sus
archivos de inicalización dentro de su directorio rc.local. Un archivo que se utiliza típicamente
es rc.local. Ya que esto inicia Apache como usuario root se recomienda que configure
apropiadamente su seguridad y autenticación antes de añadir esta llamada.
También puede configurar el servicio httpd para iniciar en tiempo de arranque utilizando una
herramienta script de inicialización tal como /sbin/chkconfig, /usr/sbin/ntsysv, o el programa
Services Configuration Tool.
También puede visualizar el estado de su servidor httpd escribiendo:
340
Arrancar y detener httpd
apachectl status
Sin embargo, el módulo de estado mod_status necesita ser habilitado en su archivo de
configuración mod_status para que esto funcione. Para obtener más detalles sobre mod_status
vaya a http://httpd.apache.org/docs/2.2/mod/mod_status.html.
Nota
If running the Apache HTTP Server as a secure server, the secure server's password
is required after the machine boots when using an encrypted private SSL key.
Puede encontrar más información en http://httpd.apache.org/docs/2.2/ssl
22.4. Configuración del Servidor HTTP Apache
The HTTP Configuration Tool allows you to configure the /etc/httpd/conf/httpd.conf
configuration file for the Apache HTTP Server. It does not use the old srm.conf or access.conf
configuration files; leave them empty. Through the graphical interface, you can configure directives
such as virtual hosts, logging attributes, and maximum number of connections. To start the HTTD
Configuration Tool, click on System > Administration > Server Settings > HTTP.
Sólo se pueden configurar con la Herramienta de Configuración HTTPaquellos módulos que
estén incluídos con Red Hat Enterprise Linux. Si se instalanotros módulos, no se podrán configurar
utilizando esta herramienta.
Advertencia
No modifique el archivo de configuración /etc/httpd/conf/httpd.conf
manualmente si desea utilizar esta herramienta. La Herramienta de Configuración
HTTP genera este archivo después de que haya grabado los cambios y haya salido
del programa. Si desea añadir módulos u opciones de configuración que no se
encuentran en la Herramienta de Configuración HTTP no podrá usarla.
Los pasos generales para configurar el Servidor HTTP Apache utilizando la Herramienta de
Configuración HTTP son los siguientes:
1. Configure los aspectos básicos que se encuentran en la pestaña Principal
2. Haga clic en Hosts Virtualesy configure las opciones predeterminadas.
3. Bajo la pestaña Hosts Virtuales configure el Host Virtual Predeterminado.
4. Para servir más de una URL o más de un host virtual, añada cualquierhost virtual adicional.
5. Configure las características del servidor bajo la pestaña Servidor.
6. Configure la configuración de las conexiones bajo la pestaña Ajuste de Rendimiento.
7. Copie todos los archivos necesarios a los directorios DocumentRoot y cgi-bin
8. Salga de la aplicación y seleccione guardar sus configuraciones.
341
Basic Settings
22.4.1. Basic Settings
Use la pestaña Principal para establecer las configuraciones básicas del servidor.
Figura 22.1. Basic Settings
Enter a fullyqualified domain name that you have the right to use in the Server Name text area.
This option corresponds to the ServerName
2
directive in httpd.conf. The ServerName directive
sets the hostname of the Web server. It is used when creating redirection URLs. If you do not
define a server name, the Web server attempts to resolve it from the IP address of the system. The
server name does not have to be the domain name resolved from the IP address of the server. For
example, you might set the server name to www.example.com while the server's real DNS name is
foo.example.com.
Enter the email address of the person who maintains the Web server in the Webmaster email
address text area. This option corresponds to the ServerAdmin
3
directive in httpd.conf. If you
configure the server's error pages to contain an email address, this email address is used so that
users can report a problem to the server's administrator. The default value is root@localhost.
Utilice el área Direcciones Disponibles para definir los puertos en los que el servidor acepta pedidos
entrantes. Esta opción corresponde a la directriz Listen
4
en httpd.conf. Por defecto, Red Hat
configura el Servidor HTTP Apache para que escuche el puerto 80 para comunicaciones de web no
seguras.
2
http://httpd.apache.org/docs/2.2/mod/core.html#servername
3
http://httpd.apache.org/docs/2.2/mod/core.html#serveradmin
4
http://httpd.apache.org/docs/2.2/mod/mpm_common.html#listen
342
Basic Settings
Click the Add button to define additional ports on which to accept requests. A window as shown in
Figura 22.2, “Available Addresses” appears. Either choose the Listen to all addresses option to
listen to all IP addresses on the defined port or specify a particular IP address over which the server
accepts connections in the Address field. Only specify one IP address per port number. To specify
more than one IP address with the same port number, create an entry for each IP address. If at all
possible, use an IP address instead of a domain name to prevent a DNS lookup failure. Refer to http://
httpd.apache.org/docs/2.2/dns-caveats.html for more information about Issues Regarding DNS and
Apache.
Si introduce un asterisco (*) en el campo Direccionesequivaldrá a elegir la opción Escuchar todas
las direcciones. Haga click en el botón Modificar en el recuadro de Direcciones disponibles
muestra la misma ventana que el botón Añadir excepto los campos de la entrada seleccionada. Para
borrar una entrada, seleccionela y haga clic en el botón Eliminar.
Tip
Si configuró el servidor para escuchar en el puerto 1024, deberá ser root para
arrancarlo. Para el puerto 1024 y superiores, se puede arrancar httpd como un
usuario normal.
Figura 22.2. Available Addresses
22.4.2. Configuraciones predeterminadas
Después de definir el Nombre del Servidor, Dirección de correo eletrónico del webmaster y
Direcciones Disponibles haga clic en la pestaña Hosts Virtuales. La figura a continuación ilustra la
pestaña Hosts Virtuales.
343
Configuraciones predeterminadas
Figura 22.3. Virtual Hosts Tab
Al hacer clic en Modificar presentará la ventana de las Propiedades del Host Virtual desde donde
usted puede configurarlo como desee. Para añadir nuevas configuraciones haga clic en el botón
Añadir, el cual también presentará la ventana Propiedades del Host Virtual. Al hacer clic en el
botón Modificar Configuración Predeterminada aparecerá una ventana Propiedades del Host
Virtual sin la pestaña Opciones Generales.
In the General Options tab, you can change the hostname, the document root directory and also set
the webmaster's email address. In the Host information, you can set the Virtual Host's IP Address and
Host Name. The figure below illustrates the General Options tab.
344
Configuraciones predeterminadas
Figura 22.4. General Options
Si añade un host virtual, la configuración del host virtual tiene prioridad para ese host virtual. Para una
directriz no definida dentro de la configuración del host virtual se utiliza el valor predeterminado.
22.4.2.1. Site Configuration
La figura a continuación ilustra la pestaña Opciones de Página desde la cual puede configurar la
Lista de Páginas del Directorio y Páginas de Error. Si no está seguro de esta configuración no la
modifique.
345
Configuraciones predeterminadas
Figura 22.5. Site Configuration
Las entradas que aparecen en la Lista de Búsqueda de Página de Directorio definen la directiva
DirectoryIndex
5
. ElDirectoryIndex es la página predeterminada que el servidor da a un
usuario que pide el índice de un directorio escribiendo la barra inclinada (/) al final del nombre del
directorio.
Por ejemplo, cuando un usuario pide la páginahttp://www.example.com/this_directory/
recibe la página del índice del directorio, DirectoryIndex, si existe, o un listado de directorios
generado por el servidor. El servidor intentará encontrar uno de los archivos incluidos en
DirectoryIndex y entregará el primero que encuentre.
Si no encuentra ninguno de estos archivos y siOptions Indexes está configurado para ese
directorio, el servidor genera y devuelve una lista, en formato HTML, de los subdirectorios y archivos
dentro del directorio.
5
http://httpd.apache.org/docs/2.2/mod/mod_dir.html#directoryindex
346
Configuraciones predeterminadas
Utilice la sección Código Error para configurar el Servidor HTTP Apache para redireccionar el cliente
a una URL local o externa en el caso de que haya un error o un problema. Esta opción corresponde a
la directriz ErrorDocument
6
. Si ocurre un error o si se presenta un problema cuando un clienta trata
de conectarse al Servidor HTTP Apache, la acción predeterminada es presentar un corto mensaje
de error en la columna Código Error. Para cancelar esta configuración predeterminada seleccione el
código error y haga clic en el botón Modificar. Seleccione Predeterminado para visualizar el
mensaje corto de error predeterminado. Elija URL para redireccionar el cliente a la URL externa e
ingresar una URL completa incluyendo el http:// en el campo Location. Seleccione File para
redireccionar el cliente a una URL interna e ingresar la ubicación de un archivo bajo la raíz del
documento para el servidor Web. La ubicación debe comenzar con la barra inclinada (/) y debe estar
relacionada con la Raíz del Documento.
Por ejemplo, para redirigir un código de error 404 Not Found a una página web que usted ha creado
en un archivo llamado 404.html copie 404.html a DocumentRoot/../error/404.html. En
este caso, DocumentRoot es el directorio del documento raíz que ha definido (el valor por defecto es
/var/www/html/). Si se deja el documento raíz como la ubicación por defecto, el archivo debería
ser copiado a /var/www/error/404.html. Luego, elija Archivo como el Comportamiento para el
código de error 404 - Not Found e introduzca /error/404.html como la Ubicación.
Desde el menú Pie de Página de Error por Defecto escoja una de las siguientes opciones:
• Mostrar el pie de página con la dirección de correo electrónico — Esta opción muestra el pie
de página predeterminado en todas las páginas de error junto con la dirección de correo electrónico
del encargado del sitio web especificado por la directriz ServerAdmin
7
.
• Muestra el pie de página — Esta opción le muestra el pie de página predeterminado en todas las
páginas de error.
• Ningún pie de página — No muestra el pie de página en las páginas de error.
22.4.2.2. Soporte SSL
El mod_ssl le permite encriptar el protocolo HTTP sobre SSL. El protocolo SSL(Secure Sockets
Layer) se utiliza para comunicación y para encriptarsobre redes TCP/IP. La pestaña SSL le permite
configurar SSL para su servidor. Para configurar SSL necesita proporcionar la ruta a su:
• Archivo de certificado - equivalente a utilizar la directriz SSLCertificateFile la cual apunta la
ruta al archivo de certificado de servidor codificado PEM (Privacy Enhanced Mail).
• Archivo de la llave - equivalente a utilizar la directriz SSLCertificateKeyFile la cual apunta la
ruta al archivo de la llave privada del servidor codificado PEM.
• Certificate chain file - equivalent to using the SSLCertificateChainFile directive which points
the path to the certificate file containing all the server's chain of certificates.
• Archivo de autoridad del certificado - es un archivo encriptado utilizado para confirmar la
autenticidad o identidad de las partes que se comunican con el servidor.
Puede encontrar más información sobre las directrices de configuración para SSL en http://
httpd.apache.org/docs/2.2/mod/directives.html#S
8
. También necesita determinar que opciones SSL
debe habilitar. Estas son equivalentes a utilizar SSLOptions con las siguientes opciones:
6
http://httpd.apache.org/docs/2.2/mod/core.html#errordocument
8
http://httpd.apache.org/docs/2.2/mod/directives.html#S
Configuraciones predeterminadas
347
• FakeBasicAuth - enables standard authentication methods used by Apache. This means that
the Client X509 certificate's Subject Distinguished Name (DN) is translated into a basic HTTP
username.
• ExportCertData - crea variables de entorno CGI en SSL_SERVER_CERT, SSL_CLIENT_CERT y
SSL_CLIENT_CERT_CHAIN_n en donde n es un número 0,1,2,3,4... Los scripts CGI utilizan estos
archivos para más chequeos de certificados.
• CompatEnvVars - habilita una compatibilidad retroactiva para Apache SSL añadiendo variables de
entorno CGI.
• StrictRequire - habilita acceso estricto el cual obliga a denegar acceso cuando las directrices
SSLRequireSSL y SSLRequire indican que es prohibido el acceso.
• OptRenegotiate - permite eludir los apretones de manos de mod_ssl el cual también realiza
chequeos de parámetros seguros. Se recomienda que habilite OptRenegotiate con base en el
directorio.
Para obtener más información sobre las opciones SSL mencionadas anteriormente vaya a http://
httpd.apache.org/docs/2.2/mod/mod_ssl.html#ssloptions
9
. La figura a continuación ilustra la pestaña
SSL y las opciones que se discutieron anteriormente.
9
http://httpd.apache.org/docs/2.2/mod/mod_ssl.html#ssloptions
Configuraciones predeterminadas
348
Figura 22.6. SSL
22.4.2.3. Logging
Utilice la pestaña Registro para configurar las opciones para registro de errores y transferencia
específica.
Por defecto, el servidor escribe el registro de transferencia en el archivo /var/log/httpd/
access_log y el registro de error en el archivo /var/log/httpd/error_log.
El registro de transferencias contiene una lista de todos los intentos para acceder al servidor web.
Graba las direcciones IP del cliente que está tratande de conectarse, la fecha y hora en que intentó,
y el archivo en el servidor web que está tratando de recuperar. Introduzca el nombre de la ruta y
del archivo en donde se alamacenará esta información. Si el nombre de la ruta y del archivo no
Configuraciones predeterminadas
349
comienzan con una barra inclinada (/), la ruta es relativa al directorio root del servidor como se
configurá. Esta opción corresponde a la directriz TransferLog
10
.
Figura 22.7. Logging
Puede configurar un registro con formato personalizado chequeando Usar las facilidades de
registro personalizado e introduciendo una cadena personalizada en el campo Cadena de
registro personalizada. Esto configura la directriz LogFormat
11
. Para mayor información
sobre los detalles del formato de la directiva consulte http://httpd.apache.org/docs/2.2/mod/
mod_log_config.html#logformat
12
.
El registro de transferencia incluye una lista de los errores del servidor. Introduzca el nombre de la
ruta y del archivo en donde se debe almacenar esta información. Si el nombre de la ruta y del archivo
10
http://httpd.apache.org/docs/2.2/mod/mod_log_config.html#transferlog
11
http://httpd.apache.org/docs/2.2/mod/mod_log_config.html#logformat
12
http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#formats
Configuraciones predeterminadas
350
no empiezan con una barra inclinada (/), la ruta es relativa al directorio root del servidor como se
configuró. Esta opción corresponde a la directriz ErrorLog
13
.
Utilice el menú Nivel de Registro para establecer la verbosidad de los emnsajes de error en los
registrs de error. Se puede configurar (del menos verbos al más verboso) como emerg, alerta, crit,
error, advert, aviso, info o depurar. Esta opción corresponde a la directriz LogLevel
14
.
El valor escogido en el menú Búsqueda inversa del DNS define la directiva HostnameLookups
15
Si
escoge Ninguna búsqueda inversa se desactiva el valor, si escoge Búsqueda inversa el valor está
activado y si escoge Doble búsqueda inversa éste se duplica.
Si escoje Búsuqeda Inversa su servidor resuelve automáticamente la dirección IP para cada
conexión la cual pide un documento de su servidor web. El resolver una dirección IP significa que su
servidor realiza una o más conexiones al DNS para encontrar el nombre del host que corresponde a
una dirección IP en particular.
Si elije Búsqueda Inversa Doble su servidor realiza un DNS inverso doble. Es decir, después de que
se realiza una búsqueda inversa, se realiza una búsqueda avanzada en el resultado. Por lo menos
una de las direcciones IP en la búsqueda vanazada debe coincidir con la dirección de la primera
búqieda inversa.
Generalmente, esta opción debería de estar en Ninguna Búsqueda Inversa porque sino se
sobrecarga al servidor y disminuye el ritmo de trabajo. Si su servidor tiene mucha carga, al tratar de
realizar estas búsquedas, los efectos serán bastante notables.
Reverse lookups and double reverse lookups are also an issue for the Internet as a whole. Each
individual connection made to look up each hostname adds up. Therefore, for your own Web server's
benefit, as well as for the Internet's benefit, you should leave this option set to No Reverse Lookup.
22.4.2.4. Environment Variables
Utilice la pestaña Entorno para configurar las opciones para variables específicas para establecer,
pasar o desconfigurar para scripts CGI.
Algunas veces es necesario modificar las variables del entorno para scripts CGI o páginas server-side
include (SSI). El Servidor HTTP Apache puede usar el módulo mod_env para configurar las variables
del ambiente que son pasadas a los scripts CGI y a las páginas SSI. Utilice la página Variables de
entorno para configurar las directivas para este módulo.
Use the Set for CGI Scripts section to set an environment variable that is passed to CGI scripts and
SSI pages. For example, to set the environment variable MAXNUM to 50, click the Add button inside
the Set for CGIScript section, as shown in Figura 22.8, “Environment Variables”, and type MAXNUM in
the Environment Variable text field and 50 in the Value to set text field. Click OK to add it to the list.
The Set for CGIScripts section configures the SetEnv
16
directive.
Utilice la sección Pasar a los Scripts CGIpara pasar el valor de una variable de entorno cuando
el servidor se inicia por primera vez en scripts CGI. Para ver esta variable de entrada escriba el
comando env en un intérprete de comandos. Haga clic en el botón Añadir dentro de la sección
Pasar a Scripts CGI e introduzca el nombre de la variable de entorno en la ventana de diálogo
13
http://httpd.apache.org/docs/2.2/mod/core.html#errorlog
14
http://httpd.apache.org/docs/2.2/mod/core.html#loglevel
15
http://httpd.apache.org/docs/2.2/mod/core.html#hostnamelookups
16
http://httpd.apache.org/docs/2.2/mod/mod_env.html#setenv
Configuraciones predeterminadas
351
que aparece. Haga clic en OK para añadirla a la lista. La sección Pass to CGIScripts configura la
directriz PasarEnt
17
.
Figura 22.8. Environment Variables
Para eliminar una variable de entorno de manera que el valor no se pase a a los scripts CGI y a las
páginas SSI utilice la sección Desconfigurar para Scripts CGI. Haga clic en Añadir en la sección
Desconfigurar para Scripts CGIe introduzca el nombre de la variable de entorno en desconfigurar.
Haga clic en OK para añadirla a la lista. Esto corresponde a la directriz DesconfigEnt
18
Para modificar cualquier de estos valores de entorno selecciónelo de la lista y haga clic en el botón
Modificar . Para borrar cualquier entrada de la lista selecciónela y haga clic en el botón Eliminar
correspondiente.
17
http://httpd.apache.org/docs/2.2/mod/mod_env.html#passenv
18
http://httpd.apache.org/docs/2.2/mod/mod_env.html#unsetenv
Configuraciones predeterminadas
352
Para obtener más información sobre las variables de entorno en el Servidor HTTP Apache refiérase a:
http://httpd.apache.org/docs/2.2/env.html
22.4.2.5. Directories
Use the Directories page in the Performance tab to configure options for specific directories. This
corresponds to the <Directory>
19
directive.
Figura 22.9. Directories
Click the Edit button in the top right-hand corner to configure the Default Directory Options for all
directories that are not specified in the Directory list below it. The options that you choose are listed
19
http://httpd.apache.org/docs/2.2/mod/core.html#directory
Configuraciones predeterminadas
353
as the Options
20
directive within the <Directory>
21
directive. You can configure the following
options:
• ExecCGI — Permite la ejecución de los scripts CGI. Los scripts no se ejecutan si no elige esta
opción.
• FollowSymLinks — Permite que se sigan enlaces simbólicos.
• Includes — Permite las inclusiones en el servidor (SSI).
• IncludesNOEXEC — Permite las inclusiones en el servidor pero anula los comandos #exec y
#include en los scripts CGI.
• Indexes — Display a formatted list of the directory's contents, if no DirectoryIndex (such as
index.html) exists in the requested directory.
• index.html Soporta las visualizaciones múltiples de los contenidos; esta opción no está activada
por defecto.
• SymLinksIfOwnerMatch — Permite seguir un enlace simbólico sólamente si el archivo o el
directorio en cuestión tienen el mismo propietario que el enlace.
To specify options for specific directories, click the Add button beside the Directory list box. A
window as shown in Figura 22.10, “Directory Settings” appears. Enter the directory to configure in the
Directory text field at the bottom of the window. Select the options in the right-hand list and configure
the Order
22
directive with the left-hand side options. The Order directive controls the order in which
allow and deny directives are evaluated. In the Allow hosts from and Deny hosts from text field, you
can specify one of the following:
• Permitir todas los hosts — Escriba all para permitir el acceso a todos los hosts.
• Nombre parcial de dominio — Permite todas las máquinas cuyos nombres coincidan o terminen con
una cadena determinado.
• Dirección IP completa — Permite el acceso a una determinada dirección IP.
• Una subred — Tal como 192.168.1.0/255.255.255.0
• Una especificación CIDR de red — como por ejemplo 10.3.0.0/16
20
http://httpd.apache.org/docs/2.2/mod/core.html#options
21
http://httpd.apache.org/docs/2.2/mod/core.html#directory
22
http://httpd.apache.org/docs-2.0/mod/mod_access.html#order
Configuraciones predeterminadas
354
Figura 22.10. Directory Settings
Si marca Permitir que los archivos .htaccess pasen por encima de las opciones del directorio
las directivas de configuración en el archivo .htaccess toman precedencia.
22.5. Directrices de configuración en httpd.conf
El archivo de configuración del Servidor HTTP Apache es /etc/httpd/conf/httpd.conf. El
archivo httpd.conf está bien comentado y en gran parte es autoexplicativo. Su configuración por
defecto funciona para la mayoría de los casos; sin embargo, es una buena idea familiarizarse con
algunas de las opciones de configuración más importantes.
Advertencia
With the release of Apache HTTP Server 2.2, many configuration options have
changed. If migrating from version 1.3 to 2.2, please firstly read Sección 22.2.2,
“Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión
1.3 a la 2.0”.
22.5.1. Sugerencias de configuración generales
If configuring the Apache HTTP Server, edit /etc/httpd/conf/httpd.conf and then either
reload, restart, or stop and start the httpd process as outlined in Sección 22.3, “Arrancar y detener
httpd”.
Antes de modificar el archivo httpd.conf, primero haga una copia del archivo original. Al crear una
copia de respaldo se hace más fácil recuperarse de posibles errores cometidos mientras se editaba el
archivo de configuración.
355
Sugerencias de configuración generales
Si comete un error y su servidor de web no funciona correctamente, lo primero que debe realizar es
revisar lo que lo que acaba de modificar en httpd.conf para ver si no hay errores de transcripción.
Next look in the Web server's error log, /var/log/httpd/error_log. The error log may not be
easy to interpret, depending on your level of expertise. However, the last entries in the error log should
provide useful information.
Las siguientes subsecciones proporcionan una breve descripción de muchas de las directrices
incluidas en httpd.conf. Estas descripciones no son exhaustivas. Para obtener más información
consulte la documentación de Apache en línea http://httpd.apache.org/docs/2.2/.
Para obtener mayor información sobre las directrices mod_ssl consulte la documentación en http://
httpd.apache.org/docs/2.2/mod/mod_ssl.html.
AccessFileName
AccessFileName denomina el archivo que el servidor utilizará para información de control de
acceso en cada directorio. Por defecto, el servidor utilizará .htaccess.
Justo tras AccessFileName, un conjunto de indicadores de Files aplican el control de acceso
a cualquier archivo comenzando con un .ht. Estas directrices niegan el acceso Web a cualquier
archivo .htaccess (o otros archivos que comiencen con .ht) por razones de seguridad.
Action
Action especifica parejas tipo contenido MIME y script CGI, para que cuando un archivo de ese tipo
de media sea solicitado, se ejecute un script CGI particular.
AddDescription
Cuando utilice FancyIndexing como un parámetro de IndexOptions, la directriz
AddDescription se puedeusar para mostrar descripciones especificadas por el usuario para
ciertos archivos o tipos de archivo en un listado de directorio generado por el servidor. La directriz
AddDescription soporta el listado de archivos específicos, expresiones con comodines o
extensiones de archivos.
AddEncoding
La directriz AddEncoding nombra las extensiones de archivos que deberían especificar un tipo
particular de codificación. También se puede usar AddEncoding para decirle a los navegadores que
descompriman ciertos archivos mientras los descargan.
AddHandler
La directriz AddHandler hace corresponder extensiones de archivos a manejadores específicos. Por
ejemplo, se puede corresponder el manejador cgi-script con la extensión .cgi para que
automáticamente trate a cualquier archivo con un nombre que termine en .cgi como un script CGI. A
continuaciónse presenta un ejemplo de una directriz AddHandler para la extensión .cgi.
AddHandler cgi-script .cgi
356
Sugerencias de configuración generales
This directive enables CGIs outside of the cgi-bin to function in any directory on the server which
has the ExecCGI option within the directories container. Refer to Directory for more information about
setting the ExecCGI option for a directory.
Además de los scripts CGI, la directriz AddHandler es usada para procesar archivos de mapas de
imagen y HTMLanalizados por el servidor.
AddIcon
AddIcon dice al servidor qué icono mostrar en los listados del directorio para ciertos tipos de
archivos según la extensión. Por ejemplo, el servidor Web muestra el icono binary.gif para
archivos con extensiones .bin o .exe.
AddIconByEncoding
Esta directriz denomina qué iconos se mostrarán con los archivos según su codificación MIME, en los
listados de directorio. Por ejemplo, el servidor muestra por defecto el icono compressed.gif junto a
archivos con codificación MIME x-compress y x-gzip en los listados de directorio.
AddIconByType
Esta directriz denomina qué iconos se mostrarán con los archivos con codificación MIME, en los
listados del directorio. Por ejemplo, por defecto, el servidor muestra el icono text.gif junto a
archivos con tipo MIME text en los listados del directorio.
AddLanguage
AddLanguage associates file name extensions with specific languages. This directive is useful for
Apache HTTP Servers which serve content in multiple languages based on the client Web browser's
language settings.
AddType
Utilice la directriz AddType para definir o suprimir por defecto pares tipo MIME y extensiones
de archivos. El siguiente ejemplo de directriz le dice al Servidor HTTP Apache que reconozca la
extensión de archivos .tgz:
AddType application/x-tar .tgz
Alias
The Alias setting allows directories outside the DocumentRoot directory to be accessible. Any URL
ending in the alias automatically resolves to the alias' path. By default, one alias for an icons/
directory is already set up. An icons/ directory can be accessed by the Web server, but the directory
is not in the DocumentRoot.
Allow
Allow especifica cual cliente puede acceder a un directorio dado. El solicitantepuede ser all, un
nombre de dominio, una dirección IP, una dirección IP parcial, un par de red/máscara de la red, etc.
El directorio DocumentRoot está configurado para permitir (Allow) peticiones desde todos (all), es
decir, que todos tienen acceso.
357
Sugerencias de configuración generales
AllowOverride
La directriz AllowOverride indica si puede o no ignorar cualquiera de las Options por las
declaraciones en un archivo .htaccess. Por defecto, tanto el directorio raíz como DocumentRoot
están configurados para no se permita ignorar .htaccess.
BrowserMatch
The BrowserMatch directive allows the server to define environment variables and take appropriate
actions based on the User-Agent HTTP header field — which identifies the client's Web browser type.
By default, the Web server uses BrowserMatch to deny connections to specific browsers with known
problems and also to disable keepalives and HTTP header flushes for browsers that are known to have
problems with those actions.
Directrices Cache
El archivo de configuración del Servidor HTTP Apache suministra varias directrices de caché
comentadas. En la mayoría de los casos, al quitar el comentario de estas líneas mediante la
eliminación de las almohadillas (#) del principio de la línea es suficiente.Sin embargo, lo siguiente es
una lista de algunas de las directrices relacionadas con caché más importantes.
• CacheEnable — Especifica si la caché es un disco, memoria o caché de archivo descriptivo. Por
defecto CacheEnable configura un disco caché para las URLs en o por debajo de /.
• CacheRoot — pone el nombre del directorio que contiene archivos de caché. El valor
predeterminado de CacheRoot es el directorio /var/httpd/proxy/.
• CacheSize — establece cuánto espacio puede usar el caché, en KB. El valor predeterminado de
CacheSize es 5 KB.
Lo siguiente es una lista de algunas directrices comunes relacionadas con caché.
• CacheMaxExpire — Especifica cuanto tiempo se conservan los documentos HTML(sin una
recarga desde el servidor Web original) en el caché. El valor por defecto es 24 horas (86400
segundos).
• CacheLastModifiedFactor — Especifica la creación de una fecha de vencimiento para
documentos que no venían con caducidad desde el servidor de origen. El valor predeterminado
de CacheLastModifiedFactor está configurado a 0.1, es decir que la fecha de vencimiento
para tales documentos es igual a un décimo de la cantidad de tiempo desde la última vez que se
modificó el documento.
• CacheDefaultExpire — Especifica el tiempo de caducidad en horas para un documento que
fue recibido usando un protocolo que no soporta fechas de vencimiento. El valor por defecto es
configurado a 1 hora (3600 segundos).
• NoProxy — Especifica una lista separada por espacios de subredes, direcciones IP, dominios o
hosts cuyos contenidos no están en caché. Este valor es de gran utilidad para sitios de Intranet.
CacheNegotiatedDocs
Por defecto, el servidor Web requiere a los servidores proxy que no hagan caché de los documentos
que se negocian en base al contenido (pueden cambiar en el tiempo o según la entrada de quien los
solicita). Si se configura CacheNegotiatedDocs a on, se desactiva la función y se permite acceso a
los servidores proxy a tales documentos caché.
358
Sugerencias de configuración generales
CustomLog
CustomLog identifica el archivo de registro y su formato. Por defecto, el registro de acceso es
guardado al archivo /var/log/httpd/access_log mientras que los errores se guardan en el
archivo /var/log/httpd/error_log.
El formato por defecto CustomLog es combined, como se ilustra a aquí:
remotehost rfc931 user date "request" status bytes referrer user-agent
DefaultIcon
DefaultIcon especifica el icono desplegado en el listado generado por el servidor para archivos
que no tienen otro icono especificado. El archivo de imagen por defecto es unknown.gif.
DefaultType
DefaultType establece el tipo de contenido por defecto que el servidor utilizará para documentos
cuyos tipos MIME no puedan ser determinados. Por defecto es text/plain.
Deny
Deny funciona igual que Allow, excepto que especifica a quién se le niega el acceso.
DocumentRoot no es configurado para negar (Deny) peticiones a ninguno por defecto.
Directory
<Directory /path/to/directory> and </Directory> tags create a container used to enclose
a group of configuration directives which apply only to a specific directory and its subdirectories. Any
directive which is applicable to a directory may be used within Directory tags.
By default, very restrictive parameters are applied to the root directory (/), using the Options (refer to
Options) and AllowOverride (refer to AllowOverride) directives. Under this configuration, any
directory on the system which needs more permissive settings has to be explicitly given those settings.
En la configuración predeterminada, otro contenedor Directory es configurado para el
DocumentRoot, el cual asigna parámetros menos rígidos al árbol del directorio para que el Servidor
HTTP Apache pueda acceder a los archivos que residan allí.
The Directory container can be also be used to configure additional cgi-bin directories for server-
side applications outside of the directory specified in the ScriptAlias directive (refer to ScriptAlias
for more information).
Para lograr esto, el contenedor Directory debe configurar la opción ExecCGI para ese directorio.
Por ejemplo, si los scripts CGI están localizados en /home/my_cgi_directory, añada el
contenedor siguiente Directory al archivo httpd.conf:
<Directory /home/my_cgi_directory> Options +ExecCGI </Directory>
Next, the AddHandler directive must be uncommented to identify files with the .cgi extension as
CGI scripts. Refer to AddHandler for instructions on setting AddHandler.
359
Sugerencias de configuración generales
Para que esto funcione, los permisos para los scripts CGI y la ruta completa a los scripts, se deben
colocar a 0755.
DirectoryIndex
DirectoryIndex es la página por defecto que entrega el servidor cuando hay una petición de índice
de un directorio especificado con una barra (/) al final del nombre del directorio.
Cuando un usuario pide la página http://ejemplo/este_directorio/, recibe la página del índice
del directorio, DirectoryIndex, si existe, o un listado de directorios generado por el servidor. El
valor por defecto para DirectoryIndex es index.html y el tipo de mapa index.html.var. El
servidor intentará encontrar cualquiera de estos archivos y entregará el primero que encuentre. Si no
encuentra ninguno de estos archivos y Options Indexes esta configurado para ese directorio, el
servidor genera y devuelve una lista, en formato HTML, de los subdirectorios y archivos dentro del
directorio, a menos que la característica de listar directorios esté desactivada.
DocumentRoot
DocumentRoot es el directorio que contiene la mayoría de los archivos HTML que se entregarán en
respuesta a peticiones. El directorio predeterminado DocumentRoot para servidores web seguros y
no seguros es /var/www/html. Por ejemplo, el servidor puede recibir una petición para el siguiente
documento:
http://example.com/foo.html
El servidor busca por el archivo siguiente en el directorio por defecto:
/var/www/html/foo.html
To change the DocumentRoot so that it is not shared by the secure and the non-secure Web servers,
refer to Sección 22.7, “Hosts virtuales”.
ErrorDocument
La directriz ErrorDocument asocia un código de respuesta HTTP con un mensaje o un URL para
que sea devuelto al cliente. Por defecto, el servidor Web produce una salida simple de mensaje de
error cuando ocurre alguno. La directriz ErrorDocument obliga a que el servidor Web envie una
salida de mensaje personalizado o página.
Importante
To be valid, the message must be enclosed in a pair of double quotes ".
ErrorLog
ErrorLog especifica el archivo donde se guardan los errores del servidor . Por defecto, esta directriz
es configurada a /var/log/httpd/error_log.
360
Sugerencias de configuración generales
ExtendedStatus
The ExtendedStatus directive controls whether Apache generates basic (off) or detailed server
status information (on), when the server-status handler is called. The server-status handler is
called using Location tags. More information on calling server-status is included in Location.
Group
Especifica el nombre del grupo de los procesos del Servidor HTTP Apache.
Esta directriz se ha desaprobado para la configuración de hosts virtuales.
Por defecto, Group está configurado a apache.
HeaderName
La directriz HeaderName dicta el archivo (si existe dentro del directorio) que se antepondrá al
comienzo de los listados de los directorios. Al igual que con ReadmeName, el servidor intentará
incluirlo como documento HTMLsi es posible, o en caso contrario, como texto.
HostnameLookups
HostnameLookups se puede configurar a on, off o double. Si se configura HostnameLookups
a on, el servidor automáticamente resuelve las direcciones IP para cada conexión. Resolver las
direcciones IP significa que el servidor hace una o más conexiones a un servidor DNS, añadiendo
sobrecarga por procesamiento. Si HostnameLookups es configurado a double, el servidor realiza
búsquedas inversa doble del DNS, añadiendo aún más sobrecarga.
Para ahorrar recursos en el servidor, HostnameLookups es configurado a off por defecto.
Si se requieren nombres de host en los archivos de registro, considere ejecutar una de los muchas
herramientas de análisis de log que llevan a cabo las búsquedas de DNS de forma mucho más
eficiente y por montones cuando se este rotandolos archivos de log del servidor Web.
IfDefine
The IfDefine tags surround configuration directives that are applied if the "test" stated in the
IfDefine tag is true. The directives are ignored if the test is false.
The test in the IfDefine tags is a parameter name (for example, HAVE_PERL). If the parameter is
defined, meaning that it is provided as an argument to the server's start-up command, then the test is
true. In this case, when the Web server is started, the test is true and the directives contained in the
IfDefine tags are applied.
IfModule
<IfModule> and </IfModule> tags create a conditional container which are only activated if the
specified module is loaded. Directives within the IfModule container are processed under one of two
conditions. The directives are processed if the module contained within the starting <IfModule> tag is
loaded. Or, if an exclamation point ! appears before the module name, the directives are processed
only if the module specified in the <IfModule> tag is not loaded.
361
Sugerencias de configuración generales
For more information about Apache HTTP Server modules, refer to Sección 22.6, “Añadir módulos”.
Include
Include permite que se incluyan otros archivos de configuración en el tiempo de ejecución.
La ruta a estos archivos de configuración pueden ser absolutas o relativas con respecto al
ServerRoot.
Importante
Para que el servidor use módulos de paquetes individuales, como mod_ssl,
mod_perl y php, tiene que estar la siguiente directriz en Section 1: Global
Environment del httpd.conf:
Include conf.d/*.conf
IndexIgnore
IndexIgnore lista las extensiones de archivo, los nombres de los archivos parciales, las
expresiones con comodines o los nombres completos. El servidor Web no incluirá ningún archivo que
coincida con estos patrones en los listados de directorios.
IndexOptions
IndexOptions controls the appearance of server generated directing listings, by adding icons, file
descriptions, and so on. If Options Indexes is set (refer to Options), the Web server generates a
directory listing when the Web server receives an HTTP request for a directory without an index.
Primero el servidor Web busca en el directorio solicitado un archivo que coincida los nombres listados
en la directriz DirectoryIndex (usualmente, index.html). Si el servidor no encuentra un archivo
index.html el Servidor HTTP Apache genera un listado del directorio en HTML. La apariencia del
listado de este directorio es controlada, en parte, por la directriz IndexOptions.
La configuración predeterminada activa FancyIndexing. Esto significa que un usuario puede
reordenar un listado de directorio haciendo clic en las cabeceras de columnas. Otro clic en la misma
cabecera cambiará del orden ascendente al descendente. FancyIndexing también muestra iconos
diferentes para diferentes archivos, basados en las extensiones de archivos.
La opción AddDescription, cuando se utiliza junto con FancyIndexing, presenta una descripción
corta para el archivo en los listados de directorios generados por el servidor.
IndexOptions tiene otros parámetros que pueden activarse para controlar la apariencia de los
listados generados por los servidores. Los parámetros IconHeight y IconWidth requieren que
el servidor incluya etiquetas HTML HEIGHT y WIDTH para los iconos en las páginas generadas por
el servidor. El parámetro IconsAreLinks combina el icono con el ancla HTML, la cual contiene el
enlace URL objetivo.
KeepAlive
KeepAlive sets whether the server allows more than one request per connection and can be used to
prevent any one client from consuming too much of the server's resources.
362
Sugerencias de configuración generales
By default Keepalive is set to off. If Keepalive is set to on and the server becomes very busy, the
server can quickly spawn the maximum number of child processes. In this situation, the server slows
down significantly. If Keepalive is enabled, it is a good idea to set the the KeepAliveTimeout low
(refer to KeepAliveTimeout for more information about the KeepAliveTimeout directive) and monitor
the /var/log/httpd/error_log log file on the server. This log reports when the server is running
out of child processes.
KeepAliveTimeout
La directriz KeepAliveTimeout establece el número de segundos que el servidor esperará tras
haber dado servicio a una petición, antes de cerrar la conexión. Una vez que el servidor recibe una
petición, se aplica la directriz Timeout en su lugar. KeepAliveTimeout está configurado a 15
segundos por defecto.
LanguagePriority
La directriz LanguagePriority permite dar la prioridad para diferentes idiomas en caso de que el
navegador Web no especique la preferencia de idioma.
Listen
El comando Listen identifica los puertos en los que el servidor Web aceptará las peticiones
entrantes. Por defecto, el Servidor HTTP Apache está configurado para escuchar en el puerto 80 para
comunicaciones Web no seguras y (en el archivo /etc/httpd/conf.d/ssl.conf el cual define
cualquier servidor seguro) en el puerto 443 para comunicaciones seguras.
Si el Servidor HTTP Apache está configurado para escuchar en un puerto por debajo del 1024,
se necesita al usuario root para iniciarlo. Para los puertos 1024 y superiores, httpd puede ser
arrancado por cualquier usuario.
La directriz Listen también se puede usar para especificar direcciones IP particulares sobre las
cuales el servidor aceptará conexiones.
LoadModule
LoadModule is used to load Dynamic Shared Object (DSO) modules. More information on the
Apache HTTP Server's DSO support, including instructions for using the LoadModule directive, can
be found in Sección 22.6, “Añadir módulos”. Note, the load order of the modules is no longer important
with Apache HTTP Server 2.0. Refer to Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object
(DSO) (Objeto dinámico compartido)” for more information about Apache HTTP Server 2.0 DSO
support.
Location
The <Location> and </Location> tags create a container in which access control based on URL
can be specified.
For instance, to allow people connecting from within the server's domain to see status reports, use the
following directives:
<Location /server-status> SetHandler server-status Order deny,allow Deny from all Allow
from <.example.com> </Location>
363
Sugerencias de configuración generales
Replace <.example.com> with the second-level domain name for the Web server.
Para proporcionarinformes de configuración del servidor (incluyendo los módulos instalados y las
directrices de configuración) a peticiones desde dentro del dominio, utilice las siguientes directrices:
<Location /server-info> SetHandler server-info Order deny,allow Deny from all Allow
from <.example.com> </Location>
Again, replace <.example.com> with the second-level domain name for the Web server.
LogFormat
The LogFormat directive configures the format of the various Web server log files. The actual
LogFormat used depends on the settings given in the CustomLog directive (refer to CustomLog).
Las siguientes son las opciones de formato si la directriz CustomLog es configurada a combined:
%h (remote host's IP address or hostname)
Lista la dirección IP de la máquina remota del cliente solicitante. Si HostnameLookups es
configurada a on, el nombre de máquina del cliente es registrado a menos que no este disponible
desde el DNS.
%l (rfc931)
No se usa. Un guión - aparece en el campo de registro para este campo.
%u (usuario autenticado)
Si se requiere autenticación,lista el nombre del usuario registrado. Usualmente, esto no se utiliza,
por tanto aparece un guión - en el archivo de registro para este campo.
%t (fecha)
Lista la fecha y hora de la solicitud.
%r (cadena de la solicitud)
Lista la cadena de la solicitud exactamente como viene del navegador o cliente.
%s (estado)
Lista el estado de código HTTP el cual fue devuelto al host cliente.
%b (bytes)
Lista el tamaño del documento.
%"%{Referer}i" (referrer)
Lista la dirección URL de la página web que refiere el máquina cliente al servidor Web.
%"%{User-Agent}i" (user-agent)
Lista el tipo de navegador Web que está realizandola solicitud.
LogLevel
LogLevel establece la cantidad de detalles que tendrán los registros de mensajes de error.
LogLevel se puede configurar (desde el que tiene menos detalles a los más detallados) a emerg,
alert, crit, error, warn, notice, info o debug. El valor predeterminado de LogLevel es
warn.
364
Sugerencias de configuración generales
MaxKeepAliveRequests
This directive sets the maximum number of requests allowed per persistent connection. The Apache
Project recommends a high setting, which improves the server's performance.
MaxKeepAliveRequests is set to 100 by default, which should be appropriate for most situations.
NameVirtualHost
La directriz NameVirtualHost asocia una dirección IP y el número de puerto, si es necesario, para
cualquier máquina virtual basada en nombres. El hospedaje virtual basado en nombres permite a un
Servidor HTTP Apache servir a dominios diferentes sin utilizar múltiples direcciones IP.
Nota
Los hosts virtuales basados en nombre only funcionan con conexiones HTTP no
seguras. Si está usando host virtuales con un servidor seguro, use host virtuales
basados en direcciones IP.
Para habilitar el hospedaje basado en nombres, quite los comentarios de la directriz de configuración
NameVirtualHost y añada la dirección IP correcta. Luego añada más contenedores VirtualHost
para cada host virtual como sea necesario para su configuración.
Options
La directriz Options controla cuáles características del servidor están disponibles en un directorio en
particular. Por ejemplo, en los parámetros restrictivos especificados para el directorio raíz, Options
sólo permite FollowSymLinks. No hay características activadas, salvo que el servidor puede seguir
enlaces simbólicos en el directorio raíz.
Por defecto, en el directorio DocumentRoot, Options se configura para incluir Indexes y
FollowSymLinks. Indexes permite al servidor generar un listado de un directorio si no se
especifica el DirectoryIndex (por ejemplo, index.html). FollowSymLinks permite al servidor
seguir enlaces simbólicos en ese directorio.
Nota
Options statements from the main server configuration section need to be
replicated to each VirtualHost container individually. Refer to VirtualHost for more
information.
Order
La directriz Order controla el orden en el cual las directrices allow y deny son evaluadas. El
servidor es configurado para evaluar las directrices Allow antes de las directrices Deny para el
directorio DocumentRoot.
PidFile
PidFile nombra el archivo en el que el servidor graba su ID de proceso (pid). Por defecto, el PID es
listado en /var/run/httpd.pid.
365
Sugerencias de configuración generales
Proxy
<Proxy *> and </Proxy> tags create a container which encloses a group of configuration directives
meant to apply only to the proxy server. Many directives which are allowed within a <Directory>
container may also be used within <Proxy> container.
ProxyRequests
To configure the Apache HTTP Server to function as a proxy server, remove the hash mark (#) from
the beginning of the <IfModule mod_proxy.c> line, the ProxyRequests, and each line in the
<Proxy> stanza. Set the ProxyRequests directive to On, and set which domains are allowed access
to the server in the Allow from directive of the <Proxy> stanza.
ReadmeName
La directriz ReadmeName determina el archivo (si existe dentro del directorio) que se adjuntará a los
listados de los directorios. El servidor Web intentará primero incluirlo como documento HTMLy luego
como texto plano. El valor predeterminado de ReadmeName es README.html.
Redirect
Cuando se mueve una página web, se puedeutilizar Redirect para crear asignaciones de la
ubicación del archivo a un nuevo URL. El formato es como sigue:
Redirect /<old-path>/<file-name> http://<current-domain>/<current-path>/<file-name>
In this example, replace <old-path> with the old path information for <file-name> and
<current-domain> and <current-path> with the current domain and path information for
<file-name>.
In this example, any requests for <file-name> at the old location is automatically redirected to the
new location.
Para técnicas de redireccionamiento más avanzadas, utilice el módulo mod_rewrite incluido
con el Servidor HTTP Apache. Para obtener más información sobre la configuración del módulo
mod_rewrite refiérase a la documentación de la Apache Software Foundation en http://
httpd.apache.org/docs/2.2/mod/mod_rewrite.html
23
.
ScriptAlias
La directriz ScriptAlias define donde pueden encontrarse los scripts CGI. Normalmente, no es
una buena idea colocar los scripts CGI dentro de DocumentRoot, donde podrían, potencialmente,
ser visualizados como documentos de texto. Por esta razón, la directriz ScriptAlias diseña un
directorio especial fuera del directorio DocumentRoot para contener ejecutables del servidor y
scripts. Este directorio es conocido como un cgi-bin y se configura por defecto a /var/www/cgi-
bin/.
It is possible to establish directories for storing executables outside of the cgi-bin/ directory. For
instructions on doing so, refer to AddHandler and Directory.
23
http://httpd.apache.org/docs/2.2/mod/mod_rewrite.html
366
Sugerencias de configuración generales
ServerAdmin
Configure la directriz ServerAdmin a la dirección de correo electrónico del administrador del servidor
Web. Esta dirección de correo aparecerá en los mensajes de error en las páginas generadas por
el servidor Web, de tal manera que los usuarios pueden comunicar errores enviando correo al
administrador.
Por defecto, ServerAdmin es configurado a root@localhost.
Una forma típica de configurar ServerAdmin es configurarlo en a webmaster@ejemplo.com. Una
vez configurado, cree un alias del webmaster para la persona responsable del servidor Web en /
etc/aliases y ejecute /usr/bin/newaliases.
ServerName
ServerName specifies a hostname and port number (matching the Listen directive) for the server.
The ServerName does not need to match the machine's actual hostname. For example, the Web
server may be www.example.com, but the server's hostname is actually foo.example.com. The
value specified in ServerName must be a valid Domain Name Service (DNS) name that can be
resolved by the system — do not make something up.
Lo siguiente es una directriz ServerName de ejemplo:
ServerName www.example.com:80
Cuando especifique un ServerName, asegúrese de que el par de la dirección IP y el nombre del
servidor esten incluidos en el archivo /etc/hosts.
ServerRoot
The ServerRoot directive specifies the top-level directory containing website content. By default,
ServerRoot is set to "/etc/httpd" for both secure and non-secure servers.
ServerSignature
La directriz ServerSignature añade una línea que contiene la versión del Servidor HTTP Apache
y el ServerName para cualquier documento generado por el servidor, tales como mensajes de error
devueltos a los clientes. Por defecto ServerSignature está configurada a on.
ServerSignature se puede configurar como EMail el cual añade una etiqueta HTML
mailto:ServerAdmin a la línea de firma de respuestas auto generadas. Tambiénse puede
configurar como Off para que Apache pare de enviar su número de versión y la información del
módulo. Revise también la configuración de ServerTokens.
ServerTokens
La directriz ServerTokens determina si el encabezamiento de la respuesta del servidor que se
devuelve al cliente debe incluir detalles sobre el tipo de Sistema Operativo e información sobre
los módulos compilados. Por defecto, ServerTokens se encuentra configurado como Full y por
tanto envía información sobre el tipo del Sistema Operativo y lo módulos compilados. Al configurar
ServerTokens como Prod envía el nombre del producto sólamente y se recomienda un buen
número de hackers revise la información en el encabezamiento del servidor en la búsqueda de
vulnerabilidades. También puede configurar ServerTokens como Min (minimal) o como OS (sistema
operativo).
367
Sugerencias de configuración generales
SuexecUserGroup
La directriz SuexecUserGroup, que se origina desde el módulo mod_suexec, permite especificar
privilegios de ejecución de usuario y grupo para programas CGI. Las solicitudes no CGI también son
procesadas con el usuario y el grupo especificado en las directrices User y Group.
Nota
Desde la versión 2.0, la directriz SuexecUserGroup reemplaza la configuración del
Servidor HTTP Apache versión 1.3 de utilizar las directrices User y Group dentro de
la configuración de las secciones VirtualHosts.
Timeout
Timeout define, en segundos, el tiempo que el servidor esperará por recibir y transmitir durante la
comunicación. Timeout está configurado por defecto a 300 segundos, lo cual es apropiado para la
mayoría de las situaciones.
TypesConfig
TypesConfig nombra el archivo que configura la lista por defecto de asignaciones tipo MIME
(extensiones de nombres de archivo a tipos de contenido). El archivo predeterminado TypesConfig
es /etc/mime.types. En vez de modificar el /etc/mime.types, la forma recomendada de añadir
asignaciones de tipo MIME es usando la directriz AddType.
For more information about AddType, refer to AddType.
UseCanonicalName
Cuando se configure esta directriz como on, se está indicando al Servidor HTTP Apache a que se
referencie asímismo utilizando el valor especificado en las directrices ServerName y Port. Cuando
UseCanonicalName es configurada como off, el servidor usará el valor usado por el cliente
solicitante cuando se refiera a él.
UseCanonicalName está configurada a off por defecto.
User
La directriz User establece el nombre de usuario para el proceso del servidor y determina qué
archivos pueden acceder al servidor. Cualquier archivo que no esté accesible a este usuario tampoco
estará disponiblepara los clientes conectándose al Servidor HTTP Apache.
Por defecto User es configurado a apache.
Esta directriz se ha desaprobado para la configuración de hosts virtuales.
Nota
Por razones de seguridad, el Servidor HTTP Apache no se ejecuta como el usuario
root.
368
Sugerencias de configuración generales
UserDir
UserDir is the subdirectory within each user's home directory where they should place personal
HTMLfiles which are served by the Web server. This directive is set to disable by default.
El nombre para el subdirectorio esta configurado a public_html en la configuración por defecto. Por
ejemplo, el servidor puede recibir la siguiente petición:
http://example.com/~username/foo.html
El servidor buscará por el archivo:
/home/username/public_html/foo.html
In the above example, /home/username/ is the user's home directory (note that the default path to
users' home directories may vary).
Make sure that the permissions on the users' home directories are set correctly. Users' home
directories must be set to 0711. The read (r) and execute (x) bits must be set on the users'
public_html directories (0755 also works). Files that are served in a users' public_html
directories must be set to at least 0644.
VirtualHost
<VirtualHost> and </VirtualHost> tags create a container outlining the characteristics of a
virtual host. The VirtualHost container accepts most configuration directives.
A commented VirtualHost container is provided in httpd.conf, which illustrates the minimum set
of configuration directives necessary for each virtual host. Refer to Sección 22.7, “Hosts virtuales” for
more information about virtual hosts.
Nota
El contenedor de host virtuales SSL por defecto reside en el archivo /etc/httpd/
conf.d/ssl.conf.
22.5.2. Configuración de directrices para SSL
Las directrices en el archivo /etc/httpd/conf.d/ssl.conf se pueden configurar para activar las
comunicaciones Web seguras usando SSL y TLS.
SetEnvIf
SetEnvIf sets environment variables based on the headers of incoming connections. It is not solely
an SSL directive, though it is present in the supplied /etc/httpd/conf.d/ssl.conf file. It's
purpose in this context is to disable HTTP keepalive and to allow SSL to close the connection without
a closing notification from the client browser. This setting is necessary for certain browsers that do not
reliably shut down the SSL connection.
Para más información sobre otras directrices dentro del archivo de configuración SSL, consulte los
siguientes URLs:
369
Directrices MPM específicas al pool de servidores
• http://localhost/manual/mod/mod_ssl.html
• http://httpd.apache.org/docs/2.2/mod/mod_ssl.html
Nota
En la mayoría de los casos, las directrices SSL son configuradas apropiadamente
durante la instalación de Red Hat Enterprise Linux. Tenga cuidado cuando altere las
directrices del Servidor Seguro HTTP de Apache pues un error en la configuración
puede provocar que el servidor sea vulnerable en términos de seguridad.
22.5.3. Directrices MPM específicas al pool de servidores
As explained in Sección 22.2.2.1.2, “Regulación del tamaño del pool de servidores”, the responsibility
for managing characteristics of the server-pool falls to a module group called MPMs under Apache
HTTP Server 2.0. The characteristics of the server-pool differ depending upon which MPM is used.
For this reason, an IfModule containeris necessary to define the server-pool for the MPM in use.
Por defecto, el Servidor HTTP Apache 2.0 define el pool de servidores para ambos MPMs: prefork
y worker.
La sección siguiente lista las directrices encontradas dentro de los contenedores del pool de
servidores específicos al MPM.
MaxClients
MaxClients sets a limit on the total number of server processes, or simultaneously connected
clients, that can run at one time. The main purpose of this directive is to keep a runaway Apache
HTTP Server from crashing the operating system. For busy servers this value should be set to
a high value. The server's default is set to 150 regardless of the MPM in use. However, it is not
recommended that the value for MaxClients exceeds 256 when using the prefork MPM.
MaxRequestsPerChild
MaxRequestsPerChild establece el número máximo de peticiones que cada proceso de servidor
hijo procesa antes de morir. La principal razón para configurar MaxRequestsPerChild es evitar que
procesos de larga vida gasten memoria. El valor predeterminado de MaxRequestsPerChild para el
MPM prefork es de 4000 y, para el MPM worker, es 0.
MinSpareServers y MaxSpareServers
Estos valores solamente se utilizan con el MPM prefork. Ellos ajustan como el Servidor HTTP
Apache se adapta dinámicamente a la carga percibida manteniendo un número apropiado de
procesos de servidor extras o de repuesto basado en el número de peticiones entrantes. El
servidor comprueba el número de servidores que esperan peticiones y elimina algunos si el número
es más alto que MaxSpareServers o crea algunos si el número de servidores es menor que
MinSpareServers.
El valor predeterminado de MinSpareServers es 5 y el de MaxSpareServers es 20. Estos valores
predeterminados son suficientes en la mayoría de los casos. Tenga cuidado de no incrementar
el número de MinSpareServers a un número muy elevado ya que creará una gran carga de
procesamiento, incluso cuando el tráfico fuese bajo.
370
Directrices MPM específicas al pool de servidores
MinSpareThreads y MaxSpareThreads
Estos valores solamente son utilizado con el MPM worker. Ellos ajustan como el Servidor HTTP
Apache se adapta dinámicamente a la carga percibida manteniendo un número apropiado de hilos
de servidores extras basado en el número de peticiones entrantes. El servidor comprueba el número
de hilos de servidores que esperan peticiones y elimina algunos si el número es más alto que
MaxSpareThreads o crea algunos si el número de servidores es menor que MinSpareThreads.
El valor predeterminado de MinSpareThreads es 25 y el de MaxSpareThreads es
75. Estos valores predeterminados son apropiados en la mayoría de los casos. El valor para
MaxSpareThreads debe ser mayor o igual que la suma de MinSpareThreads y
ThreadsPerChild, de lo contrario el Servidor HTTP Apache lo corregirá automáticamente.
StartServers
La directriz StartServers establece cuántos procesos de servidor serán creados al arrancar.
Ya que el servidor Web crea y elimina dinámicamente procesos de servidor según el tráfico, no se
necesitará cambiar este parámetro. El servidor web está configurado para arrancar 8 procesos del
servidor al arrancar para el MPM prefork y 2 para el MPM worker.
ThreadsPerChild
Este valor solamente es utilizado con el MPM worker. Configura el número de hilos dentro de cada
proceso hijo. El valor por defecto para esta directriz es 25.
22.6. Añadir módulos
El Servidor HTTP Apache se distribuye con un número de módulos. Para obtener más información
sobre los módulos HTTP Apache diríjase a http://httpd.apache.org/docs/2.2/mod/.
El Servidor HTTP Apache soporta Objetos Compartidos Dinámicamente (Dynamically Shared
Objects, DSOs) o módulos, los cuales se pueden cargar fácilmente en el momento de ejecución.
El Proyecto Apache proporciona Documentación DSO completa en línea en http://httpd.apache.org/
docs/2.2/dso.html. Si el paquete http-manual está instalado,se puede encontrar documentación
sobre DSOs en http://localhost/manual/mod/.
For the Apache HTTP Server to use a DSO, it must be specified in a LoadModule directive within
/etc/httpd/conf/httpd.conf. If the module is provided by a separate package, the line
must appear within the modules configuration file in the /etc/httpd/conf.d/ directory. Refer to
LoadModule for more information.
If adding or deleting modules from http.conf, Apache HTTP Server must be reloaded or restarted,
as referred to in Sección 22.3, “Arrancar y detener httpd”.
Si está creando un nuevo módulo, instale primero el paquete httpd-devel pues contiene los
archivos include, las cabeceras de archivos así como también la aplicación APache eXtenSion (/
usr/sbin/apxs), la cual utiliza los archivos include y las cabeceras para compilar DSOs.
Después de escribir un módulo, utilice /usr/sbin/apxs para compilar las fuentes del módulo fuera
del árbol de fuentes Apache. Para obtener más información sobre el uso del comando /usr/sbin/
apxs, vea la documentación de Apache en línea en http://httpd.apache.org/docs/2.2/dso.html y en la
página man de apxs.
371
Hosts virtuales
Una vez compilado, coloque el módulo en el directorio /usr/lib/httpd/modules/. Para las
plataformas RHEL que utilizan el espacio de usuario de 64 bits predeterminado (x86_64, ia64, ?)
esta ruta será /usr/lib64/httpd/modules/. Luego añada una línea LoadModule al archivo
httpd.conf usando la siguiente estructura:
LoadModule <module-name> <path/to/module.so>
Where <module-name> is the name of the module and <path/to/module.so> is the path to the
DSO.
22.7. Hosts virtuales
The Apache HTTP Server's built in virtual hosting allows the server to provide different information
based on which IP address, hostname, or port is being requested. A complete guide to using virtual
hosts is available online at http://httpd.apache.org/docs/2.2/vhosts/.
22.7.1. Configuración de máquinas virtuales
Para crear un host virtual basado en nombre, lo mejor es utilizar el contenedor del host virtual
proporcionado en httpd.conf como un ejemplo.
El ejemplo de máquina virtual se lee como sigue:
#NameVirtualHost *:80
#
#<VirtualHost *:80>
# ServerAdmin webmaster@dummy-host.example.com
# DocumentRoot /www/docs/dummy-host.example.com
# ServerName dummy-host.example.com
# ErrorLog logs/dummy-host.example.com-error_log
# CustomLog logs/dummy-host.example.com-access_log common #</VirtualHost>
Para activar máquinas virtuales basadas en nombre, quite los comentarios de la línea
NameVirtualHost eliminando el símbolo de numeral o almohadilla (#) y reemplazando el asterísco
(*) con la dirección IP asignada a la máquina.
Next, configure a virtual host by uncommenting and customizing the <VirtualHost> container.
On the <VirtualHost> line, change the asterisk (*) to the server's IP address. Change the
ServerName to a valid DNS name assigned to the machine, and configure the other directives as
necessary.
The <VirtualHost> container is highly customizable and accepts almost every directive available
within the main server configuration.
Tip
Si se está configurandoun host virtual para que escuche en un puerto no
predeterminado, se debe agregar ese puerto a la directriz Listen en la sección de
configuraciones globales del archivo /etc/httpd/conf/http.conf.
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server
22  apache http server

Más contenido relacionado

La actualidad más candente

Apache2 dia1
Apache2 dia1Apache2 dia1
Apache2 dia1lyonel_cc
 
Reporte servicios web
Reporte servicios webReporte servicios web
Reporte servicios webFacebook
 
Guía detallada de infraestructura común para la implementación de windows ser...
Guía detallada de infraestructura común para la implementación de windows ser...Guía detallada de infraestructura común para la implementación de windows ser...
Guía detallada de infraestructura común para la implementación de windows ser...Ing Jaab
 
VERSIONES DE Windows server 2012 R2 -technology
VERSIONES DE Windows server 2012 R2 -technologyVERSIONES DE Windows server 2012 R2 -technology
VERSIONES DE Windows server 2012 R2 -technologybenito vargas condor
 
Requerimientos de instalacion
Requerimientos de instalacionRequerimientos de instalacion
Requerimientos de instalacionLuis Maza
 
Requeriminetos de sgbd oracle
Requeriminetos de sgbd oracleRequeriminetos de sgbd oracle
Requeriminetos de sgbd oracleMarcos Vazquez
 
Introduccion A Windows Server 2003
Introduccion A Windows Server 2003Introduccion A Windows Server 2003
Introduccion A Windows Server 2003RiChArD13
 
Práctica 3 FTP
Práctica 3 FTPPráctica 3 FTP
Práctica 3 FTPTerrafx9
 
Servidor ftp1
Servidor ftp1Servidor ftp1
Servidor ftp1sindikto
 
Instalacion remota pxe
Instalacion remota pxe Instalacion remota pxe
Instalacion remota pxe Daniel Patiño
 
Centos 6.5 Servidor Básico
Centos 6.5 Servidor BásicoCentos 6.5 Servidor Básico
Centos 6.5 Servidor Básicocyberleon95
 
Servidor de Correo Seguro en Linux
Servidor de Correo Seguro en LinuxServidor de Correo Seguro en Linux
Servidor de Correo Seguro en LinuxAndrez12
 
Apache: instalación y configuración en Ubuntu Server y Windows Server
Apache: instalación y configuración en Ubuntu Server y Windows ServerApache: instalación y configuración en Ubuntu Server y Windows Server
Apache: instalación y configuración en Ubuntu Server y Windows ServerNombre Apellidos
 

La actualidad más candente (19)

Apache2 dia1
Apache2 dia1Apache2 dia1
Apache2 dia1
 
Sumario
SumarioSumario
Sumario
 
Reporte servicios web
Reporte servicios webReporte servicios web
Reporte servicios web
 
Guía detallada de infraestructura común para la implementación de windows ser...
Guía detallada de infraestructura común para la implementación de windows ser...Guía detallada de infraestructura común para la implementación de windows ser...
Guía detallada de infraestructura común para la implementación de windows ser...
 
VERSIONES DE Windows server 2012 R2 -technology
VERSIONES DE Windows server 2012 R2 -technologyVERSIONES DE Windows server 2012 R2 -technology
VERSIONES DE Windows server 2012 R2 -technology
 
Requerimientos de instalacion
Requerimientos de instalacionRequerimientos de instalacion
Requerimientos de instalacion
 
Requeriminetos de sgbd oracle
Requeriminetos de sgbd oracleRequeriminetos de sgbd oracle
Requeriminetos de sgbd oracle
 
Guia postfix
Guia postfixGuia postfix
Guia postfix
 
Introduccion A Windows Server 2003
Introduccion A Windows Server 2003Introduccion A Windows Server 2003
Introduccion A Windows Server 2003
 
Configuracion de cent os
Configuracion de cent osConfiguracion de cent os
Configuracion de cent os
 
Práctica 3 FTP
Práctica 3 FTPPráctica 3 FTP
Práctica 3 FTP
 
Servidor ftp1
Servidor ftp1Servidor ftp1
Servidor ftp1
 
Instalacion remota pxe
Instalacion remota pxe Instalacion remota pxe
Instalacion remota pxe
 
Centos 6.5 Servidor Básico
Centos 6.5 Servidor BásicoCentos 6.5 Servidor Básico
Centos 6.5 Servidor Básico
 
Servidor de Correo Seguro en Linux
Servidor de Correo Seguro en LinuxServidor de Correo Seguro en Linux
Servidor de Correo Seguro en Linux
 
Windows 2012 Server
Windows 2012 ServerWindows 2012 Server
Windows 2012 Server
 
Guía instalación koha por paquetes en ubuntu 16.04 lts actualizada
Guía instalación koha por paquetes en ubuntu 16.04 lts actualizadaGuía instalación koha por paquetes en ubuntu 16.04 lts actualizada
Guía instalación koha por paquetes en ubuntu 16.04 lts actualizada
 
Apache: instalación y configuración en Ubuntu Server y Windows Server
Apache: instalación y configuración en Ubuntu Server y Windows ServerApache: instalación y configuración en Ubuntu Server y Windows Server
Apache: instalación y configuración en Ubuntu Server y Windows Server
 
PROXY CENTOS 6.5
PROXY CENTOS 6.5PROXY CENTOS 6.5
PROXY CENTOS 6.5
 

Destacado

Reglamento Sena
Reglamento SenaReglamento Sena
Reglamento SenaDerly ♥
 
Como deve ser a opção pelo lucro presumido (11)98950-3543
Como deve ser a opção pelo lucro presumido (11)98950-3543Como deve ser a opção pelo lucro presumido (11)98950-3543
Como deve ser a opção pelo lucro presumido (11)98950-3543IMPOSTO RENDA DECLARAÇÃO
 
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...mgerver
 
Fredy puerta
Fredy puertaFredy puerta
Fredy puertafredy1771
 
Arnsperger science economique_anthropologie_croissance
Arnsperger science economique_anthropologie_croissanceArnsperger science economique_anthropologie_croissance
Arnsperger science economique_anthropologie_croissancehamdi riadh
 
Quelques Réflexions en vue De Copenhague
Quelques Réflexions en vue De CopenhagueQuelques Réflexions en vue De Copenhague
Quelques Réflexions en vue De Copenhaguemnlienemann
 
Tout savoir sur carfully
Tout savoir sur carfullyTout savoir sur carfully
Tout savoir sur carfullyCarfully
 
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...Ana Maria Souza
 
Introduccionalacriptologia
IntroduccionalacriptologiaIntroduccionalacriptologia
IntroduccionalacriptologiaGabriell Mendez
 
OECD Skills Project
OECD Skills ProjectOECD Skills Project
OECD Skills ProjectOECD
 
International Journal of Business and Management Invention (IJBMI)
International Journal of Business and Management Invention (IJBMI)International Journal of Business and Management Invention (IJBMI)
International Journal of Business and Management Invention (IJBMI)inventionjournals
 
guitar hero- para principiantes
guitar hero- para principiantesguitar hero- para principiantes
guitar hero- para principiantesdevorarmando
 
Folder Sap Business One
Folder Sap Business OneFolder Sap Business One
Folder Sap Business OneMarcos
 
Cuestionario avas y ovas. diana rojas
Cuestionario avas y ovas. diana rojasCuestionario avas y ovas. diana rojas
Cuestionario avas y ovas. diana rojasDICAROR
 
Surface2013 fallwsp
Surface2013 fallwspSurface2013 fallwsp
Surface2013 fallwspJenny Donley
 
Como tomar boas decisoes em projetos?
Como tomar boas decisoes em projetos?Como tomar boas decisoes em projetos?
Como tomar boas decisoes em projetos?Moises Luna, PMP
 
Guia De Murales En MéXico
Guia De Murales En MéXicoGuia De Murales En MéXico
Guia De Murales En MéXicoMaria Irma
 

Destacado (20)

Reglamento Sena
Reglamento SenaReglamento Sena
Reglamento Sena
 
Como deve ser a opção pelo lucro presumido (11)98950-3543
Como deve ser a opção pelo lucro presumido (11)98950-3543Como deve ser a opção pelo lucro presumido (11)98950-3543
Como deve ser a opção pelo lucro presumido (11)98950-3543
 
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...
Dear Diary: Improving Data Quality and Creating an Engaging Experience throug...
 
Fredy puerta
Fredy puertaFredy puerta
Fredy puerta
 
Arnsperger science economique_anthropologie_croissance
Arnsperger science economique_anthropologie_croissanceArnsperger science economique_anthropologie_croissance
Arnsperger science economique_anthropologie_croissance
 
Los cuatro acuerdos ivonne
Los cuatro acuerdos ivonneLos cuatro acuerdos ivonne
Los cuatro acuerdos ivonne
 
Quelques Réflexions en vue De Copenhague
Quelques Réflexions en vue De CopenhagueQuelques Réflexions en vue De Copenhague
Quelques Réflexions en vue De Copenhague
 
Tout savoir sur carfully
Tout savoir sur carfullyTout savoir sur carfully
Tout savoir sur carfully
 
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...
101280731 dissertacao-definitiva-sinterizacao-em-duas-etapas-de-pos-ultra-fin...
 
Introduccionalacriptologia
IntroduccionalacriptologiaIntroduccionalacriptologia
Introduccionalacriptologia
 
OECD Skills Project
OECD Skills ProjectOECD Skills Project
OECD Skills Project
 
International Journal of Business and Management Invention (IJBMI)
International Journal of Business and Management Invention (IJBMI)International Journal of Business and Management Invention (IJBMI)
International Journal of Business and Management Invention (IJBMI)
 
guitar hero- para principiantes
guitar hero- para principiantesguitar hero- para principiantes
guitar hero- para principiantes
 
Folder Sap Business One
Folder Sap Business OneFolder Sap Business One
Folder Sap Business One
 
Diseño curricular nacional
Diseño curricular nacionalDiseño curricular nacional
Diseño curricular nacional
 
Cuestionario avas y ovas. diana rojas
Cuestionario avas y ovas. diana rojasCuestionario avas y ovas. diana rojas
Cuestionario avas y ovas. diana rojas
 
Surface2013 fallwsp
Surface2013 fallwspSurface2013 fallwsp
Surface2013 fallwsp
 
Portafolios triptico
Portafolios tripticoPortafolios triptico
Portafolios triptico
 
Como tomar boas decisoes em projetos?
Como tomar boas decisoes em projetos?Como tomar boas decisoes em projetos?
Como tomar boas decisoes em projetos?
 
Guia De Murales En MéXico
Guia De Murales En MéXicoGuia De Murales En MéXico
Guia De Murales En MéXico
 

Similar a 22 apache http server

Contenidos.pdf
Contenidos.pdfContenidos.pdf
Contenidos.pdfChionaChio
 
Guia basica-securizacion-apache
Guia basica-securizacion-apacheGuia basica-securizacion-apache
Guia basica-securizacion-apacheERWIN AGUILAR
 
Curso de Magento 1.9: Unidad Didáctica 01 Instalacion
Curso de Magento 1.9: Unidad Didáctica 01 InstalacionCurso de Magento 1.9: Unidad Didáctica 01 Instalacion
Curso de Magento 1.9: Unidad Didáctica 01 InstalacionDavid Vaquero
 
94 Php. Instalacion De Apache 2.0.58
94 Php. Instalacion De Apache 2.0.5894 Php. Instalacion De Apache 2.0.58
94 Php. Instalacion De Apache 2.0.58José M. Padilla
 
Gestión de configuración con mercurial y etckeeper
Gestión de configuración con mercurial y etckeeperGestión de configuración con mercurial y etckeeper
Gestión de configuración con mercurial y etckeeperErnesto Crespo
 
Gestión de configuración distribuída para la plataforma de Canaima
Gestión de configuración distribuída para la plataforma de Canaima Gestión de configuración distribuída para la plataforma de Canaima
Gestión de configuración distribuída para la plataforma de Canaima Ernesto Crespo
 
21 protocolo de configuración dinámica de hosts dhcp
21  protocolo de configuración dinámica de hosts dhcp21  protocolo de configuración dinámica de hosts dhcp
21 protocolo de configuración dinámica de hosts dhcpAprende Viendo
 
92 Php. Instalar Php4 Como Cgi
92 Php. Instalar Php4 Como Cgi92 Php. Instalar Php4 Como Cgi
92 Php. Instalar Php4 Como CgiJosé M. Padilla
 
Servidor de correo_mediante_postfix
Servidor de correo_mediante_postfixServidor de correo_mediante_postfix
Servidor de correo_mediante_postfixJuan Puente Diaz
 
Practica Apache 3 mod dav
Practica Apache 3 mod davPractica Apache 3 mod dav
Practica Apache 3 mod davjsucarmona
 
3.4.2
3.4.23.4.2
3.4.2UNAD
 
Como es el proceso de actualizacion en un switch
Como es el proceso de actualizacion en un switchComo es el proceso de actualizacion en un switch
Como es el proceso de actualizacion en un switchjhonatan Espit
 

Similar a 22 apache http server (20)

Servidor web Apache
Servidor web ApacheServidor web Apache
Servidor web Apache
 
Contenidos.pdf
Contenidos.pdfContenidos.pdf
Contenidos.pdf
 
Guia basica-securizacion-apache
Guia basica-securizacion-apacheGuia basica-securizacion-apache
Guia basica-securizacion-apache
 
Curso de Magento 1.9: Unidad Didáctica 01 Instalacion
Curso de Magento 1.9: Unidad Didáctica 01 InstalacionCurso de Magento 1.9: Unidad Didáctica 01 Instalacion
Curso de Magento 1.9: Unidad Didáctica 01 Instalacion
 
Servidores, seguridad y autenticación
Servidores, seguridad y autenticaciónServidores, seguridad y autenticación
Servidores, seguridad y autenticación
 
94 Php. Instalacion De Apache 2.0.58
94 Php. Instalacion De Apache 2.0.5894 Php. Instalacion De Apache 2.0.58
94 Php. Instalacion De Apache 2.0.58
 
Gestión de configuración con mercurial y etckeeper
Gestión de configuración con mercurial y etckeeperGestión de configuración con mercurial y etckeeper
Gestión de configuración con mercurial y etckeeper
 
08practica monitorizacion
08practica monitorizacion08practica monitorizacion
08practica monitorizacion
 
Curso de php
Curso de phpCurso de php
Curso de php
 
Gestión de configuración distribuída para la plataforma de Canaima
Gestión de configuración distribuída para la plataforma de Canaima Gestión de configuración distribuída para la plataforma de Canaima
Gestión de configuración distribuída para la plataforma de Canaima
 
21 protocolo de configuración dinámica de hosts dhcp
21  protocolo de configuración dinámica de hosts dhcp21  protocolo de configuración dinámica de hosts dhcp
21 protocolo de configuración dinámica de hosts dhcp
 
92 Php. Instalar Php4 Como Cgi
92 Php. Instalar Php4 Como Cgi92 Php. Instalar Php4 Como Cgi
92 Php. Instalar Php4 Como Cgi
 
Servidor de correo_mediante_postfix
Servidor de correo_mediante_postfixServidor de correo_mediante_postfix
Servidor de correo_mediante_postfix
 
Practica Apache 3 mod dav
Practica Apache 3 mod davPractica Apache 3 mod dav
Practica Apache 3 mod dav
 
Practica3apache
Practica3apachePractica3apache
Practica3apache
 
3.4.2
3.4.23.4.2
3.4.2
 
Como es el proceso de actualizacion en un switch
Como es el proceso de actualizacion en un switchComo es el proceso de actualizacion en un switch
Como es el proceso de actualizacion en un switch
 
Squid lpt
Squid lptSquid lpt
Squid lpt
 
Servidor web apache
Servidor web apacheServidor web apache
Servidor web apache
 
Ftp file trnasfer protoc ol
Ftp file trnasfer protoc olFtp file trnasfer protoc ol
Ftp file trnasfer protoc ol
 

Más de Aprende Viendo

44 seguridad y se linux
44  seguridad y se linux44  seguridad y se linux
44 seguridad y se linuxAprende Viendo
 
43 aseguramiento de su red
43  aseguramiento de su red43  aseguramiento de su red
43 aseguramiento de su redAprende Viendo
 
42 seguridad y autenticación
42  seguridad y autenticación42  seguridad y autenticación
42 seguridad y autenticaciónAprende Viendo
 
41 parámetros y módulos generales
41  parámetros y módulos generales41  parámetros y módulos generales
41 parámetros y módulos generalesAprende Viendo
 
40 configuración del kernel y dispositivos
40  configuración del kernel y dispositivos40  configuración del kernel y dispositivos
40 configuración del kernel y dispositivosAprende Viendo
 
38 reunir información del sistema
38  reunir información del sistema38  reunir información del sistema
38 reunir información del sistemaAprende Viendo
 
37 supervisión del sistema
37  supervisión del sistema37  supervisión del sistema
37 supervisión del sistemaAprende Viendo
 
36 archivos de registro
36  archivos de registro36  archivos de registro
36 archivos de registroAprende Viendo
 
34 configuración de la impresora
34  configuración de la impresora34  configuración de la impresora
34 configuración de la impresoraAprende Viendo
 
32 configuración del sistema x window
32  configuración del sistema x window32  configuración del sistema x window
32 configuración del sistema x windowAprende Viendo
 
31 el sistema x window
31  el sistema x window31  el sistema x window
31 el sistema x windowAprende Viendo
 
46 customizing se linux policy
46  customizing se linux policy46  customizing se linux policy
46 customizing se linux policyAprende Viendo
 
45 trabajar con se linux
45  trabajar con  se linux45  trabajar con  se linux
45 trabajar con se linuxAprende Viendo
 
29 configuración de la fecha y hora
29  configuración de la fecha y hora29  configuración de la fecha y hora
29 configuración de la fecha y horaAprende Viendo
 
27 configuración del sistema
27  configuración del sistema27  configuración del sistema
27 configuración del sistemaAprende Viendo
 
28 el directorio sysconfig
28  el directorio sysconfig28  el directorio sysconfig
28 el directorio sysconfigAprende Viendo
 
25 protocolo ligero de acceso a directorios ldap
25  protocolo ligero de acceso a directorios ldap25  protocolo ligero de acceso a directorios ldap
25 protocolo ligero de acceso a directorios ldapAprende Viendo
 

Más de Aprende Viendo (20)

44 seguridad y se linux
44  seguridad y se linux44  seguridad y se linux
44 seguridad y se linux
 
43 aseguramiento de su red
43  aseguramiento de su red43  aseguramiento de su red
43 aseguramiento de su red
 
42 seguridad y autenticación
42  seguridad y autenticación42  seguridad y autenticación
42 seguridad y autenticación
 
41 parámetros y módulos generales
41  parámetros y módulos generales41  parámetros y módulos generales
41 parámetros y módulos generales
 
40 configuración del kernel y dispositivos
40  configuración del kernel y dispositivos40  configuración del kernel y dispositivos
40 configuración del kernel y dispositivos
 
39 o profile
39  o profile39  o profile
39 o profile
 
38 reunir información del sistema
38  reunir información del sistema38  reunir información del sistema
38 reunir información del sistema
 
37 supervisión del sistema
37  supervisión del sistema37  supervisión del sistema
37 supervisión del sistema
 
36 archivos de registro
36  archivos de registro36  archivos de registro
36 archivos de registro
 
35 automated tasks
35  automated tasks35  automated tasks
35 automated tasks
 
34 configuración de la impresora
34  configuración de la impresora34  configuración de la impresora
34 configuración de la impresora
 
33 usuarios y grupos
33  usuarios y grupos33  usuarios y grupos
33 usuarios y grupos
 
32 configuración del sistema x window
32  configuración del sistema x window32  configuración del sistema x window
32 configuración del sistema x window
 
31 el sistema x window
31  el sistema x window31  el sistema x window
31 el sistema x window
 
46 customizing se linux policy
46  customizing se linux policy46  customizing se linux policy
46 customizing se linux policy
 
45 trabajar con se linux
45  trabajar con  se linux45  trabajar con  se linux
45 trabajar con se linux
 
29 configuración de la fecha y hora
29  configuración de la fecha y hora29  configuración de la fecha y hora
29 configuración de la fecha y hora
 
27 configuración del sistema
27  configuración del sistema27  configuración del sistema
27 configuración del sistema
 
28 el directorio sysconfig
28  el directorio sysconfig28  el directorio sysconfig
28 el directorio sysconfig
 
25 protocolo ligero de acceso a directorios ldap
25  protocolo ligero de acceso a directorios ldap25  protocolo ligero de acceso a directorios ldap
25 protocolo ligero de acceso a directorios ldap
 

Último

Registro Auxiliar - Primaria 2024 (1).pptx
Registro Auxiliar - Primaria  2024 (1).pptxRegistro Auxiliar - Primaria  2024 (1).pptx
Registro Auxiliar - Primaria 2024 (1).pptxFelicitasAsuncionDia
 
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdf
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdfCurso = Metodos Tecnicas y Modelos de Enseñanza.pdf
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdfFrancisco158360
 
Criterios ESG: fundamentos, aplicaciones y beneficios
Criterios ESG: fundamentos, aplicaciones y beneficiosCriterios ESG: fundamentos, aplicaciones y beneficios
Criterios ESG: fundamentos, aplicaciones y beneficiosJonathanCovena1
 
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Carlos Muñoz
 
PIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonablesPIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonablesYanirisBarcelDelaHoz
 
PLAN DE REFUERZO ESCOLAR primaria (1).docx
PLAN DE REFUERZO ESCOLAR primaria (1).docxPLAN DE REFUERZO ESCOLAR primaria (1).docx
PLAN DE REFUERZO ESCOLAR primaria (1).docxlupitavic
 
actividades comprensión lectora para 3° grado
actividades comprensión lectora para 3° gradoactividades comprensión lectora para 3° grado
actividades comprensión lectora para 3° gradoJosDanielEstradaHern
 
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptx
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptxTIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptx
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptxlclcarmen
 
La empresa sostenible: Principales Características, Barreras para su Avance y...
La empresa sostenible: Principales Características, Barreras para su Avance y...La empresa sostenible: Principales Características, Barreras para su Avance y...
La empresa sostenible: Principales Características, Barreras para su Avance y...JonathanCovena1
 
Qué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativaQué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativaDecaunlz
 
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...JAVIER SOLIS NOYOLA
 
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURA
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURAFORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURA
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURAEl Fortí
 
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.Alejandrino Halire Ccahuana
 
Estrategia de prompts, primeras ideas para su construcción
Estrategia de prompts, primeras ideas para su construcciónEstrategia de prompts, primeras ideas para su construcción
Estrategia de prompts, primeras ideas para su construcciónLourdes Feria
 
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICABIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICAÁngel Encinas
 
Cuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdfCuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdfNancyLoaa
 
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VS
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VSOCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VS
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VSYadi Campos
 

Último (20)

Registro Auxiliar - Primaria 2024 (1).pptx
Registro Auxiliar - Primaria  2024 (1).pptxRegistro Auxiliar - Primaria  2024 (1).pptx
Registro Auxiliar - Primaria 2024 (1).pptx
 
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdf
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdfCurso = Metodos Tecnicas y Modelos de Enseñanza.pdf
Curso = Metodos Tecnicas y Modelos de Enseñanza.pdf
 
Criterios ESG: fundamentos, aplicaciones y beneficios
Criterios ESG: fundamentos, aplicaciones y beneficiosCriterios ESG: fundamentos, aplicaciones y beneficios
Criterios ESG: fundamentos, aplicaciones y beneficios
 
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
 
PIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonablesPIAR v 015. 2024 Plan Individual de ajustes razonables
PIAR v 015. 2024 Plan Individual de ajustes razonables
 
Unidad 3 | Metodología de la Investigación
Unidad 3 | Metodología de la InvestigaciónUnidad 3 | Metodología de la Investigación
Unidad 3 | Metodología de la Investigación
 
PLAN DE REFUERZO ESCOLAR primaria (1).docx
PLAN DE REFUERZO ESCOLAR primaria (1).docxPLAN DE REFUERZO ESCOLAR primaria (1).docx
PLAN DE REFUERZO ESCOLAR primaria (1).docx
 
actividades comprensión lectora para 3° grado
actividades comprensión lectora para 3° gradoactividades comprensión lectora para 3° grado
actividades comprensión lectora para 3° grado
 
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptx
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptxTIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptx
TIPOLOGÍA TEXTUAL- EXPOSICIÓN Y ARGUMENTACIÓN.pptx
 
La empresa sostenible: Principales Características, Barreras para su Avance y...
La empresa sostenible: Principales Características, Barreras para su Avance y...La empresa sostenible: Principales Características, Barreras para su Avance y...
La empresa sostenible: Principales Características, Barreras para su Avance y...
 
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdfTema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
Tema 8.- PROTECCION DE LOS SISTEMAS DE INFORMACIÓN.pdf
 
Qué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativaQué es la Inteligencia artificial generativa
Qué es la Inteligencia artificial generativa
 
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
ACERTIJO DE LA BANDERA OLÍMPICA CON ECUACIONES DE LA CIRCUNFERENCIA. Por JAVI...
 
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURA
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURAFORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURA
FORTI-MAYO 2024.pdf.CIENCIA,EDUCACION,CULTURA
 
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.
Lecciones 05 Esc. Sabática. Fe contra todo pronóstico.
 
Estrategia de prompts, primeras ideas para su construcción
Estrategia de prompts, primeras ideas para su construcciónEstrategia de prompts, primeras ideas para su construcción
Estrategia de prompts, primeras ideas para su construcción
 
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICABIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
BIOMETANO SÍ, PERO NO ASÍ. LA NUEVA BURBUJA ENERGÉTICA
 
Power Point: Fe contra todo pronóstico.pptx
Power Point: Fe contra todo pronóstico.pptxPower Point: Fe contra todo pronóstico.pptx
Power Point: Fe contra todo pronóstico.pptx
 
Cuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdfCuaderno de trabajo Matemática 3 tercer grado.pdf
Cuaderno de trabajo Matemática 3 tercer grado.pdf
 
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VS
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VSOCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VS
OCTAVO SEGUNDO PERIODO. EMPRENDIEMIENTO VS
 

22 apache http server

  • 1. 327 Apache HTTP Server El Servidor HTTP Apache es un servidor Web de tecnología Open Source sólido y para uso comercial desarrollado por Apache Software Foundation (http://www.apache.org/). Red Hat Enterprise Linux incluye el Servidor HTTP Apache versión 2.2 así como también una serie de módulos de servidor diseñados para mejorar su funcionalidad. El archivo de configuración predeterminado instalado en el Servidor HTTP Apache funciona sin necesidad de modificarlo, en la mayor parte de los casos. Este capítulo da una idea general de las directrices dentro de este archivo de configuración (/etc/httpd/conf/httpd.conf) para ayudar a aquellos que requieren una configuración personalizada o que necesitan convertir un archivo de configuración del formato más antiguo del Servidor HTTP Apache versión 1.3. Advertencia If using the graphical HTTP Configuration Tool (system-config-httpd ), do not hand edit the Apache HTTP Server's configuration file as the HTTP Configuration Tool regenerates this file whenever it is used. 22.1. Servidor HTTP Apache Versión 2.2 There are important differences between the Apache HTTP Server 2.2 and version 2.0 (version 2.0 shipped with Red Hat Enterprise Linux 4 and earlier). This section reviews some of the features of Apache HTTP Server 2.2 and outlines important changes. If you are upgrading from version 1.3, you should also read the instructions on migrating from version 1.3 to version 2.0. For instructions on migrating a version 1.3 configuration file to the 2.0 format, refer to Sección 22.2.2, “Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0”. 22.1.1. Características del Servidor HTTP Apache Versión 2.2 El Servidor HTTP Apache Versión 2.2 presenta las siguientes mejoras sobre las versión 2.0: • Módulos de cacheo mejorados (mod_cache, mod_disk_cache, mod_mem_cache). • Una nueva estructura para el soporte de autenticación y autorización que remplaza los módulos de autenticación proporcionados en las versiones anteriores. • Soporte para balanceo de carga proxy (mod_proxy_balancer) • soporte para manejo de archivos grandes (más grandes de 2 GB) en plataformas de 32 bits. Se han realizado los siguientes cambios a la configuración httpd predeterminada: • Los módulos mod_cern_meta y mod_asis ya no se cargan por defecto. • Ahora el módulo mod_ext_filter se cargapor defecto. Si actualiza desde un lanzamiento previo de Red Hat Enterprise Linux, la configuración httpd necesitará actualizarse para httpd 2.2. Para obtener más información refiérase a http:// httpd.apache.org/docs/2.2/upgrading.html.
  • 2. 328 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 22.2. Migración de los Archivos de Configuración del Servidor HTTP Apache 22.2.1. Migración de los Archivos de Configuración del Servidor HTTP Apache Versión 2.0. This section outlines migration from version 2.0 to 2.2. If you are migrating from version 1.3, please refer to Sección 22.2.2, “Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0”. • Los archivos de configuración y los scripts de inicialización de la versión 2.0 necesitan ajustes mínimos particularmente en los nombres de los módulos los cuales pueden haber cambiado. Los módulos de terceros que servían en la versión 2.0 también sirven en la versión 2.2 pero necesitan ser recompilados antes de que los cargue. Los módulos claves que se deben observar son los módulos de autenticación y autorización. Para cada unos de los módulos que ha sido renombrado será necesario actualizarla línea LoadModule 1 . • El módulo mod_userdir sólamente actuará bajo pedidos si proporciona una directiva UserDir indicando un nombre de directorio. Si desea mantener los procedimientos utilizados en la versión 2.0 añada la directiva UserDir public_html en su archivo de configuración. • Para habilitar SSL, edite el archivo httpd.conf añadiendo las directivas necesarias mod_ssl. Utilice apachectl start ya que apachectl startssl no se encuentra disponibleen la versión 2.2. Puede ver un ejemplo de la configuración SSL para httpd en conf/extra/httpd- ssl.conf. • Para probar su configuración se le aconseja que utilice service httpd configtest la cual detectará errores de configuración. Para obtener más información sobre como actualizar desde la versión 2.0 a la 2.2 puede ir a http:// httpd.apache.org/docs/2.2/upgrading.html. 22.2.2. Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 Esta sección detalla la migración de un archivo de configuración del Servidor HTTP Apache versión 1.3 para el Servidor HTTP Apache versión 2.0 lo pueda utilizar. Si está actualizando a Red Hat Enterprise Linux 5 desde Red Hat Enterprise Linux 2.1 tenga en cuenta que el nuevo archivo de configuración para el paquete del Servidor HTTP Apache versión 2.0 es instalado como /etc/httpd/conf/httpd.conf.rpmnew y no se toca la versión original 1.3 httpd.conf. Depende absolutamente de usted si decide utilizar el nuevo archivo de configuración y migrar los viejos cambios o si utilizar el archivo ya existente como base y modificarlo para que se adapte; sin embargo, algunas partes del archivo se han cambiado más que otras y lo mejor es llegar a un punto intermedio. Los archivos de configuración para ambas versiones la 1.3 y la 2.0 están dividos en tres secciones. Si el archivo /etc/httpd/conf/httpd.conf es una versión modificada de la versión por defecto recién instalada y ha guardado una copia del original, entonces le será más fácil invocar el comando diff, como se muestra a continuación (conectándose como root):
  • 3. 329 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 diff -u httpd.conf.orig httpd.conf | less Este comando subraya los cambios realizados. Si no tiene una copia del archivo original, cójalo del paquete RPM usando los comandos rpm2cpio y cpio, como en el ejemplo siguiente: rpm2cpio apache-<version-number>.i386.rpm | cpio -i --make In the above command, replace <version-number> with the version number for the apache package. Finalmente, es útil saber que el Servidor HTTP Apache tiene un modo de prueba para verificar si hay errores en la configuración. Para ello, escriba el siguiente comando: apachectl configtest 22.2.2.1. Configuración del entorno a nivel global La sección del entorno global del archivo de configuración contiene directrices que afectan la operación general del Servidor HTTP Apache como por ejemplo el número de peticiones que puede manejar al mismo tiempo y la ubicación de varios archivos que usa. Esta sección requiere un gran número de cambios y por ello se recomienda que base esta sección en el archivo de configuración del Servidor HTTP Apache versión 2.0 y que migre sus configuraciones anteriores a este. 22.2.2.1.1. Interfaces y vinculación de puertos Ya no existen las directrices BindAddress y Port; porque quedan recogidas en la directriz Listen. Si tenía configurado el Puerto 80 en el archivo de configuración de la versión 1.3, debe cambiarlo a Listen 80 en el archivo de configuración 2.0. Si el valor del Puerto estaba configurado a un valor diferente que 80, tiene que poner el número del puerto a los contenidos de la directriz ServerName. Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3: Port 123 ServerName www.example.com Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura: Listen 123 ServerName www.example.com:123 For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mpm_common.html#listen • http://httpd.apache.org/docs-2.0/mod/core.html#servername 22.2.2.1.2. Regulación del tamaño del pool de servidores Cuando el Servidor HTTP Apache acepta peticiones, este despacha procesos hijo o hilos para que los manejen. Este grupo de procesos o hilos es conocido como un pool de servidores. Bajo el Servidor HTTP Apache versión 2.0 se ha abstraído la responsabilidad de crear y mantener estos pool de servidores a un grupo de módulos llamados Módulos de Procesos Múltiples (MPMs). A diferencia de otros módulos, el Servidor HTTP Apache sólamente puede cargar un módulo del grupo MPM.
  • 4. 330 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 Hay tres módulos MPM incluidos con la versión 2.0: prefork, worker, y perchild. Actualmente, únicamente están disponibles los MPMs prefork y worker, aunque el MPM perchild estará disponible más adelante. El comportamiento del Servidor HTTP Apache 1.3 original ha sido movido al MPM prefork. El MPM prefork acepta las mismas directrices que el Servidor HTTP Apache versión 1.3 por tanto, las siguientes directrices se pueden migrar directamente: • StartServers • MinSpareServers • MaxSpareServers • MaxClients • MaxRequestsPerChild El MPM worker implementa un servidor multi-proceso y multi-hilos proporcionando una mayor escalabilidad. Cuando este utilizando este MPM, los hilos manejan las peticiones conservando recursos del sistema y permitiendo servir a grandes números de peticiones de manera eficiente. Aún cuando algunas de las directrices aceptadas por el MPM worker son las mismas que aquellas aceptadas por el MPM prefork los valores para esas directrices no deberían ser transferidos directamente desde una instalación del Servidor HTTP Apache versión 1.3. Es mejor utilizar los valores por defecto como una guía y luego experimentar para determinar los valores que funcionan mejor. Importante Para utilizar el MPM worker, cree el archivo /etc/sysconfig/httpd y añada la directriz siguiente: HTTPD=/usr/sbin/httpd.worker For more on the topic of MPMs, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mpm.html 22.2.2.1.3. Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido) Se tienen que realizar muchos cambios aquí, por eso se recomienda que para modificar la configuración del Servidor HTTP Apache 1.3 para adaptarse a la versión 2.0 (al contrario de migrar los cambios en la configuración de la versión 2.0) copie esta sección del archivo de configuración del Servidor HTTP Apache 2.0. Aquellos que no deseen copiar la sección desde la configuración del Servidor HTTP Apache versión 2.0 deberían tomar en cuenta lo siguiente: • Las directrices AddModule y ClearModuleList ya no existen. Estas directrices eran usadas para asegurarse de que se pudiesen activar los módulos en el orden correcto. El Servidor HTTP
  • 5. 331 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 Apache versión 2.0 permite a los módulos especificar su orden, eliminando la necesidad de estas dos directrices. • El orden de las líneas LoadModule ya no es relevante en la mayoría de los casos. • Se han añadido muchos módulos, otros han sido eliminados, renombrado, dividido o incorporados con otros. • Ya no son necesarias las líneas LoadModule para los módulos empaquetados en sus propios RPMs (mod_ssl, php, mod_perl y similares) ya que se pueden encontrar en sus archivos relevantes dentro del directorio /etc/httpd/conf.d/. • Las definiciones HAVE_XXX ya no existen. Importante Si se está modificando el archivo original, por favor tenga en cuenta que es de suma importancia que httpd.conf contenga la directriz siguiente: Include conf.d/*.conf La omisión de esta directriz podría resultar en la falla de todos los módulos enpaquetados en sus propios RPMs (tales como mod_perl, php y mod_ssl). 22.2.2.1.4. Otros cambios en el entorno global The following directives have been removed from Apache HTTP Server 2.0's configuration: • ServerType — El Servidor HTTP Apache se puede ejecutar sólamente como ServerType standalone por lo que esta directriz es irrelevante. • AccessConfig y ResourceConfig — Se han eliminado estas directrices porque su funcionalidad aparece ya en la directriz Include. Si las directrices AccessConfig y ResourceConfig son configuradas, entonces reemplácelas por las directrices Include. Para asegurarse que estos archivos se lean en el orden de las antiguas directrices, las directrices Include se deberían colocar al final de httpd.conf, con la correspondiente a ResourceConfig precediendo la que corresponde a AccessConfig. Si se estan usando los valores por defecto, inclúyalos explícitamente como archivos conf/srm.conf y conf/access.conf. 22.2.2.2. Configuración del servidor principal The main server configuration section of the configuration file sets up the main server, which responds to any requests that are not handled by a virtual host defined within a <VirtualHost> container. Values here also provide defaults for any <VirtualHost> containers defined. Las directrices utilizadas en esta sección han cambiado ligeramente respecto a las del Servidor HTTP Apache versión 1.3 y la versión 2.0. Si la configuración del servidor principal está altamente personalizada, le será más fácil modificar el archivo de configuración existente para que se adapte a la versión 2.0 del Servidor HTTP Apache. Los usuarios con secciones del servidor principal ligeramente personalizadas deberían migrar sus cambios al archivo de configuración 2.0 predeterminado.
  • 6. 332 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 22.2.2.2.1. Asignaciones UserDir La directriz UserDir se usa para habilitar URLs tales como http://example.com/~bob/ para mapear a un subdirectorio dentro del directorio home del usuario bob tal como /home/bob/ public_html/. Un efecto secundario de esta característica es que un potencial atacante puede determinar si un nombre de usuario dado se encuentra en el sistema; por esta razón la configuración por defecto para el Servidor HTTP Apache desactiva esta directriz. Para habilitar la asignación de UserDir, cambie la directriz en httpd.conf desde: UserDir disable a lo siguiente: UserDir public_html For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_userdir.html#userdir 22.2.2.2.2. Logging Se han eliminado las siguientes directrices de conexión: • AgentLog • RefererLog • RefererIgnore Sin embargo, las conexiones agent y referrer estan disponibles usando las directrices CustomLog y LogFormat. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#customlog • http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#logformat 22.2.2.2.3. Índice de directorios Se ha eliminado la directriz FancyIndexing. La misma funcionalidad se encuentra ahora en FancyIndexing option dentro de la directriz IndexOptions. La opción VersionSort para la directriz IndexOptions causa que los archivos conteniendo números de versiones sean ordenados de una forma más natural. Por ejemplo, httpd-2.0.6.tar aparece antes de httpd-2.0.36.tar en una página de índices de directorio. Las directrices predeterminadas ReadmeName y HeaderName han sido cambiadas desde README y HEADER a README.html y HEADER.html.
  • 7. 333 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#indexoptions • http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#readmename • http://httpd.apache.org/docs-2.0/mod/mod_autoindex.html#headername 22.2.2.2.4. Negociación de contenido La directriz CacheNegotiatedDocs toma ahora el argumento on o off. Las instancias existentes de CacheNegotiatedDocs deberían ser cambiadas con CacheNegotiatedDocs on. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_negotiation.html#cachenegotiateddocs 22.2.2.2.5. Documentos de error To use a hard-coded message with the ErrorDocument directive, the message should be enclosed in a pair of double quotation marks ", rather than just preceded by a double quotation mark as required in Apache HTTP Server 1.3. Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3: ErrorDocument 404 "The document was not found Para migrar la configuración de ErrorDocument al Servidor HTTP Apache versión 2.0, utilice la siguiente estructura: ErrorDocument 404 "The document was not found" Observe las dobles comillas en la directriz ErrorDocument del ejemplo anterior. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/core.html#errordocument 22.2.2.3. Configuración de host virtuales The contents of all <VirtualHost> containers should be migrated in the same way as the main server section as described in Sección 22.2.2.2, “Configuración del servidor principal”. Importante Observe que la configuración de las máquinas virtuales SSL/TLS se han quitado del archivo de configuración del servidor principal al archivo /etc/httpd/conf.d/ ssl.conf.
  • 8. 334 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 • http://httpd.apache.org/docs-2.0/vhosts/ 22.2.2.4. Módulos y el Servidor HTTP Apache 2.0 En la versión 2.0 del Servidor HTTP Apache el sistema de módulos se ha cambiado para permitir que los módulos se encadenen o se combinen en maneras nuevas e interesantes. Los scripts CGI (Common Gateway Interface), por ejemplo, pueden generar documentos HTMLinterpretados por el servidor que luego pueden ser procesados por mod_include. Esto abre una gran cantidad de posibilidades en lo que se refiere a cómo los módulos pueden combinarse para lograr una meta determinada. La forma en que esto funciona es que cada petición es servidapor exáctamente un módulo handler seguido por cero o más módulos filtro. Bajo el Servidor HTTP Apache 1.3, por ejemplo, un script Perl es manejado completamentepor el módulo Perl (mod_include). En la versión 2.0 del Servidor HTTP Apache la petición la gestiona inicialmente el módulo principal — que sirve archivos estáticos — y que es luego filtrado por mod_perl. Exactamente cómo utilizar esto y otras de las nuevas características del Servidor HTTP Apache 2.0, están más allá del alcance de este documento; sin embargo, el cambio tiene ramificaciones si ha usado la directriz PATH_INFO para un documento que es gestionado por un módulo que ahora se implementa como un filtro, pues cada uno contiene información del recorrido del nombre del archivo verdadero. El módulo principal, que inicialmente manejaba la petición, no entiende por defecto PATH_INFO y devuelve el error 404 Not Found para las peticiones que contienen dicha información. Como alternativa puede utilizar la directriz AcceptPathInfo para obligar al módulo principal a que acepte peticiones con PATH_INFO. A continuación se presenta un ejemplo de esta directriz: AcceptPathInfo on For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/core.html#acceptpathinfo • http://httpd.apache.org/docs-2.0/handler.html • http://httpd.apache.org/docs-2.0/filter.html 22.2.2.4.1. El módulo suexec En el Servidor HTTP Apache 2.0, el módulo mod_suexec utiliza la directriz SuexecUserGroup en vez de las directrices User y Group, la cual se utiliza para configurar hosts virtuales. Las directrices User y Group también se pueden utilizar en general, pero no para la configuración de hosts virtuales. Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3: <VirtualHost vhost.example.com:80> User someone Group somegroup </VirtualHost> Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura:
  • 9. 335 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 <VirtualHost vhost.example.com:80> SuexecUserGroup someone somegroup </VirtualHost> 22.2.2.4.2. El módulo mod_ssl The configuration for mod_ssl has been moved from the httpd.conf file into the /etc/httpd/ conf.d/ssl.conf file. For this file to be loaded, and for mod_ssl to work, the statement Include conf.d/*.conf must be in the httpd.conf file as described in Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)”. Las directrices ServerName en las máquinas virtuales SSL tienen que especificar el número del puerto. Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3: <VirtualHost _default_:443> # General setup for the virtual host ServerName ssl.example.name ... </VirtualHost> Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura: <VirtualHost _default_:443> # General setup for the virtual host ServerName ssl.host.name:443 ... </VirtualHost> It is also important to note that both the SSLLog and SSLLogLevel directives have been removed. The mod_ssl module now obeys the ErrorLog and LogLevel directives. Refer to ErrorLog and LogLevel for more information about these directives. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_ssl.html • http://httpd.apache.org/docs-2.0/vhosts/ 22.2.2.4.3. El módulo mod_proxy Proxy access control statements are now placed inside a <Proxy> block rather than a <Directory proxy:>. La funcionalidad de caché del antiguo mod_proxy se ha dividido en tres módulos siguientes: • mod_cache • mod_disk_cache • mod_mem_cache Estos generalmente usan directrices similares a las versiones anteriores del módulo mod_proxy, pero se recomienda que verifique cada directriz antes de migrar cualquier configuración caché. For more on this topic, refer to the following documentation on the Apache Software Foundation's website:
  • 10. 336 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 • http://httpd.apache.org/docs-2.0/mod/mod_proxy.html 22.2.2.4.4. El módulo mod_include The mod_include module is now implemented as a filter and is therefore enabled differently. Refer to Sección 22.2.2.4, “Módulos y el Servidor HTTP Apache 2.0” for more about filters. Por ejemplo, el siguiente es un ejemplo de la directtriz de Servidor HTTP Apache de la versión 1.3: AddType text/html .shtml AddHandler server-parsed .shtml Para migrar esta configuración al Servidor HTTP Apache versión 2.0 utilice la siguiente estructura: AddType text/html .shtml AddOutputFilter INCLUDES .shtml Note that the Options +Includes directive is still required for the <Directory> container or in a .htaccess file. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_include.html 22.2.2.4.5. Los módulos mod_auth_dbm y mod_auth_db El Servidor HTTP Apache 1.3 soportaba dos módulos de autenticación, mod_auth_db y mod_auth_dbm que usaba las bases de datos Berkeley y DBM respectivamente. Estos módulos se han combinado en un único módulo que se llama mod_auth_dbm en el Servidor HTTP Apache 2.0, que puede acceder a diferentes formatos de bases de datos. Para migrar desde mod_auth_db los archivos de configuración se tienen que ajustar reemplazando AuthDBUserFile y AuthDBGroupFile con los equivalentes: AuthDBMUserFile y AuthDBMGroupFile. También, se debe añadir la directriz AuthDBMType DB para indicar el tipo de archivo de base de datos en uso. El siguiente ejemplo muestra una configuración mod_auth_db de ejemplo para el Servidor HTTP Apache 1.3: <Location /private/> AuthType Basic AuthName "My Private Files" AuthDBUserFile /var/www/authdb require valid-user </Location> Para migrar esta configuración a la versión 2.0 del Servidor HTTP Apache 2.0 utilice la siguiente estructura: <Location /private/> AuthType Basic AuthName "My Private Files" AuthDBMUserFile /var/www/ authdb AuthDBMType DB require valid-user </Location> Observe que la directriz AuthDBMUserFile también puede ser usada en archivos .htaccess. El script Perl dbmmanage que se utiliza para manipular bases de datos de nombres de usuarios y contraseñas ha sido reemplazado por htdbm en el Servidor HTTP Apache 2.0. El programa htdbm ofrece una funcionalidad equivalente y como mod_auth_dbm puede operar en una variedad de
  • 11. 337 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 formatos de bases de datos; la opción -T se puede usar en la línea de comandos para especificar el formato a utilizar. Tabla 22.1, “Migración del dbmmanage a htdbm” shows how to migrate from a DBM-format database to htdbm format using dbmmanage. Action comando dbmmanage (1.3) comando equivalente htdbm (2.0) Añade un usuario a la base de datos (usando la contraseña dada) Añade un usuario a la base de datos ( le pide la contraseña) Eliminar el usuario de la base de datos dbmmanage authdb add username password dbmmanage authdb adduser username dbmmanage authdb delete username htdbm -b -TDB authdb username password htdbm -TDB authdb username htdbm -x -TDB authdb username Listar usuarios en la base de datos dbmmanage authdb view htdbm -l -TDB authdb Verificar una contraseña dbmmanage authdb check username Tabla 22.1. Migración del dbmmanage a htdbm htdbm -v -TDB authdb username Las opciones -m y -s trabajan con dbmmanage y con htdbm, permitiendo el uso de los algortimos MD5 o SHA1 para las contraseñas hashing, respectivamente. Cuando cree una nueva base de datos con htdbm, use la opción -c. For more on this topic, refer to the following documentation on the Apache Software Foundation's website: • http://httpd.apache.org/docs-2.0/mod/mod_auth_dbm.html 22.2.2.4.6. El módulo mod_perl The configuration for mod_perl has been moved from httpd.conf into the file /etc/httpd/ conf.d/perl.conf. For this file to be loaded, and hence for mod_perl to work, the statement Include conf.d/*.conf must be included in httpd.conf as described in Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)”. Las ocurrencias del Apache:: en el httpd.conf tienen que ser sustituídas por ModPerl::. Además, se ha cambiado el modo en que se registran los manejadores. Ejemplo de configuración del Servidor HTTP Apache 1.3 mod_perl: <Directory /var/www/perl> SetHandler perl-script PerlHandler Apache::Registry Options +ExecCGI </Directory> Este es el equivalente del mod_perl para el Servidor HTTP Apache 2.0: <Directory /var/www/perl> SetHandler perl-script PerlResponseHandler ModPerl::Registry Options +ExecCGI </Directory>
  • 12. 338 Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0 La mayoría de los módulos para mod_perl 1.x deberían funcionar sin modificación con los módulos mod_perl 2.x. Los módulos XS requieren recompilación y quizás algunas modificaciones menores de Makefile. 22.2.2.4.7. El módulo mod_python Configuration for mod_python has moved from httpd.conf to the /etc/httpd/conf.d/ python.conf file. For this file to be loaded, and hence for mod_python to work, the statement Include conf.d/*.conf must be in httpd.conf as described in Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)”. 22.2.2.4.8. PHP The configuration for PHP has been moved from httpd.conf into the file /etc/httpd/conf.d/ php.conf. For this file to be loaded, the statement Include conf.d/*.conf must be in httpd.conf as described in Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)”. Nota Cualquier directriz de configuración PHP utilizada en el Servidor HTTP Apache 1.3 ahora es completamente compatible cuando se migra al Servidor HTTP Apache 2.0 en Red Hat Enterprise Linux 5. En PHP 4.2.0 y posterior, el conjunto predeterminado de variables predefinidas que están disponibles en el ámbito global, han cambiado. Las entradas individuales y las variables del servidor, por defecto, ya no se colocan directamente en el ámbito global. Este cambio puede hacer que se rompan los scripts. Cámbiese al antiguo comportamiento colocando register_globals a On en el archivo / etc/php.ini. Para mayor información sobre estos temas, consulte los siguientes sitios web: • http://www.php.net/release_4_1_0.php 22.2.2.4.9. El módulo mod_authz_ldap Red Hat Enterprise Linux ships with the mod_authz_ldap module for the Apache HTTP Server. This module uses the short form of the distinguished name for a subject and the issuer of the client SSL certificate to determine the distinguished name of the user within an LDAP directory. It is also capable of authorizing users based on attributes of that user's LDAP directory entry, determining access to assets based on the user and group privileges of the asset, and denying access for users with expired passwords. The mod_ssl module is required when using the mod_authz_ldap module. Importante El módulo mod_authz_ldap no valida un usuario a un directorio LDAP usando un hash de contraseña encriptada. Esta funcionalidad es proporcionada por el módulo experimental mod_auth_ldap. Consulte la documentación en línea de mod_auth_ldap en http://httpd.apache.org/docs-2.0/mod/mod_auth_ldap.html para más detalles sobre el estatus de este módulo. El archivo /etc/httpd/conf.d/authz_ldap.conf configura al módulo mod_authz_ldap.
  • 13. 339 Arrancar y detener httpd Refer to /usr/share/doc/mod_authz_ldap-<version>/index.html (replacing <version> with the version number of the package) or http://authzldap.othello.ch/ for more information on configuring the mod_authz_ldap third party module. 22.3. Arrancar y detener httpd After installing the httpd package, review the Apache HTTP Server's documentation available online at http://httpd.apache.org/docs/2.2/. El RPM de httpd instala el script /etc/init.d/httpd, el cual se puede acceder usando el comando /sbin/service. Iniciando httpd utilizandoel script de control apachectl configura las variables del entorno en /etc/sysconfig/httpd e inicia httpd. También puede configurar las variables del entorno utilizando el script de inicialización. Para arrancar el servidor utilizando el script de control apachectl como tipo root: apachectl start También puede arrancar httpd utilizando /sbin/service httpd start. Esto inicia httpd pero no configura las variables del entorno. Si está utilizando la directriz predeterminada Listen en httpd.conf, la cual es el puerto 80, necesitará contar con privilegios de usuario root para iniciar el servidor apache. Para detener el servidor, como root escriba: apachectl stop También puede detener httpd utilizando /sbin/service httpd stop. La opción restart es una manera más rápida de detener y luego iniciar el Servidor HTTP Apache. Para reiniciar el servidor como root escriba: apachectl restart or: /sbin/service httpd restart Apache presentará un mensaje en la consola o en el ErrorLog si encuentra un error al iniciar. Por defecto, el servicio httpd no inicia automáticamente al momento de arranque. Si quiere que Apache inicie al momento de arranque necesitará añadir una llamada a apachectl en sus archivos de inicalización dentro de su directorio rc.local. Un archivo que se utiliza típicamente es rc.local. Ya que esto inicia Apache como usuario root se recomienda que configure apropiadamente su seguridad y autenticación antes de añadir esta llamada. También puede configurar el servicio httpd para iniciar en tiempo de arranque utilizando una herramienta script de inicialización tal como /sbin/chkconfig, /usr/sbin/ntsysv, o el programa Services Configuration Tool. También puede visualizar el estado de su servidor httpd escribiendo:
  • 14. 340 Arrancar y detener httpd apachectl status Sin embargo, el módulo de estado mod_status necesita ser habilitado en su archivo de configuración mod_status para que esto funcione. Para obtener más detalles sobre mod_status vaya a http://httpd.apache.org/docs/2.2/mod/mod_status.html. Nota If running the Apache HTTP Server as a secure server, the secure server's password is required after the machine boots when using an encrypted private SSL key. Puede encontrar más información en http://httpd.apache.org/docs/2.2/ssl 22.4. Configuración del Servidor HTTP Apache The HTTP Configuration Tool allows you to configure the /etc/httpd/conf/httpd.conf configuration file for the Apache HTTP Server. It does not use the old srm.conf or access.conf configuration files; leave them empty. Through the graphical interface, you can configure directives such as virtual hosts, logging attributes, and maximum number of connections. To start the HTTD Configuration Tool, click on System > Administration > Server Settings > HTTP. Sólo se pueden configurar con la Herramienta de Configuración HTTPaquellos módulos que estén incluídos con Red Hat Enterprise Linux. Si se instalanotros módulos, no se podrán configurar utilizando esta herramienta. Advertencia No modifique el archivo de configuración /etc/httpd/conf/httpd.conf manualmente si desea utilizar esta herramienta. La Herramienta de Configuración HTTP genera este archivo después de que haya grabado los cambios y haya salido del programa. Si desea añadir módulos u opciones de configuración que no se encuentran en la Herramienta de Configuración HTTP no podrá usarla. Los pasos generales para configurar el Servidor HTTP Apache utilizando la Herramienta de Configuración HTTP son los siguientes: 1. Configure los aspectos básicos que se encuentran en la pestaña Principal 2. Haga clic en Hosts Virtualesy configure las opciones predeterminadas. 3. Bajo la pestaña Hosts Virtuales configure el Host Virtual Predeterminado. 4. Para servir más de una URL o más de un host virtual, añada cualquierhost virtual adicional. 5. Configure las características del servidor bajo la pestaña Servidor. 6. Configure la configuración de las conexiones bajo la pestaña Ajuste de Rendimiento. 7. Copie todos los archivos necesarios a los directorios DocumentRoot y cgi-bin 8. Salga de la aplicación y seleccione guardar sus configuraciones.
  • 15. 341 Basic Settings 22.4.1. Basic Settings Use la pestaña Principal para establecer las configuraciones básicas del servidor. Figura 22.1. Basic Settings Enter a fullyqualified domain name that you have the right to use in the Server Name text area. This option corresponds to the ServerName 2 directive in httpd.conf. The ServerName directive sets the hostname of the Web server. It is used when creating redirection URLs. If you do not define a server name, the Web server attempts to resolve it from the IP address of the system. The server name does not have to be the domain name resolved from the IP address of the server. For example, you might set the server name to www.example.com while the server's real DNS name is foo.example.com. Enter the email address of the person who maintains the Web server in the Webmaster email address text area. This option corresponds to the ServerAdmin 3 directive in httpd.conf. If you configure the server's error pages to contain an email address, this email address is used so that users can report a problem to the server's administrator. The default value is root@localhost. Utilice el área Direcciones Disponibles para definir los puertos en los que el servidor acepta pedidos entrantes. Esta opción corresponde a la directriz Listen 4 en httpd.conf. Por defecto, Red Hat configura el Servidor HTTP Apache para que escuche el puerto 80 para comunicaciones de web no seguras. 2 http://httpd.apache.org/docs/2.2/mod/core.html#servername 3 http://httpd.apache.org/docs/2.2/mod/core.html#serveradmin 4 http://httpd.apache.org/docs/2.2/mod/mpm_common.html#listen
  • 16. 342 Basic Settings Click the Add button to define additional ports on which to accept requests. A window as shown in Figura 22.2, “Available Addresses” appears. Either choose the Listen to all addresses option to listen to all IP addresses on the defined port or specify a particular IP address over which the server accepts connections in the Address field. Only specify one IP address per port number. To specify more than one IP address with the same port number, create an entry for each IP address. If at all possible, use an IP address instead of a domain name to prevent a DNS lookup failure. Refer to http:// httpd.apache.org/docs/2.2/dns-caveats.html for more information about Issues Regarding DNS and Apache. Si introduce un asterisco (*) en el campo Direccionesequivaldrá a elegir la opción Escuchar todas las direcciones. Haga click en el botón Modificar en el recuadro de Direcciones disponibles muestra la misma ventana que el botón Añadir excepto los campos de la entrada seleccionada. Para borrar una entrada, seleccionela y haga clic en el botón Eliminar. Tip Si configuró el servidor para escuchar en el puerto 1024, deberá ser root para arrancarlo. Para el puerto 1024 y superiores, se puede arrancar httpd como un usuario normal. Figura 22.2. Available Addresses 22.4.2. Configuraciones predeterminadas Después de definir el Nombre del Servidor, Dirección de correo eletrónico del webmaster y Direcciones Disponibles haga clic en la pestaña Hosts Virtuales. La figura a continuación ilustra la pestaña Hosts Virtuales.
  • 17. 343 Configuraciones predeterminadas Figura 22.3. Virtual Hosts Tab Al hacer clic en Modificar presentará la ventana de las Propiedades del Host Virtual desde donde usted puede configurarlo como desee. Para añadir nuevas configuraciones haga clic en el botón Añadir, el cual también presentará la ventana Propiedades del Host Virtual. Al hacer clic en el botón Modificar Configuración Predeterminada aparecerá una ventana Propiedades del Host Virtual sin la pestaña Opciones Generales. In the General Options tab, you can change the hostname, the document root directory and also set the webmaster's email address. In the Host information, you can set the Virtual Host's IP Address and Host Name. The figure below illustrates the General Options tab.
  • 18. 344 Configuraciones predeterminadas Figura 22.4. General Options Si añade un host virtual, la configuración del host virtual tiene prioridad para ese host virtual. Para una directriz no definida dentro de la configuración del host virtual se utiliza el valor predeterminado. 22.4.2.1. Site Configuration La figura a continuación ilustra la pestaña Opciones de Página desde la cual puede configurar la Lista de Páginas del Directorio y Páginas de Error. Si no está seguro de esta configuración no la modifique.
  • 19. 345 Configuraciones predeterminadas Figura 22.5. Site Configuration Las entradas que aparecen en la Lista de Búsqueda de Página de Directorio definen la directiva DirectoryIndex 5 . ElDirectoryIndex es la página predeterminada que el servidor da a un usuario que pide el índice de un directorio escribiendo la barra inclinada (/) al final del nombre del directorio. Por ejemplo, cuando un usuario pide la páginahttp://www.example.com/this_directory/ recibe la página del índice del directorio, DirectoryIndex, si existe, o un listado de directorios generado por el servidor. El servidor intentará encontrar uno de los archivos incluidos en DirectoryIndex y entregará el primero que encuentre. Si no encuentra ninguno de estos archivos y siOptions Indexes está configurado para ese directorio, el servidor genera y devuelve una lista, en formato HTML, de los subdirectorios y archivos dentro del directorio. 5 http://httpd.apache.org/docs/2.2/mod/mod_dir.html#directoryindex
  • 20. 346 Configuraciones predeterminadas Utilice la sección Código Error para configurar el Servidor HTTP Apache para redireccionar el cliente a una URL local o externa en el caso de que haya un error o un problema. Esta opción corresponde a la directriz ErrorDocument 6 . Si ocurre un error o si se presenta un problema cuando un clienta trata de conectarse al Servidor HTTP Apache, la acción predeterminada es presentar un corto mensaje de error en la columna Código Error. Para cancelar esta configuración predeterminada seleccione el código error y haga clic en el botón Modificar. Seleccione Predeterminado para visualizar el mensaje corto de error predeterminado. Elija URL para redireccionar el cliente a la URL externa e ingresar una URL completa incluyendo el http:// en el campo Location. Seleccione File para redireccionar el cliente a una URL interna e ingresar la ubicación de un archivo bajo la raíz del documento para el servidor Web. La ubicación debe comenzar con la barra inclinada (/) y debe estar relacionada con la Raíz del Documento. Por ejemplo, para redirigir un código de error 404 Not Found a una página web que usted ha creado en un archivo llamado 404.html copie 404.html a DocumentRoot/../error/404.html. En este caso, DocumentRoot es el directorio del documento raíz que ha definido (el valor por defecto es /var/www/html/). Si se deja el documento raíz como la ubicación por defecto, el archivo debería ser copiado a /var/www/error/404.html. Luego, elija Archivo como el Comportamiento para el código de error 404 - Not Found e introduzca /error/404.html como la Ubicación. Desde el menú Pie de Página de Error por Defecto escoja una de las siguientes opciones: • Mostrar el pie de página con la dirección de correo electrónico — Esta opción muestra el pie de página predeterminado en todas las páginas de error junto con la dirección de correo electrónico del encargado del sitio web especificado por la directriz ServerAdmin 7 . • Muestra el pie de página — Esta opción le muestra el pie de página predeterminado en todas las páginas de error. • Ningún pie de página — No muestra el pie de página en las páginas de error. 22.4.2.2. Soporte SSL El mod_ssl le permite encriptar el protocolo HTTP sobre SSL. El protocolo SSL(Secure Sockets Layer) se utiliza para comunicación y para encriptarsobre redes TCP/IP. La pestaña SSL le permite configurar SSL para su servidor. Para configurar SSL necesita proporcionar la ruta a su: • Archivo de certificado - equivalente a utilizar la directriz SSLCertificateFile la cual apunta la ruta al archivo de certificado de servidor codificado PEM (Privacy Enhanced Mail). • Archivo de la llave - equivalente a utilizar la directriz SSLCertificateKeyFile la cual apunta la ruta al archivo de la llave privada del servidor codificado PEM. • Certificate chain file - equivalent to using the SSLCertificateChainFile directive which points the path to the certificate file containing all the server's chain of certificates. • Archivo de autoridad del certificado - es un archivo encriptado utilizado para confirmar la autenticidad o identidad de las partes que se comunican con el servidor. Puede encontrar más información sobre las directrices de configuración para SSL en http:// httpd.apache.org/docs/2.2/mod/directives.html#S 8 . También necesita determinar que opciones SSL debe habilitar. Estas son equivalentes a utilizar SSLOptions con las siguientes opciones: 6 http://httpd.apache.org/docs/2.2/mod/core.html#errordocument 8 http://httpd.apache.org/docs/2.2/mod/directives.html#S
  • 21. Configuraciones predeterminadas 347 • FakeBasicAuth - enables standard authentication methods used by Apache. This means that the Client X509 certificate's Subject Distinguished Name (DN) is translated into a basic HTTP username. • ExportCertData - crea variables de entorno CGI en SSL_SERVER_CERT, SSL_CLIENT_CERT y SSL_CLIENT_CERT_CHAIN_n en donde n es un número 0,1,2,3,4... Los scripts CGI utilizan estos archivos para más chequeos de certificados. • CompatEnvVars - habilita una compatibilidad retroactiva para Apache SSL añadiendo variables de entorno CGI. • StrictRequire - habilita acceso estricto el cual obliga a denegar acceso cuando las directrices SSLRequireSSL y SSLRequire indican que es prohibido el acceso. • OptRenegotiate - permite eludir los apretones de manos de mod_ssl el cual también realiza chequeos de parámetros seguros. Se recomienda que habilite OptRenegotiate con base en el directorio. Para obtener más información sobre las opciones SSL mencionadas anteriormente vaya a http:// httpd.apache.org/docs/2.2/mod/mod_ssl.html#ssloptions 9 . La figura a continuación ilustra la pestaña SSL y las opciones que se discutieron anteriormente. 9 http://httpd.apache.org/docs/2.2/mod/mod_ssl.html#ssloptions
  • 22. Configuraciones predeterminadas 348 Figura 22.6. SSL 22.4.2.3. Logging Utilice la pestaña Registro para configurar las opciones para registro de errores y transferencia específica. Por defecto, el servidor escribe el registro de transferencia en el archivo /var/log/httpd/ access_log y el registro de error en el archivo /var/log/httpd/error_log. El registro de transferencias contiene una lista de todos los intentos para acceder al servidor web. Graba las direcciones IP del cliente que está tratande de conectarse, la fecha y hora en que intentó, y el archivo en el servidor web que está tratando de recuperar. Introduzca el nombre de la ruta y del archivo en donde se alamacenará esta información. Si el nombre de la ruta y del archivo no
  • 23. Configuraciones predeterminadas 349 comienzan con una barra inclinada (/), la ruta es relativa al directorio root del servidor como se configurá. Esta opción corresponde a la directriz TransferLog 10 . Figura 22.7. Logging Puede configurar un registro con formato personalizado chequeando Usar las facilidades de registro personalizado e introduciendo una cadena personalizada en el campo Cadena de registro personalizada. Esto configura la directriz LogFormat 11 . Para mayor información sobre los detalles del formato de la directiva consulte http://httpd.apache.org/docs/2.2/mod/ mod_log_config.html#logformat 12 . El registro de transferencia incluye una lista de los errores del servidor. Introduzca el nombre de la ruta y del archivo en donde se debe almacenar esta información. Si el nombre de la ruta y del archivo 10 http://httpd.apache.org/docs/2.2/mod/mod_log_config.html#transferlog 11 http://httpd.apache.org/docs/2.2/mod/mod_log_config.html#logformat 12 http://httpd.apache.org/docs-2.0/mod/mod_log_config.html#formats
  • 24. Configuraciones predeterminadas 350 no empiezan con una barra inclinada (/), la ruta es relativa al directorio root del servidor como se configuró. Esta opción corresponde a la directriz ErrorLog 13 . Utilice el menú Nivel de Registro para establecer la verbosidad de los emnsajes de error en los registrs de error. Se puede configurar (del menos verbos al más verboso) como emerg, alerta, crit, error, advert, aviso, info o depurar. Esta opción corresponde a la directriz LogLevel 14 . El valor escogido en el menú Búsqueda inversa del DNS define la directiva HostnameLookups 15 Si escoge Ninguna búsqueda inversa se desactiva el valor, si escoge Búsqueda inversa el valor está activado y si escoge Doble búsqueda inversa éste se duplica. Si escoje Búsuqeda Inversa su servidor resuelve automáticamente la dirección IP para cada conexión la cual pide un documento de su servidor web. El resolver una dirección IP significa que su servidor realiza una o más conexiones al DNS para encontrar el nombre del host que corresponde a una dirección IP en particular. Si elije Búsqueda Inversa Doble su servidor realiza un DNS inverso doble. Es decir, después de que se realiza una búsqueda inversa, se realiza una búsqueda avanzada en el resultado. Por lo menos una de las direcciones IP en la búsqueda vanazada debe coincidir con la dirección de la primera búqieda inversa. Generalmente, esta opción debería de estar en Ninguna Búsqueda Inversa porque sino se sobrecarga al servidor y disminuye el ritmo de trabajo. Si su servidor tiene mucha carga, al tratar de realizar estas búsquedas, los efectos serán bastante notables. Reverse lookups and double reverse lookups are also an issue for the Internet as a whole. Each individual connection made to look up each hostname adds up. Therefore, for your own Web server's benefit, as well as for the Internet's benefit, you should leave this option set to No Reverse Lookup. 22.4.2.4. Environment Variables Utilice la pestaña Entorno para configurar las opciones para variables específicas para establecer, pasar o desconfigurar para scripts CGI. Algunas veces es necesario modificar las variables del entorno para scripts CGI o páginas server-side include (SSI). El Servidor HTTP Apache puede usar el módulo mod_env para configurar las variables del ambiente que son pasadas a los scripts CGI y a las páginas SSI. Utilice la página Variables de entorno para configurar las directivas para este módulo. Use the Set for CGI Scripts section to set an environment variable that is passed to CGI scripts and SSI pages. For example, to set the environment variable MAXNUM to 50, click the Add button inside the Set for CGIScript section, as shown in Figura 22.8, “Environment Variables”, and type MAXNUM in the Environment Variable text field and 50 in the Value to set text field. Click OK to add it to the list. The Set for CGIScripts section configures the SetEnv 16 directive. Utilice la sección Pasar a los Scripts CGIpara pasar el valor de una variable de entorno cuando el servidor se inicia por primera vez en scripts CGI. Para ver esta variable de entrada escriba el comando env en un intérprete de comandos. Haga clic en el botón Añadir dentro de la sección Pasar a Scripts CGI e introduzca el nombre de la variable de entorno en la ventana de diálogo 13 http://httpd.apache.org/docs/2.2/mod/core.html#errorlog 14 http://httpd.apache.org/docs/2.2/mod/core.html#loglevel 15 http://httpd.apache.org/docs/2.2/mod/core.html#hostnamelookups 16 http://httpd.apache.org/docs/2.2/mod/mod_env.html#setenv
  • 25. Configuraciones predeterminadas 351 que aparece. Haga clic en OK para añadirla a la lista. La sección Pass to CGIScripts configura la directriz PasarEnt 17 . Figura 22.8. Environment Variables Para eliminar una variable de entorno de manera que el valor no se pase a a los scripts CGI y a las páginas SSI utilice la sección Desconfigurar para Scripts CGI. Haga clic en Añadir en la sección Desconfigurar para Scripts CGIe introduzca el nombre de la variable de entorno en desconfigurar. Haga clic en OK para añadirla a la lista. Esto corresponde a la directriz DesconfigEnt 18 Para modificar cualquier de estos valores de entorno selecciónelo de la lista y haga clic en el botón Modificar . Para borrar cualquier entrada de la lista selecciónela y haga clic en el botón Eliminar correspondiente. 17 http://httpd.apache.org/docs/2.2/mod/mod_env.html#passenv 18 http://httpd.apache.org/docs/2.2/mod/mod_env.html#unsetenv
  • 26. Configuraciones predeterminadas 352 Para obtener más información sobre las variables de entorno en el Servidor HTTP Apache refiérase a: http://httpd.apache.org/docs/2.2/env.html 22.4.2.5. Directories Use the Directories page in the Performance tab to configure options for specific directories. This corresponds to the <Directory> 19 directive. Figura 22.9. Directories Click the Edit button in the top right-hand corner to configure the Default Directory Options for all directories that are not specified in the Directory list below it. The options that you choose are listed 19 http://httpd.apache.org/docs/2.2/mod/core.html#directory
  • 27. Configuraciones predeterminadas 353 as the Options 20 directive within the <Directory> 21 directive. You can configure the following options: • ExecCGI — Permite la ejecución de los scripts CGI. Los scripts no se ejecutan si no elige esta opción. • FollowSymLinks — Permite que se sigan enlaces simbólicos. • Includes — Permite las inclusiones en el servidor (SSI). • IncludesNOEXEC — Permite las inclusiones en el servidor pero anula los comandos #exec y #include en los scripts CGI. • Indexes — Display a formatted list of the directory's contents, if no DirectoryIndex (such as index.html) exists in the requested directory. • index.html Soporta las visualizaciones múltiples de los contenidos; esta opción no está activada por defecto. • SymLinksIfOwnerMatch — Permite seguir un enlace simbólico sólamente si el archivo o el directorio en cuestión tienen el mismo propietario que el enlace. To specify options for specific directories, click the Add button beside the Directory list box. A window as shown in Figura 22.10, “Directory Settings” appears. Enter the directory to configure in the Directory text field at the bottom of the window. Select the options in the right-hand list and configure the Order 22 directive with the left-hand side options. The Order directive controls the order in which allow and deny directives are evaluated. In the Allow hosts from and Deny hosts from text field, you can specify one of the following: • Permitir todas los hosts — Escriba all para permitir el acceso a todos los hosts. • Nombre parcial de dominio — Permite todas las máquinas cuyos nombres coincidan o terminen con una cadena determinado. • Dirección IP completa — Permite el acceso a una determinada dirección IP. • Una subred — Tal como 192.168.1.0/255.255.255.0 • Una especificación CIDR de red — como por ejemplo 10.3.0.0/16 20 http://httpd.apache.org/docs/2.2/mod/core.html#options 21 http://httpd.apache.org/docs/2.2/mod/core.html#directory 22 http://httpd.apache.org/docs-2.0/mod/mod_access.html#order
  • 28. Configuraciones predeterminadas 354 Figura 22.10. Directory Settings Si marca Permitir que los archivos .htaccess pasen por encima de las opciones del directorio las directivas de configuración en el archivo .htaccess toman precedencia. 22.5. Directrices de configuración en httpd.conf El archivo de configuración del Servidor HTTP Apache es /etc/httpd/conf/httpd.conf. El archivo httpd.conf está bien comentado y en gran parte es autoexplicativo. Su configuración por defecto funciona para la mayoría de los casos; sin embargo, es una buena idea familiarizarse con algunas de las opciones de configuración más importantes. Advertencia With the release of Apache HTTP Server 2.2, many configuration options have changed. If migrating from version 1.3 to 2.2, please firstly read Sección 22.2.2, “Migración de los Archivos de Configuración del Servidor HTTP Apache de la Versión 1.3 a la 2.0”. 22.5.1. Sugerencias de configuración generales If configuring the Apache HTTP Server, edit /etc/httpd/conf/httpd.conf and then either reload, restart, or stop and start the httpd process as outlined in Sección 22.3, “Arrancar y detener httpd”. Antes de modificar el archivo httpd.conf, primero haga una copia del archivo original. Al crear una copia de respaldo se hace más fácil recuperarse de posibles errores cometidos mientras se editaba el archivo de configuración.
  • 29. 355 Sugerencias de configuración generales Si comete un error y su servidor de web no funciona correctamente, lo primero que debe realizar es revisar lo que lo que acaba de modificar en httpd.conf para ver si no hay errores de transcripción. Next look in the Web server's error log, /var/log/httpd/error_log. The error log may not be easy to interpret, depending on your level of expertise. However, the last entries in the error log should provide useful information. Las siguientes subsecciones proporcionan una breve descripción de muchas de las directrices incluidas en httpd.conf. Estas descripciones no son exhaustivas. Para obtener más información consulte la documentación de Apache en línea http://httpd.apache.org/docs/2.2/. Para obtener mayor información sobre las directrices mod_ssl consulte la documentación en http:// httpd.apache.org/docs/2.2/mod/mod_ssl.html. AccessFileName AccessFileName denomina el archivo que el servidor utilizará para información de control de acceso en cada directorio. Por defecto, el servidor utilizará .htaccess. Justo tras AccessFileName, un conjunto de indicadores de Files aplican el control de acceso a cualquier archivo comenzando con un .ht. Estas directrices niegan el acceso Web a cualquier archivo .htaccess (o otros archivos que comiencen con .ht) por razones de seguridad. Action Action especifica parejas tipo contenido MIME y script CGI, para que cuando un archivo de ese tipo de media sea solicitado, se ejecute un script CGI particular. AddDescription Cuando utilice FancyIndexing como un parámetro de IndexOptions, la directriz AddDescription se puedeusar para mostrar descripciones especificadas por el usuario para ciertos archivos o tipos de archivo en un listado de directorio generado por el servidor. La directriz AddDescription soporta el listado de archivos específicos, expresiones con comodines o extensiones de archivos. AddEncoding La directriz AddEncoding nombra las extensiones de archivos que deberían especificar un tipo particular de codificación. También se puede usar AddEncoding para decirle a los navegadores que descompriman ciertos archivos mientras los descargan. AddHandler La directriz AddHandler hace corresponder extensiones de archivos a manejadores específicos. Por ejemplo, se puede corresponder el manejador cgi-script con la extensión .cgi para que automáticamente trate a cualquier archivo con un nombre que termine en .cgi como un script CGI. A continuaciónse presenta un ejemplo de una directriz AddHandler para la extensión .cgi. AddHandler cgi-script .cgi
  • 30. 356 Sugerencias de configuración generales This directive enables CGIs outside of the cgi-bin to function in any directory on the server which has the ExecCGI option within the directories container. Refer to Directory for more information about setting the ExecCGI option for a directory. Además de los scripts CGI, la directriz AddHandler es usada para procesar archivos de mapas de imagen y HTMLanalizados por el servidor. AddIcon AddIcon dice al servidor qué icono mostrar en los listados del directorio para ciertos tipos de archivos según la extensión. Por ejemplo, el servidor Web muestra el icono binary.gif para archivos con extensiones .bin o .exe. AddIconByEncoding Esta directriz denomina qué iconos se mostrarán con los archivos según su codificación MIME, en los listados de directorio. Por ejemplo, el servidor muestra por defecto el icono compressed.gif junto a archivos con codificación MIME x-compress y x-gzip en los listados de directorio. AddIconByType Esta directriz denomina qué iconos se mostrarán con los archivos con codificación MIME, en los listados del directorio. Por ejemplo, por defecto, el servidor muestra el icono text.gif junto a archivos con tipo MIME text en los listados del directorio. AddLanguage AddLanguage associates file name extensions with specific languages. This directive is useful for Apache HTTP Servers which serve content in multiple languages based on the client Web browser's language settings. AddType Utilice la directriz AddType para definir o suprimir por defecto pares tipo MIME y extensiones de archivos. El siguiente ejemplo de directriz le dice al Servidor HTTP Apache que reconozca la extensión de archivos .tgz: AddType application/x-tar .tgz Alias The Alias setting allows directories outside the DocumentRoot directory to be accessible. Any URL ending in the alias automatically resolves to the alias' path. By default, one alias for an icons/ directory is already set up. An icons/ directory can be accessed by the Web server, but the directory is not in the DocumentRoot. Allow Allow especifica cual cliente puede acceder a un directorio dado. El solicitantepuede ser all, un nombre de dominio, una dirección IP, una dirección IP parcial, un par de red/máscara de la red, etc. El directorio DocumentRoot está configurado para permitir (Allow) peticiones desde todos (all), es decir, que todos tienen acceso.
  • 31. 357 Sugerencias de configuración generales AllowOverride La directriz AllowOverride indica si puede o no ignorar cualquiera de las Options por las declaraciones en un archivo .htaccess. Por defecto, tanto el directorio raíz como DocumentRoot están configurados para no se permita ignorar .htaccess. BrowserMatch The BrowserMatch directive allows the server to define environment variables and take appropriate actions based on the User-Agent HTTP header field — which identifies the client's Web browser type. By default, the Web server uses BrowserMatch to deny connections to specific browsers with known problems and also to disable keepalives and HTTP header flushes for browsers that are known to have problems with those actions. Directrices Cache El archivo de configuración del Servidor HTTP Apache suministra varias directrices de caché comentadas. En la mayoría de los casos, al quitar el comentario de estas líneas mediante la eliminación de las almohadillas (#) del principio de la línea es suficiente.Sin embargo, lo siguiente es una lista de algunas de las directrices relacionadas con caché más importantes. • CacheEnable — Especifica si la caché es un disco, memoria o caché de archivo descriptivo. Por defecto CacheEnable configura un disco caché para las URLs en o por debajo de /. • CacheRoot — pone el nombre del directorio que contiene archivos de caché. El valor predeterminado de CacheRoot es el directorio /var/httpd/proxy/. • CacheSize — establece cuánto espacio puede usar el caché, en KB. El valor predeterminado de CacheSize es 5 KB. Lo siguiente es una lista de algunas directrices comunes relacionadas con caché. • CacheMaxExpire — Especifica cuanto tiempo se conservan los documentos HTML(sin una recarga desde el servidor Web original) en el caché. El valor por defecto es 24 horas (86400 segundos). • CacheLastModifiedFactor — Especifica la creación de una fecha de vencimiento para documentos que no venían con caducidad desde el servidor de origen. El valor predeterminado de CacheLastModifiedFactor está configurado a 0.1, es decir que la fecha de vencimiento para tales documentos es igual a un décimo de la cantidad de tiempo desde la última vez que se modificó el documento. • CacheDefaultExpire — Especifica el tiempo de caducidad en horas para un documento que fue recibido usando un protocolo que no soporta fechas de vencimiento. El valor por defecto es configurado a 1 hora (3600 segundos). • NoProxy — Especifica una lista separada por espacios de subredes, direcciones IP, dominios o hosts cuyos contenidos no están en caché. Este valor es de gran utilidad para sitios de Intranet. CacheNegotiatedDocs Por defecto, el servidor Web requiere a los servidores proxy que no hagan caché de los documentos que se negocian en base al contenido (pueden cambiar en el tiempo o según la entrada de quien los solicita). Si se configura CacheNegotiatedDocs a on, se desactiva la función y se permite acceso a los servidores proxy a tales documentos caché.
  • 32. 358 Sugerencias de configuración generales CustomLog CustomLog identifica el archivo de registro y su formato. Por defecto, el registro de acceso es guardado al archivo /var/log/httpd/access_log mientras que los errores se guardan en el archivo /var/log/httpd/error_log. El formato por defecto CustomLog es combined, como se ilustra a aquí: remotehost rfc931 user date "request" status bytes referrer user-agent DefaultIcon DefaultIcon especifica el icono desplegado en el listado generado por el servidor para archivos que no tienen otro icono especificado. El archivo de imagen por defecto es unknown.gif. DefaultType DefaultType establece el tipo de contenido por defecto que el servidor utilizará para documentos cuyos tipos MIME no puedan ser determinados. Por defecto es text/plain. Deny Deny funciona igual que Allow, excepto que especifica a quién se le niega el acceso. DocumentRoot no es configurado para negar (Deny) peticiones a ninguno por defecto. Directory <Directory /path/to/directory> and </Directory> tags create a container used to enclose a group of configuration directives which apply only to a specific directory and its subdirectories. Any directive which is applicable to a directory may be used within Directory tags. By default, very restrictive parameters are applied to the root directory (/), using the Options (refer to Options) and AllowOverride (refer to AllowOverride) directives. Under this configuration, any directory on the system which needs more permissive settings has to be explicitly given those settings. En la configuración predeterminada, otro contenedor Directory es configurado para el DocumentRoot, el cual asigna parámetros menos rígidos al árbol del directorio para que el Servidor HTTP Apache pueda acceder a los archivos que residan allí. The Directory container can be also be used to configure additional cgi-bin directories for server- side applications outside of the directory specified in the ScriptAlias directive (refer to ScriptAlias for more information). Para lograr esto, el contenedor Directory debe configurar la opción ExecCGI para ese directorio. Por ejemplo, si los scripts CGI están localizados en /home/my_cgi_directory, añada el contenedor siguiente Directory al archivo httpd.conf: <Directory /home/my_cgi_directory> Options +ExecCGI </Directory> Next, the AddHandler directive must be uncommented to identify files with the .cgi extension as CGI scripts. Refer to AddHandler for instructions on setting AddHandler.
  • 33. 359 Sugerencias de configuración generales Para que esto funcione, los permisos para los scripts CGI y la ruta completa a los scripts, se deben colocar a 0755. DirectoryIndex DirectoryIndex es la página por defecto que entrega el servidor cuando hay una petición de índice de un directorio especificado con una barra (/) al final del nombre del directorio. Cuando un usuario pide la página http://ejemplo/este_directorio/, recibe la página del índice del directorio, DirectoryIndex, si existe, o un listado de directorios generado por el servidor. El valor por defecto para DirectoryIndex es index.html y el tipo de mapa index.html.var. El servidor intentará encontrar cualquiera de estos archivos y entregará el primero que encuentre. Si no encuentra ninguno de estos archivos y Options Indexes esta configurado para ese directorio, el servidor genera y devuelve una lista, en formato HTML, de los subdirectorios y archivos dentro del directorio, a menos que la característica de listar directorios esté desactivada. DocumentRoot DocumentRoot es el directorio que contiene la mayoría de los archivos HTML que se entregarán en respuesta a peticiones. El directorio predeterminado DocumentRoot para servidores web seguros y no seguros es /var/www/html. Por ejemplo, el servidor puede recibir una petición para el siguiente documento: http://example.com/foo.html El servidor busca por el archivo siguiente en el directorio por defecto: /var/www/html/foo.html To change the DocumentRoot so that it is not shared by the secure and the non-secure Web servers, refer to Sección 22.7, “Hosts virtuales”. ErrorDocument La directriz ErrorDocument asocia un código de respuesta HTTP con un mensaje o un URL para que sea devuelto al cliente. Por defecto, el servidor Web produce una salida simple de mensaje de error cuando ocurre alguno. La directriz ErrorDocument obliga a que el servidor Web envie una salida de mensaje personalizado o página. Importante To be valid, the message must be enclosed in a pair of double quotes ". ErrorLog ErrorLog especifica el archivo donde se guardan los errores del servidor . Por defecto, esta directriz es configurada a /var/log/httpd/error_log.
  • 34. 360 Sugerencias de configuración generales ExtendedStatus The ExtendedStatus directive controls whether Apache generates basic (off) or detailed server status information (on), when the server-status handler is called. The server-status handler is called using Location tags. More information on calling server-status is included in Location. Group Especifica el nombre del grupo de los procesos del Servidor HTTP Apache. Esta directriz se ha desaprobado para la configuración de hosts virtuales. Por defecto, Group está configurado a apache. HeaderName La directriz HeaderName dicta el archivo (si existe dentro del directorio) que se antepondrá al comienzo de los listados de los directorios. Al igual que con ReadmeName, el servidor intentará incluirlo como documento HTMLsi es posible, o en caso contrario, como texto. HostnameLookups HostnameLookups se puede configurar a on, off o double. Si se configura HostnameLookups a on, el servidor automáticamente resuelve las direcciones IP para cada conexión. Resolver las direcciones IP significa que el servidor hace una o más conexiones a un servidor DNS, añadiendo sobrecarga por procesamiento. Si HostnameLookups es configurado a double, el servidor realiza búsquedas inversa doble del DNS, añadiendo aún más sobrecarga. Para ahorrar recursos en el servidor, HostnameLookups es configurado a off por defecto. Si se requieren nombres de host en los archivos de registro, considere ejecutar una de los muchas herramientas de análisis de log que llevan a cabo las búsquedas de DNS de forma mucho más eficiente y por montones cuando se este rotandolos archivos de log del servidor Web. IfDefine The IfDefine tags surround configuration directives that are applied if the "test" stated in the IfDefine tag is true. The directives are ignored if the test is false. The test in the IfDefine tags is a parameter name (for example, HAVE_PERL). If the parameter is defined, meaning that it is provided as an argument to the server's start-up command, then the test is true. In this case, when the Web server is started, the test is true and the directives contained in the IfDefine tags are applied. IfModule <IfModule> and </IfModule> tags create a conditional container which are only activated if the specified module is loaded. Directives within the IfModule container are processed under one of two conditions. The directives are processed if the module contained within the starting <IfModule> tag is loaded. Or, if an exclamation point ! appears before the module name, the directives are processed only if the module specified in the <IfModule> tag is not loaded.
  • 35. 361 Sugerencias de configuración generales For more information about Apache HTTP Server modules, refer to Sección 22.6, “Añadir módulos”. Include Include permite que se incluyan otros archivos de configuración en el tiempo de ejecución. La ruta a estos archivos de configuración pueden ser absolutas o relativas con respecto al ServerRoot. Importante Para que el servidor use módulos de paquetes individuales, como mod_ssl, mod_perl y php, tiene que estar la siguiente directriz en Section 1: Global Environment del httpd.conf: Include conf.d/*.conf IndexIgnore IndexIgnore lista las extensiones de archivo, los nombres de los archivos parciales, las expresiones con comodines o los nombres completos. El servidor Web no incluirá ningún archivo que coincida con estos patrones en los listados de directorios. IndexOptions IndexOptions controls the appearance of server generated directing listings, by adding icons, file descriptions, and so on. If Options Indexes is set (refer to Options), the Web server generates a directory listing when the Web server receives an HTTP request for a directory without an index. Primero el servidor Web busca en el directorio solicitado un archivo que coincida los nombres listados en la directriz DirectoryIndex (usualmente, index.html). Si el servidor no encuentra un archivo index.html el Servidor HTTP Apache genera un listado del directorio en HTML. La apariencia del listado de este directorio es controlada, en parte, por la directriz IndexOptions. La configuración predeterminada activa FancyIndexing. Esto significa que un usuario puede reordenar un listado de directorio haciendo clic en las cabeceras de columnas. Otro clic en la misma cabecera cambiará del orden ascendente al descendente. FancyIndexing también muestra iconos diferentes para diferentes archivos, basados en las extensiones de archivos. La opción AddDescription, cuando se utiliza junto con FancyIndexing, presenta una descripción corta para el archivo en los listados de directorios generados por el servidor. IndexOptions tiene otros parámetros que pueden activarse para controlar la apariencia de los listados generados por los servidores. Los parámetros IconHeight y IconWidth requieren que el servidor incluya etiquetas HTML HEIGHT y WIDTH para los iconos en las páginas generadas por el servidor. El parámetro IconsAreLinks combina el icono con el ancla HTML, la cual contiene el enlace URL objetivo. KeepAlive KeepAlive sets whether the server allows more than one request per connection and can be used to prevent any one client from consuming too much of the server's resources.
  • 36. 362 Sugerencias de configuración generales By default Keepalive is set to off. If Keepalive is set to on and the server becomes very busy, the server can quickly spawn the maximum number of child processes. In this situation, the server slows down significantly. If Keepalive is enabled, it is a good idea to set the the KeepAliveTimeout low (refer to KeepAliveTimeout for more information about the KeepAliveTimeout directive) and monitor the /var/log/httpd/error_log log file on the server. This log reports when the server is running out of child processes. KeepAliveTimeout La directriz KeepAliveTimeout establece el número de segundos que el servidor esperará tras haber dado servicio a una petición, antes de cerrar la conexión. Una vez que el servidor recibe una petición, se aplica la directriz Timeout en su lugar. KeepAliveTimeout está configurado a 15 segundos por defecto. LanguagePriority La directriz LanguagePriority permite dar la prioridad para diferentes idiomas en caso de que el navegador Web no especique la preferencia de idioma. Listen El comando Listen identifica los puertos en los que el servidor Web aceptará las peticiones entrantes. Por defecto, el Servidor HTTP Apache está configurado para escuchar en el puerto 80 para comunicaciones Web no seguras y (en el archivo /etc/httpd/conf.d/ssl.conf el cual define cualquier servidor seguro) en el puerto 443 para comunicaciones seguras. Si el Servidor HTTP Apache está configurado para escuchar en un puerto por debajo del 1024, se necesita al usuario root para iniciarlo. Para los puertos 1024 y superiores, httpd puede ser arrancado por cualquier usuario. La directriz Listen también se puede usar para especificar direcciones IP particulares sobre las cuales el servidor aceptará conexiones. LoadModule LoadModule is used to load Dynamic Shared Object (DSO) modules. More information on the Apache HTTP Server's DSO support, including instructions for using the LoadModule directive, can be found in Sección 22.6, “Añadir módulos”. Note, the load order of the modules is no longer important with Apache HTTP Server 2.0. Refer to Sección 22.2.2.1.3, “Soporte del Dynamic Shared Object (DSO) (Objeto dinámico compartido)” for more information about Apache HTTP Server 2.0 DSO support. Location The <Location> and </Location> tags create a container in which access control based on URL can be specified. For instance, to allow people connecting from within the server's domain to see status reports, use the following directives: <Location /server-status> SetHandler server-status Order deny,allow Deny from all Allow from <.example.com> </Location>
  • 37. 363 Sugerencias de configuración generales Replace <.example.com> with the second-level domain name for the Web server. Para proporcionarinformes de configuración del servidor (incluyendo los módulos instalados y las directrices de configuración) a peticiones desde dentro del dominio, utilice las siguientes directrices: <Location /server-info> SetHandler server-info Order deny,allow Deny from all Allow from <.example.com> </Location> Again, replace <.example.com> with the second-level domain name for the Web server. LogFormat The LogFormat directive configures the format of the various Web server log files. The actual LogFormat used depends on the settings given in the CustomLog directive (refer to CustomLog). Las siguientes son las opciones de formato si la directriz CustomLog es configurada a combined: %h (remote host's IP address or hostname) Lista la dirección IP de la máquina remota del cliente solicitante. Si HostnameLookups es configurada a on, el nombre de máquina del cliente es registrado a menos que no este disponible desde el DNS. %l (rfc931) No se usa. Un guión - aparece en el campo de registro para este campo. %u (usuario autenticado) Si se requiere autenticación,lista el nombre del usuario registrado. Usualmente, esto no se utiliza, por tanto aparece un guión - en el archivo de registro para este campo. %t (fecha) Lista la fecha y hora de la solicitud. %r (cadena de la solicitud) Lista la cadena de la solicitud exactamente como viene del navegador o cliente. %s (estado) Lista el estado de código HTTP el cual fue devuelto al host cliente. %b (bytes) Lista el tamaño del documento. %"%{Referer}i" (referrer) Lista la dirección URL de la página web que refiere el máquina cliente al servidor Web. %"%{User-Agent}i" (user-agent) Lista el tipo de navegador Web que está realizandola solicitud. LogLevel LogLevel establece la cantidad de detalles que tendrán los registros de mensajes de error. LogLevel se puede configurar (desde el que tiene menos detalles a los más detallados) a emerg, alert, crit, error, warn, notice, info o debug. El valor predeterminado de LogLevel es warn.
  • 38. 364 Sugerencias de configuración generales MaxKeepAliveRequests This directive sets the maximum number of requests allowed per persistent connection. The Apache Project recommends a high setting, which improves the server's performance. MaxKeepAliveRequests is set to 100 by default, which should be appropriate for most situations. NameVirtualHost La directriz NameVirtualHost asocia una dirección IP y el número de puerto, si es necesario, para cualquier máquina virtual basada en nombres. El hospedaje virtual basado en nombres permite a un Servidor HTTP Apache servir a dominios diferentes sin utilizar múltiples direcciones IP. Nota Los hosts virtuales basados en nombre only funcionan con conexiones HTTP no seguras. Si está usando host virtuales con un servidor seguro, use host virtuales basados en direcciones IP. Para habilitar el hospedaje basado en nombres, quite los comentarios de la directriz de configuración NameVirtualHost y añada la dirección IP correcta. Luego añada más contenedores VirtualHost para cada host virtual como sea necesario para su configuración. Options La directriz Options controla cuáles características del servidor están disponibles en un directorio en particular. Por ejemplo, en los parámetros restrictivos especificados para el directorio raíz, Options sólo permite FollowSymLinks. No hay características activadas, salvo que el servidor puede seguir enlaces simbólicos en el directorio raíz. Por defecto, en el directorio DocumentRoot, Options se configura para incluir Indexes y FollowSymLinks. Indexes permite al servidor generar un listado de un directorio si no se especifica el DirectoryIndex (por ejemplo, index.html). FollowSymLinks permite al servidor seguir enlaces simbólicos en ese directorio. Nota Options statements from the main server configuration section need to be replicated to each VirtualHost container individually. Refer to VirtualHost for more information. Order La directriz Order controla el orden en el cual las directrices allow y deny son evaluadas. El servidor es configurado para evaluar las directrices Allow antes de las directrices Deny para el directorio DocumentRoot. PidFile PidFile nombra el archivo en el que el servidor graba su ID de proceso (pid). Por defecto, el PID es listado en /var/run/httpd.pid.
  • 39. 365 Sugerencias de configuración generales Proxy <Proxy *> and </Proxy> tags create a container which encloses a group of configuration directives meant to apply only to the proxy server. Many directives which are allowed within a <Directory> container may also be used within <Proxy> container. ProxyRequests To configure the Apache HTTP Server to function as a proxy server, remove the hash mark (#) from the beginning of the <IfModule mod_proxy.c> line, the ProxyRequests, and each line in the <Proxy> stanza. Set the ProxyRequests directive to On, and set which domains are allowed access to the server in the Allow from directive of the <Proxy> stanza. ReadmeName La directriz ReadmeName determina el archivo (si existe dentro del directorio) que se adjuntará a los listados de los directorios. El servidor Web intentará primero incluirlo como documento HTMLy luego como texto plano. El valor predeterminado de ReadmeName es README.html. Redirect Cuando se mueve una página web, se puedeutilizar Redirect para crear asignaciones de la ubicación del archivo a un nuevo URL. El formato es como sigue: Redirect /<old-path>/<file-name> http://<current-domain>/<current-path>/<file-name> In this example, replace <old-path> with the old path information for <file-name> and <current-domain> and <current-path> with the current domain and path information for <file-name>. In this example, any requests for <file-name> at the old location is automatically redirected to the new location. Para técnicas de redireccionamiento más avanzadas, utilice el módulo mod_rewrite incluido con el Servidor HTTP Apache. Para obtener más información sobre la configuración del módulo mod_rewrite refiérase a la documentación de la Apache Software Foundation en http:// httpd.apache.org/docs/2.2/mod/mod_rewrite.html 23 . ScriptAlias La directriz ScriptAlias define donde pueden encontrarse los scripts CGI. Normalmente, no es una buena idea colocar los scripts CGI dentro de DocumentRoot, donde podrían, potencialmente, ser visualizados como documentos de texto. Por esta razón, la directriz ScriptAlias diseña un directorio especial fuera del directorio DocumentRoot para contener ejecutables del servidor y scripts. Este directorio es conocido como un cgi-bin y se configura por defecto a /var/www/cgi- bin/. It is possible to establish directories for storing executables outside of the cgi-bin/ directory. For instructions on doing so, refer to AddHandler and Directory. 23 http://httpd.apache.org/docs/2.2/mod/mod_rewrite.html
  • 40. 366 Sugerencias de configuración generales ServerAdmin Configure la directriz ServerAdmin a la dirección de correo electrónico del administrador del servidor Web. Esta dirección de correo aparecerá en los mensajes de error en las páginas generadas por el servidor Web, de tal manera que los usuarios pueden comunicar errores enviando correo al administrador. Por defecto, ServerAdmin es configurado a root@localhost. Una forma típica de configurar ServerAdmin es configurarlo en a webmaster@ejemplo.com. Una vez configurado, cree un alias del webmaster para la persona responsable del servidor Web en / etc/aliases y ejecute /usr/bin/newaliases. ServerName ServerName specifies a hostname and port number (matching the Listen directive) for the server. The ServerName does not need to match the machine's actual hostname. For example, the Web server may be www.example.com, but the server's hostname is actually foo.example.com. The value specified in ServerName must be a valid Domain Name Service (DNS) name that can be resolved by the system — do not make something up. Lo siguiente es una directriz ServerName de ejemplo: ServerName www.example.com:80 Cuando especifique un ServerName, asegúrese de que el par de la dirección IP y el nombre del servidor esten incluidos en el archivo /etc/hosts. ServerRoot The ServerRoot directive specifies the top-level directory containing website content. By default, ServerRoot is set to "/etc/httpd" for both secure and non-secure servers. ServerSignature La directriz ServerSignature añade una línea que contiene la versión del Servidor HTTP Apache y el ServerName para cualquier documento generado por el servidor, tales como mensajes de error devueltos a los clientes. Por defecto ServerSignature está configurada a on. ServerSignature se puede configurar como EMail el cual añade una etiqueta HTML mailto:ServerAdmin a la línea de firma de respuestas auto generadas. Tambiénse puede configurar como Off para que Apache pare de enviar su número de versión y la información del módulo. Revise también la configuración de ServerTokens. ServerTokens La directriz ServerTokens determina si el encabezamiento de la respuesta del servidor que se devuelve al cliente debe incluir detalles sobre el tipo de Sistema Operativo e información sobre los módulos compilados. Por defecto, ServerTokens se encuentra configurado como Full y por tanto envía información sobre el tipo del Sistema Operativo y lo módulos compilados. Al configurar ServerTokens como Prod envía el nombre del producto sólamente y se recomienda un buen número de hackers revise la información en el encabezamiento del servidor en la búsqueda de vulnerabilidades. También puede configurar ServerTokens como Min (minimal) o como OS (sistema operativo).
  • 41. 367 Sugerencias de configuración generales SuexecUserGroup La directriz SuexecUserGroup, que se origina desde el módulo mod_suexec, permite especificar privilegios de ejecución de usuario y grupo para programas CGI. Las solicitudes no CGI también son procesadas con el usuario y el grupo especificado en las directrices User y Group. Nota Desde la versión 2.0, la directriz SuexecUserGroup reemplaza la configuración del Servidor HTTP Apache versión 1.3 de utilizar las directrices User y Group dentro de la configuración de las secciones VirtualHosts. Timeout Timeout define, en segundos, el tiempo que el servidor esperará por recibir y transmitir durante la comunicación. Timeout está configurado por defecto a 300 segundos, lo cual es apropiado para la mayoría de las situaciones. TypesConfig TypesConfig nombra el archivo que configura la lista por defecto de asignaciones tipo MIME (extensiones de nombres de archivo a tipos de contenido). El archivo predeterminado TypesConfig es /etc/mime.types. En vez de modificar el /etc/mime.types, la forma recomendada de añadir asignaciones de tipo MIME es usando la directriz AddType. For more information about AddType, refer to AddType. UseCanonicalName Cuando se configure esta directriz como on, se está indicando al Servidor HTTP Apache a que se referencie asímismo utilizando el valor especificado en las directrices ServerName y Port. Cuando UseCanonicalName es configurada como off, el servidor usará el valor usado por el cliente solicitante cuando se refiera a él. UseCanonicalName está configurada a off por defecto. User La directriz User establece el nombre de usuario para el proceso del servidor y determina qué archivos pueden acceder al servidor. Cualquier archivo que no esté accesible a este usuario tampoco estará disponiblepara los clientes conectándose al Servidor HTTP Apache. Por defecto User es configurado a apache. Esta directriz se ha desaprobado para la configuración de hosts virtuales. Nota Por razones de seguridad, el Servidor HTTP Apache no se ejecuta como el usuario root.
  • 42. 368 Sugerencias de configuración generales UserDir UserDir is the subdirectory within each user's home directory where they should place personal HTMLfiles which are served by the Web server. This directive is set to disable by default. El nombre para el subdirectorio esta configurado a public_html en la configuración por defecto. Por ejemplo, el servidor puede recibir la siguiente petición: http://example.com/~username/foo.html El servidor buscará por el archivo: /home/username/public_html/foo.html In the above example, /home/username/ is the user's home directory (note that the default path to users' home directories may vary). Make sure that the permissions on the users' home directories are set correctly. Users' home directories must be set to 0711. The read (r) and execute (x) bits must be set on the users' public_html directories (0755 also works). Files that are served in a users' public_html directories must be set to at least 0644. VirtualHost <VirtualHost> and </VirtualHost> tags create a container outlining the characteristics of a virtual host. The VirtualHost container accepts most configuration directives. A commented VirtualHost container is provided in httpd.conf, which illustrates the minimum set of configuration directives necessary for each virtual host. Refer to Sección 22.7, “Hosts virtuales” for more information about virtual hosts. Nota El contenedor de host virtuales SSL por defecto reside en el archivo /etc/httpd/ conf.d/ssl.conf. 22.5.2. Configuración de directrices para SSL Las directrices en el archivo /etc/httpd/conf.d/ssl.conf se pueden configurar para activar las comunicaciones Web seguras usando SSL y TLS. SetEnvIf SetEnvIf sets environment variables based on the headers of incoming connections. It is not solely an SSL directive, though it is present in the supplied /etc/httpd/conf.d/ssl.conf file. It's purpose in this context is to disable HTTP keepalive and to allow SSL to close the connection without a closing notification from the client browser. This setting is necessary for certain browsers that do not reliably shut down the SSL connection. Para más información sobre otras directrices dentro del archivo de configuración SSL, consulte los siguientes URLs:
  • 43. 369 Directrices MPM específicas al pool de servidores • http://localhost/manual/mod/mod_ssl.html • http://httpd.apache.org/docs/2.2/mod/mod_ssl.html Nota En la mayoría de los casos, las directrices SSL son configuradas apropiadamente durante la instalación de Red Hat Enterprise Linux. Tenga cuidado cuando altere las directrices del Servidor Seguro HTTP de Apache pues un error en la configuración puede provocar que el servidor sea vulnerable en términos de seguridad. 22.5.3. Directrices MPM específicas al pool de servidores As explained in Sección 22.2.2.1.2, “Regulación del tamaño del pool de servidores”, the responsibility for managing characteristics of the server-pool falls to a module group called MPMs under Apache HTTP Server 2.0. The characteristics of the server-pool differ depending upon which MPM is used. For this reason, an IfModule containeris necessary to define the server-pool for the MPM in use. Por defecto, el Servidor HTTP Apache 2.0 define el pool de servidores para ambos MPMs: prefork y worker. La sección siguiente lista las directrices encontradas dentro de los contenedores del pool de servidores específicos al MPM. MaxClients MaxClients sets a limit on the total number of server processes, or simultaneously connected clients, that can run at one time. The main purpose of this directive is to keep a runaway Apache HTTP Server from crashing the operating system. For busy servers this value should be set to a high value. The server's default is set to 150 regardless of the MPM in use. However, it is not recommended that the value for MaxClients exceeds 256 when using the prefork MPM. MaxRequestsPerChild MaxRequestsPerChild establece el número máximo de peticiones que cada proceso de servidor hijo procesa antes de morir. La principal razón para configurar MaxRequestsPerChild es evitar que procesos de larga vida gasten memoria. El valor predeterminado de MaxRequestsPerChild para el MPM prefork es de 4000 y, para el MPM worker, es 0. MinSpareServers y MaxSpareServers Estos valores solamente se utilizan con el MPM prefork. Ellos ajustan como el Servidor HTTP Apache se adapta dinámicamente a la carga percibida manteniendo un número apropiado de procesos de servidor extras o de repuesto basado en el número de peticiones entrantes. El servidor comprueba el número de servidores que esperan peticiones y elimina algunos si el número es más alto que MaxSpareServers o crea algunos si el número de servidores es menor que MinSpareServers. El valor predeterminado de MinSpareServers es 5 y el de MaxSpareServers es 20. Estos valores predeterminados son suficientes en la mayoría de los casos. Tenga cuidado de no incrementar el número de MinSpareServers a un número muy elevado ya que creará una gran carga de procesamiento, incluso cuando el tráfico fuese bajo.
  • 44. 370 Directrices MPM específicas al pool de servidores MinSpareThreads y MaxSpareThreads Estos valores solamente son utilizado con el MPM worker. Ellos ajustan como el Servidor HTTP Apache se adapta dinámicamente a la carga percibida manteniendo un número apropiado de hilos de servidores extras basado en el número de peticiones entrantes. El servidor comprueba el número de hilos de servidores que esperan peticiones y elimina algunos si el número es más alto que MaxSpareThreads o crea algunos si el número de servidores es menor que MinSpareThreads. El valor predeterminado de MinSpareThreads es 25 y el de MaxSpareThreads es 75. Estos valores predeterminados son apropiados en la mayoría de los casos. El valor para MaxSpareThreads debe ser mayor o igual que la suma de MinSpareThreads y ThreadsPerChild, de lo contrario el Servidor HTTP Apache lo corregirá automáticamente. StartServers La directriz StartServers establece cuántos procesos de servidor serán creados al arrancar. Ya que el servidor Web crea y elimina dinámicamente procesos de servidor según el tráfico, no se necesitará cambiar este parámetro. El servidor web está configurado para arrancar 8 procesos del servidor al arrancar para el MPM prefork y 2 para el MPM worker. ThreadsPerChild Este valor solamente es utilizado con el MPM worker. Configura el número de hilos dentro de cada proceso hijo. El valor por defecto para esta directriz es 25. 22.6. Añadir módulos El Servidor HTTP Apache se distribuye con un número de módulos. Para obtener más información sobre los módulos HTTP Apache diríjase a http://httpd.apache.org/docs/2.2/mod/. El Servidor HTTP Apache soporta Objetos Compartidos Dinámicamente (Dynamically Shared Objects, DSOs) o módulos, los cuales se pueden cargar fácilmente en el momento de ejecución. El Proyecto Apache proporciona Documentación DSO completa en línea en http://httpd.apache.org/ docs/2.2/dso.html. Si el paquete http-manual está instalado,se puede encontrar documentación sobre DSOs en http://localhost/manual/mod/. For the Apache HTTP Server to use a DSO, it must be specified in a LoadModule directive within /etc/httpd/conf/httpd.conf. If the module is provided by a separate package, the line must appear within the modules configuration file in the /etc/httpd/conf.d/ directory. Refer to LoadModule for more information. If adding or deleting modules from http.conf, Apache HTTP Server must be reloaded or restarted, as referred to in Sección 22.3, “Arrancar y detener httpd”. Si está creando un nuevo módulo, instale primero el paquete httpd-devel pues contiene los archivos include, las cabeceras de archivos así como también la aplicación APache eXtenSion (/ usr/sbin/apxs), la cual utiliza los archivos include y las cabeceras para compilar DSOs. Después de escribir un módulo, utilice /usr/sbin/apxs para compilar las fuentes del módulo fuera del árbol de fuentes Apache. Para obtener más información sobre el uso del comando /usr/sbin/ apxs, vea la documentación de Apache en línea en http://httpd.apache.org/docs/2.2/dso.html y en la página man de apxs.
  • 45. 371 Hosts virtuales Una vez compilado, coloque el módulo en el directorio /usr/lib/httpd/modules/. Para las plataformas RHEL que utilizan el espacio de usuario de 64 bits predeterminado (x86_64, ia64, ?) esta ruta será /usr/lib64/httpd/modules/. Luego añada una línea LoadModule al archivo httpd.conf usando la siguiente estructura: LoadModule <module-name> <path/to/module.so> Where <module-name> is the name of the module and <path/to/module.so> is the path to the DSO. 22.7. Hosts virtuales The Apache HTTP Server's built in virtual hosting allows the server to provide different information based on which IP address, hostname, or port is being requested. A complete guide to using virtual hosts is available online at http://httpd.apache.org/docs/2.2/vhosts/. 22.7.1. Configuración de máquinas virtuales Para crear un host virtual basado en nombre, lo mejor es utilizar el contenedor del host virtual proporcionado en httpd.conf como un ejemplo. El ejemplo de máquina virtual se lee como sigue: #NameVirtualHost *:80 # #<VirtualHost *:80> # ServerAdmin webmaster@dummy-host.example.com # DocumentRoot /www/docs/dummy-host.example.com # ServerName dummy-host.example.com # ErrorLog logs/dummy-host.example.com-error_log # CustomLog logs/dummy-host.example.com-access_log common #</VirtualHost> Para activar máquinas virtuales basadas en nombre, quite los comentarios de la línea NameVirtualHost eliminando el símbolo de numeral o almohadilla (#) y reemplazando el asterísco (*) con la dirección IP asignada a la máquina. Next, configure a virtual host by uncommenting and customizing the <VirtualHost> container. On the <VirtualHost> line, change the asterisk (*) to the server's IP address. Change the ServerName to a valid DNS name assigned to the machine, and configure the other directives as necessary. The <VirtualHost> container is highly customizable and accepts almost every directive available within the main server configuration. Tip Si se está configurandoun host virtual para que escuche en un puerto no predeterminado, se debe agregar ese puerto a la directriz Listen en la sección de configuraciones globales del archivo /etc/httpd/conf/http.conf.