Apache es el servidor web mas utilizado en sistemas GNU/Linux y Unix. Los servidores web seusan para el alojamiento de paginas web solicitadas por el cliente a través de internet desde losnavegadores de web, actualmente el servidor apache se encuentra en la versión 2. Viene con las siguiente ventajas y beneficios proporcionados por el software de servidor apache:
El protocolo utilizado para ver paginas web es el Hyper Text Tranfer Protocol(Protocolo de Transferencia de hipertexto), protocolo es de los pilares de la www.
El puerto predeterminado para las solicitudes http es el puerto 80, aunque también puede configurarse un servidor web para que utilice un puerto diferente que no se este ocupando en ese momento. También existen otro puerto para el servidor apache el cual es 443, este puerto solamente es ocupado para conexiones seguras del apache (https).
Para poder instalar apache solamente tenemos que ejecutar el siguiente comando.
root@server1:~# apt-get install apache2 elinks
Lo que se hizo fue instalar el servidor apache2 y el paquete elinks es un navegador web vía consola de comandos. Cuando termina de instalar el servidor apache sera iniciado automáticamente, ante solamente tendremos acceso a la pagina de bienvenida o de prueba de apache.
Opciones de ejecución apache. Apache tiene varias opciones opciones de ejecución dentro apache.
root@server1:~# /etc/init.d/apache2 {start|stop|restart|reload|forcereload}
Como pudimos ver nuestro servidor apache tiene varias opciones:
OPCION | DESCRIPCION |
---|---|
start | Inicia el servicio de apache. |
stop | Detiene el servicio de apache. |
restart | Reinicia el servicio de apache. |
reload | Recarga los últimos cambios registrados dentro del servicio de apache. |
Force-reload | Forzar a realizar una recarga de los últimos cambios realizados dentro del servicio de apache. |
Ejemplo: Como reiniciar el servidor apache.
root@server1:~# /etc/init.d/apache2 restart * Restarting web server apache2 [ OK ] root@server1:~#
Ficheros de configuración. La ruta de configuración de los archivos del servicio de apache se localiza en:
/etc/apache2/
Para poder entrar a la ruta solamente tenemos que hacer lo siguiente:
root@server1:~# cd /etc/apache/
Dentro de este directorio encontraremos varios archivos y carpetas como las siguientes:
OPCION | DESCRIPCION |
---|---|
apache2.conf | Dentro de este archivo se encuentra la configuración del servidor web apache. |
conf.d | Directorio en donde se encuentran los archivos de configuración de apache. |
envvars | Este archivo de configuración contiene la información del usuario, grupo Y PID del servicio de apache. |
httpd.conf | Este era el archivo de configuración, pero todavía esta siendo ocupado en la distribución Red Hat y derivados. |
mods-available | Directorio en se depositan los módulos que se vayan agregar a nuestro servidor apache. |
mods-enabled | Directorio donde se encontrara el modulo cuando ya este activado y esta disponible para apache. Este carpeta solamente contiene ligas suaves a los módulos. |
port.conf | Archivo de configuración en donde se especifica el puerto de escucha, por default es 80 y 443. |
sites-available | Directorio en donde se encuentran los archivos de configuración de sitios o paginas web que configuremos. Dentro de esta carpeta se encuentra un archivo de default el cual trae la configuración de la pagina de bienvenida de nuestro apache. |
sites-enabled | Directorio en donde se habilita los sitios web, también son ligas suaves a los sitios. |
Como sabemos al terminar de instalar apache ya es iniciado en automático ya que no requiere de modificaciones para funcionar. Lo que haremos en este momento es añadir un alias a un directorio localizado en /var/ww/pub y cual queremos visualizar como el directorio /pub/ en apache, para esto tenemos que crear un fichero de configuración el cual nos permite hacer esta opción. Como vimos anteriormente todos estos archivos de configuración van dentro del directorio sitesavailable.
root@server1:~# cd /etc/apache/sitesavailable
Estando dentro de este directorio tenemos que crear el archivo de configuracion.
root@server1:sitesavailable# vim alias.conf
El cual tendrá la siguiente información.
Alias /pub /var/www/pub <Directory "/var/www/pub"> Options Indexes Includes FollowSymLinks AllowOverride all </Directory>
Guardamos el archivo y nos vamos a la siguiente ruta:
root@server1:sitesavailable# cd /var/www
Dentro de esta ruta en donde se depositaran las paginas web de cada sitio que tengamos registrados. Lo que haremos es crear una carpeta pub y le daremos permisos.
root@server1:www# mkdir pub
Lo que haremos es dar permisos de grupo para que sea ocupada por apache.
root@server1:www# chown root.www-data pub -R
Ahora tendremos que recargar los ultimos cambios de nuestro servidor web.
root@server1:www# /etc/init.d/apache2 reload * Reloading web server config apache2 [ OK ] root@server1:/var/www#
Utilizaremos nuestro navegador web elinks el cual se ejecuta desde consola
root@server1:www# elinks http://192.168.1.243/pub
Como vimos que creamos un archivo de configuración de una carpeta pub, comentaremos ahora para que es cada opción.
Este parámetro permite definir directorios virtuales e instalar tu sitio web “fuera” del DocumentRoot e incluso en otro servidor.
Alias /pub /var/www/pub
Este parámetro se usa para englobar un grupo de directivas que se aplicaran solamente al directorio especificado y a sus subdirectorios.
<Directory "/var/www/pub"> </Directory>
Configura las funcionalidades disponibles en un directorio en particular
Options Indexes Includes FollowSymLinks AllowOverride all
Permite el uso de directivas que controlan el indexado de directorio.
Options Indexes Includes FollowSymLinks AllowOverride all
Permite incluir Server-side, puede ejecutar programas dentro del servidor (php,perl, etc).
Options Indexes Includes FollowSymLinks AllowOverride all
El servidor seguira los enlaces simbolicos en este directorio.
Options Indexes Includes FollowSymLinks AllowOverride all
AllowOverride controla qué directivas de los ficheros .htaccess. Los valores de AllowOverride pueden ser “All”, “None”,
Options Indexes Includes FollowSymLinks AllowOverride all
Los dominios virtuales consisten en utilizar el mismo servidor web para atender varios dominios. En estos casos solo se dispone de una sola dirección IP publica y esta misma esta enlazada a varios dominios.
Tendremos que entrar a la siguiente ruta.
root@server1:~# cd /etc/apache2/ root@server1:apache2#
Todas las configuración de los virtualhost se guardan dentro del directorio sites-available.
root@server1:apache2# cd sites-available/ root@server1:sites-available#
Ya estando adentro tendremos que crear el archivo de configuración de cada dominio.
root@server1:sites-available# vim rodmen.conf
Y tendremos que agregar lo siguiente.
<VirtualHost *> DocumentRoot /var/www/rodmen.com ServerName www.rodmen.com ServerAdmin admin@rodmen.com ErrorLog /var/www/rodmen.com/log/error_log CustomLog /var/www/rodmen.com/log/access_log combined </VirtualHost> <Directory "/var/www/rodmen.com"> AllowOverride All </Directory>
Tendremos que crear el deposito de la pagina web del dominio rodmen.com.
root@server1:sites-available# mkdir /var/www/rodmen.com
Ahora vamos a explicar para que sirva cada parámetro del VirtualHost.
En apache existen dos tipos de Host Virtuales:
En este parámetro que estamos viendo indicamos que todas las direcciones IP asignadas apache serán utilizadas para soportar los Host Virtuales.
<VirtualHost *> </VirtualHost>
Por cada virtualhost que vayamos agregar lo tendremos que agregar entre las directivas <VirtualHost> </VirtualHost>
Indica el directorio desde donde se servirán los documentos web.
DocumentRoot /var/www/rodmen.com
El cual indica el nombre del Host por el cual responderá su sitio web, tambien se puede especificar algún puerto de escucha.
ServerName www.rodmen.com
Especifica la dirección de correo electrónico del administrador del servidor.
ServerAdmin admin@rodmen.com
Esta opción indica en donde se encuentra el archivo en el cual se registran los errores para este sitio.
ErrorLog /var/www/rodmen.com/log/error_log
Esta opción especifica primero el archivo donde se anotan las peticiones hechas al servidor y en segundo lugar el tipo de anotación según se haya definido.
CustomLog /var/www/rodmen.com/log/access_log combined
Tendremos que agregar el usuario encargado del mismo.
root@server1:sitesavailable# useradd -g ftp -d /var/www/pub/ -s /bin/ftp \ rodmen root@server1:/var/www/pub# passwd rodmen Enter new UNIX password: Retype new UNIX password: passwd: password updated successfully root@server1:sites-available#
Tendremos que cambiar el usuario y grupo encargado del deposito.
root@server1:sites-available# chown rodmen.www-data /var/www/rodmen.com/ -R
Ahora tendremos que crear el directorio de los log los archivo que contiene.
root@server1:sitesavailable# cd /var/www/rodmen.com/ root@server1:rodmen.com#
Tendremos que crear el directorio log.
root@server1:rodmen.com# mkdir log
Dentro de este tendremos que crear dos archivo de texto plano, los cuales registraran los accesos al sitio como también los errores.
root@server1:rodmen.com# touch log/access_log root@server1:rodmen.com# touch log/error_log
Tendremos que editar el fichero hosts ya que sean enlace el nombre con la ip de nuestro servidor.
root@server1:sites-available# vim /etc/hosts
Agregar la siguiente linea.
127.0.0.1 localhost 127.0.1.1 server1.factor.dynalias.net server1 192.168.1.243 www.rodmen.com rodmen
Una forma de checar que ya esta funcionando el hacer un ping al dominio.
root@server1:sitesavailable# ping -c 2 www.rodmen.com
Ya que tenemos el archivo de configuración del virtualhost, usuario, logs y hosts, ya podemos activar el dominio virtual dentro de apache. Primero entraremos en la ruta en donde se encuentra el archivo de configuración del virtualhost a activar.
root@server1:rodmen.com# cd /etc/apache2/sites-available/ root@server1:sites-available#
Ya estando ahí tendremos que usar el comando a2ensite y el archivo de configuración del dominio virtual.
root@server1:site-savailable# a2ensite rodmen.conf Site fabian.conf installed; run /etc/init.d/apache2 reload to enable. root@server1:sites-available#
Nos muestra una salida en la cual indica que tenemos que hacer una recarga de apache.
root@server1:sites-available# /etc/init.d/apache2 reload * Reloading web server config apache2 [OK] root@server1:sites-available#
Entonces podemos ahora ejecutar nuestro navegador web desde consola.
root@server1:sites-available# elinks http://www.rodmen.com
Para poder desactivar un dominio tendremos que ejecutar el comando a2dissite mas el archivo del virtualhost.
root@server1:sites-available# a2dissite rodmen.conf Site fabian.conf disabled; run /etc/init.d/apache2 reload to fully disable.
Y nos pide que también recarguemos el apache.
root@server1:sites-available# /etc/init.d/apache2 start * Starting web server apache2 [OK] root@server1:sites-available#
Los htaccess son archivo en texto plano ocultos que contienen una serie de directivas para el servidor apache. El servidor busca dentro del directorio y subcarpetas del sitio El uso para que se ocupan los htaccess para:
Para poder crear el fichero htaccess, lo haremos dentro del deposito del sitio a desear.
root@server1:~# cd /var/www/rodmen.com/ root@server1:rodmen.com#
Crearemos el archivo htaccess pero este archivo es oculto.
root@server1:rodmen.com# touch .htaccess
Ahora tendremos que editar este archivo, agregarle los siguientes datos y guardarlo.
AuthName "ZONA VIP" AuthType Basic require validuser AuthUserFile /var/www/rodmen.com/claves
Hay que crear otro archivo plano en donde se almacenaran contraseñas.
root@server1:rodmen.com# touch /var/www/rodmen.com/claves
Tendremos que darle seguridad al fichero que hemos creado.
root@server1:rodmen.com# chmod 600 claves root@server1:rodmen.com# chown www-data.www-data claves root@server1:rodmen.com#
Ahora crearemos el usuario y contraseña.
root@server1:rodmen.com# htpasswd claves rodrigo New password: Re-type new password: Adding password for user rodrigo
Reiniciamos apache.
root@server1:rodmen.com# /etc/init.d/apache2 restart * Restarting web server apache2 [ OK ] root@server1:rodmen.com#
Ahora que usemos nuestro navegador web hacia el sitio rodmen.com, nos solicitara el usuario y contraseña para poder acceder. Lo que se hizo es darle mas seguridad al sitio ya solamente usuario autenticados podrán conectarse al sitio.
Un modulo en Apache, es la forma de poder agrupar y modularizar ciertos funcionamientos para el servidor, se encuentra una lista de los módulos en:
Una de las principales razones de emplear módulos en Apache, es que no toda instalación requiere de las mismas funcionalidades, si fueran incluidas todas las funcionalidades posibles en una versión única de Apache, esto lo haría sumamente pesado en cuanto a requerimientos de Memoria RAM y espacio en Disco Duro. Existen dos tipos de módulos:
Para poder ver los módulos que tenemos activados en apache tenemos que ejecutar:
root@server1:~# apache2ctl -l Compiled in modules: core.c mod_log_config.c mod_logio.c http_core.c mod_so.c
En algunos casos apache no carga los módulos automáticamente y tendremos que agregarlos manualmente.
root@server1:~#a2enmod modulo
Para desactivar módulos tenemos que ejecutar el siguiente comando.
root@server1:~#a2dismod modulo
Es una interfaz de usuario al servidor que ayudar al administrador controlar el funcionamiento del demonio de apache. La herramienta apache2ctl tiene varias opciones:
OPCION | DESCRIPCION |
---|---|
start | Inicia el servicio de apache. |
stop | Detiene el servicio de apache. |
reload | Reinicia el servicio de apache. |
fullstatus | Muestra un reporte del estado completo de apache. |
status | Muestra un reporte del estado breve de apache. |
graceful | Reinicia delicadamente el servicio apache enviando una señal SIGUSR1. |
configtest | Corre una prueba hacia los archivos de configuración de apache, en caso de que devuelva Syntax OK indica que toda la configuración de apache esta bien o marca el error. |
Apache contiene dos archivos en los cuales se almacenan los log de acceso y error.
Estan importante esta información para el administrador del servidor ya que ellos puede obtener estadísticas o un posible problema que tenga el mismo. Se recomienda siempre ver los logs.
root@server1:~# tail -f /var/log/apache2/error.log