|
|
(5 revisiones intermedias por el mismo usuario no mostrado) |
Línea 81: |
Línea 81: |
| <div class="slide"> | | <div class="slide"> |
| ===Servidor Web=== | | ===Servidor Web=== |
| + | ;Proceso de comunición '''''tcp/ip''''' |
| + | [[Archivo:transmision_tcp_ip2.png|center]] |
| + | *Es importante entender el concepto de protocolo. |
| + | {{MRM_Definicion|Title=Protocolo| |
| + | ;Un programa que implementa una serie de reglas y normas para que dos partes diferentes se puedan comunicar. |
| + | }} |
| + | *Un protocolo es un programa, pero solo el programa de '''''nivel de aplicación''''' vamos a gestinar (instalar, eliminar, configurar), el resto de software (protocolos de otros niveles), son parte del kernel del sistema operativo, a los que no tenemos acceso de gestionar, pero sí, a veces, de configurar, como estalbecer el ''número ip' dentro del '''''protocolo ip o protocolo de internet'''''. |
| + | |
| + | ;El Servidor |
| + | *La imagen anterior, muestra el proceso de comunicación tcp/ip entre dos dispositivos. |
| + | *El equipo que recibe la comunicación se conoce como servidor, por el hecho de que están ejecutándose en él diferentes programas servidores. |
| + | *Cada programa está escuchando por un puerto, que es quién le identifica, de modo que cuando la tarjeta de red recibe un paquete, datagrama o fragmento (un grupo de bits), si el nivel de red, decide que es él el destinatario, desde el nivel de transporte sabe a qué aplicación entregarlo. |
| + | |
| [[Archivo:solicitud_web_2.png|center]] | | [[Archivo:solicitud_web_2.png|center]] |
| </div> | | </div> |
Línea 192: |
Línea 205: |
| | | |
| </div> | | </div> |
| + | |
| + | <div class="slide"> |
| | | |
| ===Configuración de un servidor web=== | | ===Configuración de un servidor web=== |
Línea 267: |
Línea 282: |
| </div> | | </div> |
| <div class="slide"> | | <div class="slide"> |
− | ====Ejemplo Confituracion virutalHost | + | ====Ejemplo Confituracion virutalHost==== |
− | [[Archivo:ejemplo_virtual_hols.png|center]]
| + | |
| </div> | | </div> |
| | | |
Línea 278: |
Línea 292: |
| </div> | | </div> |
| <div class="slide"> | | <div class="slide"> |
| + | |
| ====Cliente: varios nombres .. una ip==== | | ====Cliente: varios nombres .. una ip==== |
| [[Archivo:ip_server_cliente.png]] | | [[Archivo:ip_server_cliente.png]] |
Línea 292: |
Línea 307: |
| 3.-Se busca o pregunta a nuestro servidor '''''dns''''' que nos lo resuelva. | | 3.-Se busca o pregunta a nuestro servidor '''''dns''''' que nos lo resuelva. |
| }} | | }} |
| + | {{Plegable|hide|Pasos a realizar| |
| + | ;1º Agregamos en la configuracion de apache los nuevos VirtualHost |
| + | *Creamos los ficheros de configuración en la carpeta correspondiente |
| + | /etc/apache2/sites-available/informatica.conf |
| + | /etc/apache2/sites-available/manuel.conf |
| + | /etc/apache2/sites-available/musica.conf |
| + | *En su contenido, especificamos los valores para DocumentRoot y para ServerName (comenta su significado). |
| + | {{Plegable|hide|Contenido de informatica.conf sin comentarios| |
| <source lang=bash> | | <source lang=bash> |
− | sudo vim /etc/host | + | <VirtualHost *:80> |
| + | ServerName www.informatica.com |
| + | DocumentRoot /var/www/informatica |
| + | </VirtualHost> |
| + | </source> |
| + | }} |
| + | *Rebotamos el servicio (al haber cambiado el fichero de configuración) |
| + | <source lang=bash> |
| + | sudo service apache2 restart |
| + | </source> |
| + | ;2º Creo los recursos en la web |
| + | *Hemos establecido que cuando se acceda a este servidor web con el nombre '''''informatica.com''''' se ha de ir a buscar los recursos a '''''/var/www/informatica'''''. Ahora debemos de crear esa estructura de carpetas, y ubicar ahí algún recurso (página html). |
| + | *Para realizar esta acción, debes de asegurarte de tener premisos de escritura en esta carpeta. |
| + | |
| + | ;3º Modificamos el fichero /etc/hosts para la resolución de direcciones ip, aportando un nombre |
| + | <source lang=bash> |
| + | sudo gedit /etc/host |
| </source> | | </source> |
| </div> | | </div> |
| + | *Agregamos las ip de los nombres, observa que la ip que pongo es la de loopback (127.0.0.1), o bien la ip que tenga asignada mi equipo |
| + | <source lang=bash> |
| + | 127.0.0.1 manuel.com |
| + | 127.0.0.1 informatica.com |
| + | #127.0.0.1 musica.com |
| + | 172.30.1.120 musica.com |
| + | </source> |
| + | {{MRM_Pregunta| |
| + | ;¿Cómo puedo comprobar que está bien esta configuracioń de ip-nombres? |
| + | }} |
| + | }} |
| + | |
| + | |
| + | |
| + | }} |
| | | |
| <div class="slide"> | | <div class="slide"> |
- Directivas de configuración
- El servidio (como todos el linux), se configura con directivas de configuración
- Son variables que tengo en un fichero y especifican el comportamiento de este programa
- Por ejemplo cuál es el directorio dónde apache va a buscar los recursos solicitados
Modificar el document root
- Edita el fichero de configuración 000-default.conf ubicado en /etc/apache2/sites-enabled con privilegios de root
sudo gedit /etc/apache2/sites-enabled/000-default.conf
- Modifica la direciva DocumentRoot
sudo service apache2 restart
|
- Listado de los ficheros log para conocer incidencias y notificiones
- No es objetivo profundizar en estos ficheros, pero sí es importante conocer
- apache.conf
fichero de configuración general.
en él se incorporar muchos otros ficheros de configuración.
Servidor Web
- Proceso de comunición tcp/ip
- Es importante entender el concepto de protocolo.
Protocolo
- Un programa que implementa una serie de reglas y normas para que dos partes diferentes se puedan comunicar.
|
- Un protocolo es un programa, pero solo el programa de nivel de aplicación vamos a gestinar (instalar, eliminar, configurar), el resto de software (protocolos de otros niveles), son parte del kernel del sistema operativo, a los que no tenemos acceso de gestionar, pero sí, a veces, de configurar, como estalbecer el número ip' dentro del protocolo ip o protocolo de internet.
- El Servidor
- La imagen anterior, muestra el proceso de comunicación tcp/ip entre dos dispositivos.
- El equipo que recibe la comunicación se conoce como servidor, por el hecho de que están ejecutándose en él diferentes programas servidores.
- Cada programa está escuchando por un puerto, que es quién le identifica, de modo que cuando la tarjeta de red recibe un paquete, datagrama o fragmento (un grupo de bits), si el nivel de red, decide que es él el destinatario, desde el nivel de transporte sabe a qué aplicación entregarlo.
Permisos de ficheros
Parar poder acceder a un fichero necesitamos tener una referencia a él (Tanto para escribir como para leer).
- Temas de permisos de apache
A pesar de que no somos administradores/as debemos tener conocimientos para ciertos temas.
Lo primero debemos tener claro es que cuando php le dice en el script a apache que actúe sobre el sistema de ficheros, es en última instancia el usuario apache quién quiere hacer la acciones
- Lee atentamente el siguiente cuadro y asegúrate de tener claro cada punto, si no, pregunta.
Puntos fundamentales sobre permisos
1.- En linux todo fichero tiene un propietario, y también todo proceso.
- El propietario del proceso es el usuario que lazó dicho proceso.
- Cuando un proceso quiere hacer algo sobre un fichero, el usuario que lanzó el proceso, debe tener permisos sobre el fichero para hacerlo.
- El usuario que lanza apache es www-data
- Para hacer a un usuario propietario de un fichero o a su grupo usamos la sentencia
sudo chown usuario:grupo fichero (-R) }}
(: *-R parámetro opcional que actuaría de forma recursiva.
- En php un directorio es igual que un fichero cuyo contenido son los ficheros y directorios que contiene.)
- Para dar permisos sobre un fichero a un usuario usamos la sentencia
sudo chmod permisos fichero (-R) }}
(:
- permisos' es un número de tres dígitos en octal, ver tabla de abajo.
- fichero al cual le queremos dar permisos, se puede usar * para especificar todos.
- -R parámetro opcional que actuaría de forma recursiva.
)
|
Número
|
Binario
|
Lectura (r)
|
Escritura (w)
|
Ejecución (x)
|
0
|
000
|
|
|
|
1
|
001
|
|
|
|
2
|
010
|
|
|
|
3
|
011
|
|
|
|
4
|
100
|
|
|
|
5
|
101
|
|
|
|
6
|
110
|
|
|
|
7
|
111
|
|
|
|
Por ejemplo:
chmod 766 file.txt # brinda acceso total al dueño
# y lectura y escritura a los demás
chmod 770 file.txt # brinda acceso total al dueño y al grupo
# y elimina todos los permisos a los demás usuarios
chmod 635 file.txt # Permite lectura y escritura al dueño,
# escritura y ejecución al grupo,
# y lectura y ejecución al resto
(: Recuerda que es el usuario apache el que ha de tener los permisos necesarios (leer(r),escribir (w), ejecutar (x))
Configuración de un servidor web
La configuración se basa en un VirtualHost.
VirtualHost
- Forma de configurar en una única máquina (una ip) Apache.
conjunto sitios web (1 o más)
basados en nombres de dominio (cada uno un nombre)
cada dominio su configuración independiente (directivas de apache)
|
- VirtualHost
- Una única ip, varios dominios
- Cada dominio configurado en el Virtualhost
- Cada VirtualHost su propia configuración
- Se configura a través de directivas de apache
- Mejor en fichero independiente en el directorio
- VirtualHost
- sites_enabled vs sites_available
Organización de los ficheros de configuración
- Tener todos los posibles sitios virtuales en el directorio sites-available
- Solo aquellos que quiero que estén activos establezco un enlace simbólico en el directorio sites-enabled
Tip: Solo los ficheros que haya en el directorio sites-enabled estarán activos
|
- VirtualHost
- Para crear un enlace simbólico
ln -s directorio/fichero_fisico directorio/fichero_enlace
- Podemos usar comando de apache
a2ensite <site>
a2dissite <site>
Algunas directivas importantes
- ServerName
Directiva que especifica el directorio base para buscar ficheros
- DocumentRoot
Directiva que especifica el directorio base para buscar ficheros
- DirectoryIndex
Nombre de fichero/s que se entregan por defecto al solicitar recurso
- <Directory ./../..> </Directory>
Para configurar de forma particular algún directorio dentr del sitio web de esta configuración
Ejemplo Confituracion virutalHost
- VirtualHost
- Los valores principales serían
#DocumentRoot Que es la ruta base de nuestro servidor web
#ServerName . Que es el nombre del host donde está nuestro servidor web
Cliente: varios nombres .. una ip
- Especificando varios nombres de host
- Un mismo host (ip), puede ser especificado con diferentes dominios (esto no puede ser al contrario).
- Como no vamos a entrar en configurar bind (DNS), modificaremos el fichero hosts
Debemos recordar que cuando queremos encontrar la ip de un dominio se siguen unos pasos
1.-Primero miramos en el fichero /etc/hosts
a ver si hay una traducción directo.
2.-Se mira en la caché.
3.-Se busca o pregunta a nuestro servidor dns que nos lo resuelva.
|
Pasos a realizar |
---|
- 1º Agregamos en la configuracion de apache los nuevos VirtualHost
- Creamos los ficheros de configuración en la carpeta correspondiente
/etc/apache2/sites-available/informatica.conf
/etc/apache2/sites-available/manuel.conf
/etc/apache2/sites-available/musica.conf
- En su contenido, especificamos los valores para DocumentRoot y para ServerName (comenta su significado).
Contenido de informatica.conf sin comentarios |
---|
<VirtualHost *:80>
ServerName www.informatica.com
DocumentRoot /var/www/informatica
</VirtualHost>
|
- Rebotamos el servicio (al haber cambiado el fichero de configuración)
sudo service apache2 restart
- 2º Creo los recursos en la web
- Hemos establecido que cuando se acceda a este servidor web con el nombre informatica.com se ha de ir a buscar los recursos a /var/www/informatica. Ahora debemos de crear esa estructura de carpetas, y ubicar ahí algún recurso (página html).
- Para realizar esta acción, debes de asegurarte de tener premisos de escritura en esta carpeta.
- 3º Modificamos el fichero /etc/hosts para la resolución de direcciones ip, aportando un nombre
</div>
- Agregamos las ip de los nombres, observa que la ip que pongo es la de loopback (127.0.0.1), o bien la ip que tenga asignada mi equipo
127.0.0.1 manuel.com
127.0.0.1 informatica.com
#127.0.0.1 musica.com
172.30.1.120 musica.com
Pregunta
- ¿Cómo puedo comprobar que está bien esta configuracioń de ip-nombres?
|
|
</table>
}}
Crea 3 sitios web
- Crea 3 sitios web con los siguiente nombres
#www.informatica.dwes.es
#www.tuNombre.es
#www.musica.es
- Que cada uno de ellos vaya a buscar su fichero index.html a las carpetas respectivas
#/var/www/informatica
#/var/www/tuNombre
#/var/www/musica
|
(: Mira la sección de ejercicios donde verás una posible solución)
- Arrancar y parar el servido
- para parar y arrancar el servicio
sudo /etc/init.d/apache2 stop|start
- Siempre que modifiquemos la configuración, tenemos que rearmar el servicio
- Localizar el fichero de errores
- Muy importante, el servidor generará errores cuando no pueda procesar algo (incluido php)
Fichero de errores de apache
- /var/log/apache2/error.log
|
- Usa el comando tail -f para tenerlo abierto en caliente con las últimas líneas añadidas
tail -f /var/log/apache2/error.log
|
- Si quieres puedes crear un alias para no tener que escribir el comando completo
- Se recomienda, ya que con bastante frecuencia consultaremos los errores cuando no funcionen la aplicación
Crea un alias
- Edita el fichero oculto .basrc
- Añade el la última línea el comando
alias e="tail -f /var/log/apahce2/error.log"
- Vuelve a cargar el fichero (esto no hará falta cuando vuelvas a cargar el sistema)
- Ahora si escribes el alias e, se ejecutará el comando asignado
|