Documente Academic
Documente Profesional
Documente Cultură
Contenido
INDICE.............................................................................................................................................................2
ÍNDICE DE OBJETOS...................................................................................................................................2
INTRODUCCION............................................................................................................................................2
OBJETIVO DE LA INVESTIGACION...........................................................................................................2
Desarrollo........................................................................................................................................................3
SERVIDOR WEB............................................................................................................................................3
SERVICIOS.....................................................................................................................................................4
PROTOCOLOS DEL SERVIDOR WEB.......................................................................................................6
Servidor Web Local....................................................................................................................................6
Servidores de aplicaciones.......................................................................................................................6
PASOS PARA LA PETICIÓN DE UNA PÁGINA WEB...............................................................................7
FUNCIONAMIENTO DE UN SERVIDOR WEB..........................................................................................7
Arquitectura Modelo Cliente – Servidor...................................................................................................7
APLICACIONES EN EL LADO DEL SERVIDOR.......................................................................................9
Servidores basados en procesos.............................................................................................................9
Servidores basados en hilos.....................................................................................................................9
Servidores basado en sockets no bloqueantes o dirigidos por eventos...........................................10
Servidores implementados en el kernel.................................................................................................10
SERVIDORES MÁS USADOS...................................................................................................................10
Apache.......................................................................................................................................................10
Microsoft IIS...............................................................................................................................................11
Sun Java System Web Server................................................................................................................11
Ngnix..........................................................................................................................................................11
Lighttp.........................................................................................................................................................12
FUNCIONAMIENTO EN LA ACTUALIDAD...............................................................................................12
SERVIDORES WEB MÁS UTILIZADOS...................................................................................................12
OTROS TIPOS DE SERVIDORES............................................................................................................13
CONCLUSIÓN..............................................................................................................................................13
BIBLIOGRAFÍA.............................................................................................................................................14
ÍNDICE DE OBJETOS
Ilustración I: Representación de servidor web...................................................................................4
Ilustración II: Servidor local................................................................................................................9
INTRODUCCION
OBJETIVO DE LA INVESTIGACION
Un servidor web o servidor HTTP es un programa informático que procesa una aplicación
del lado del servidor, realizando conexiones bidireccionales o unidireccionales y síncronas
o asíncronas con el cliente y generando o cediendo una respuesta en cualquier lenguaje
o Aplicación del lado del cliente. El código recibido por el cliente es renderizado por
un navegador web. Para la transmisión de todos estos datos suele utilizarse
algún protocolo. Generalmente se usa el protocolo HTTP para estas comunicaciones,
perteneciente a la capa de aplicación del modelo OSI. El término también se emplea para
referirse al ordenador.
2
Desarrollo
SERVIDOR WEB
Los Servicios Web surgieron ante una necesidad de estandarizar la comunicación entre
distintas plataformas (PC, Mainframe, Mac, etc.) y lenguajes de programación
(PHP, C, Java, etc.). Anteriormente se habían realizado intentos de crear estándares pero
fracasaron o no tuvieron el suficiente éxito, algunos de ellos son DCOM y CORBA, por ser
dependientes de la implementación del vendedor DCOM – Microsoft, y CORBA – ORB (a
pesar que CORBA de múltiples vendedores pueden operar entre si, hay ciertas
limitaciones para aplicaciones de niveles más altos en los cuales se necesite seguridad o
administración de transacciones).
Otro gran problema es que se hacía uso de RPC (Remote Procedure Call) para realizar la
comunicación entre diferentes nodos. Esto, además de presentar ciertos problemas de
seguridad, tiene la desventaja de que su implementación en un ambiente como
es Internet, es casi imposible (muchos Firewalls bloquean este tipo de mensajes, lo que
hace prácticamente imposible a dos computadoras conectadas por Internet comunicarse).
Los Servicios Web surgieron para finalmente poder lograr la tan esperada comunicación
entre diferentes plataformas. En la actualidad muchos sistemas legacy están pasando a
ser servicios web. Es por esto que en 1999 se comenzó a plantear un nuevo estándar, el
cual terminaría utilizando XML, SOAP, WSDL, y UDDI.
A pesar de mucho limitar el uso de los servicios Web al Protocolo http, los servicios Web
no fueron pensados para un protocolo en particular, es decir, nada impidió
utilizar SOAP sobre algún otro protocolo de Internet (SMTP, FTP, etc.). Se utiliza
principalmente HTTP por ser un protocolo ampliamente difundido y que se encuentra
menos restringido por firewalls (generalmente se bloquean puertos como el FTP, pero el
HTTP es muy probable que no esté bloqueado).
En la década de los 90's Internet permitió conectar computadoras en una escala global. En
principio la conexión fue entre PCs y servidores por medio del explorador de Internet. A
comienzos de este siglo es clara la necesidad de permitir a las computadoras conectadas
a Internet comunicarse entre ellas. Desde entonces se va dando forma al nuevo modelo
de computación distribuida llamado servicios Web basados en XML. El objetivo es permitir
comunicarse entre sí a sistemas heterogéneos dentro y fuera de la empresa. Esta
comunicación es independiente del Sistema Operativo, lenguaje o modelo de
programación. Para conseguir esto se desarrollaron estándares. El consorcio de
Internet http://www.w3c.org fue el encargado de crear y mantener estos estándares.
Desde los inicios de Internet, fueron surgiendo diferentes demandas por los usuarios y se
dieron soluciones mediante lenguajes estáticos. A medida que paso el tiempo, las
tecnologías fueron desarrollándose y surgieron nuevos problemas a dar solución. Esto dio
lugar a desarrollar lenguajes de programación para la Web dinámicos, que permitieran
interactuar con los usuarios y utilizaran sistemas de Bases de Datos.
Antes de la adopción del modelo de Servicios Web basados en XML los datos eran “islas”
que se encontraban dentro de las aplicaciones. Era muy difícil y costoso implementar
soluciones para acceder a la información desde afuera de la aplicación. Las aplicaciones
pueden ahora, comunicarse entre sí y con los sistemas de sus socios, proveedores y
clientes gracias a los Servicios Web y XML.
SERVICIOS
Navegador Web: Para establecer conexiones con los servidores Web, y obtener la
información y los servicios que estos prestan, el usuario necesita tener instalado en su
equipo un programa cliente capaz de comunicarse con ellos. Estos programas son los
4
llamados Navegadores Web. Los Navegadores Web, también llamados Visores de
Web o Browsers, son aplicaciones que permiten ver en pantalla texto con formato (con
palabras en negrita, y con distintas fuentes tipográficas, tamaños y colores) y
presentar imágenes en línea. También permiten visualizar secuencias de vídeo y
escuchar ficheros de sonido.
Todo esto depende del uso que se le dé al servidor. Si usted lo desea, puede convertir al
equipo desde el cual se está trabajando en un servidor instalando un programa que
trabaje por la Red y a la que los usuarios de su red ingresen a través de un programa de
servidor web como Apache. Por lo cual podemos llegar a la conclusión de que un servidor
también puede ser un proceso que entrega información o sirve a otro proceso.
Los tipos específicos de servidores que incluyen son los Servidores Web, los Servidores
de archivo, los Servidores del correo, etc. Mientras que sus propósitos varían de unos
servicios a otros, la arquitectura básica seguirá siendo la misma. Una disposición muy
común son los Sistemas multicapa en los que el servidor se descompone en diferentes
programas que pueden ser ejecutados por diferentes computadoras aumentando así el
grado de distribución del sistema.
5
PROTOCOLOS DEL SERVIDOR WEB
Un servidor web es un programa que sirve datos en forma de Páginas Web, hipertextos o
páginas HTML (HyperText Markup Language): textos complejos con enlaces, figuras,
formularios, botones y objetos incrustados como animaciones o reproductores de sonidos.
La comunicación de estos datos entre cliente y servidor se hace por medio un protocolo,
concretamente del protocolo Http. Con esto, un servidor Web se mantiene a la espera de
peticiones HTTP, que son ejecutadas por un cliente HTTP; lo que solemos conocer como
un Navegador Web. A modo de ejemplo: al teclear (http://www.cnice.mec.es) en un
navegador, éste realizará una petición HTTP al servidor que tiene asociada dicha URL.
Tener un servidor Web local debería ser fundamental para todas aquellas personas que no
disponen de un Sitio Web online. ¿Por qué? La respuesta es muy sencilla. El Servidor
local nos va a permitir comprobar que todas las modificaciones que se van a realizar en
nuestro diseños Web, no provoquen algún error que pueda afectar a todos aquellos
usuarios que naveguen por la red. Otro aspecto positivo de un Servidor local, es que no
hará falta tener que subir ficheros al servidor Ftp para hacer nuestras pruebas con lo cual,
la espera se hace más corta.
Protocolo HTTP: Una de las características del Protocolo Http es que no es permanente,
es decir, cada operación HTTP implica una conexión con el servidor, que es liberada al
término de la misma. Por ejemplo, un documento HTML con 10 imágenes son necesarias
11 conexiones distintas (10 imágenes más la página HTML en sí).
Servidores de aplicaciones
6
básico y otro con multitud de extensiones fuertemente integradas al que llaman Servidor
de Aplicaciones.
El Servidor trata cada petición como una operación totalmente independiente del resto. A
partir de la versión 1.1 del Protocolo http, se pueden habilitar conexiones persistentes
(permiten enviar más objetos con un menor número de conexiones.
7
Los servicios son utilizados por programas denominados programas clientes que se
ejecutan en equipos clientes. Por eso se utiliza el término "cliente" (cliente FTP, cliente de
correo electrónico, etc.) cuando un programa que se ha diseñado para ejecutarse en un
equipo cliente, capaz de procesar los datos recibidos de un servidor (en el caso del
cliente FTP se trata de archivos, mientras que para el cliente de correo electrónico se trata
de correo electrónico).
Las aplicaciones en el lado del servidor mayormente suelen ser la mejor opción para
desarrollar aplicaciones Web. La razón es que, al ejecutarse ésta en el servidor y no en la
máquina del cliente, éste último no necesita ninguna capacidad añadida para ejecutar la
aplicación, como sí ocurre en el caso de querer ejecutar aplicaciones que incluyan scripts
con javascript o java. Así pues, cualquier cliente que disponga de un navegador Web
básico puede utilizar este tipo de aplicaciones.
8
APLICACIONES EN EL LADO DEL SERVIDOR
PHP
ASP
Perl
Python
Ruby
Este tipo de diseño hoy en día es mucho más común que el basado en procesos. Los
conceptos básicos respecto al funcionamiento de un servidor basado en procesos son
aplicables también a este modelo. Las principales diferencias de los dos modelos residen
en el propio concepto de hilo. La ventaja es que la creación de un hilo no es tan costosa
como la de un proceso. Varios hilos de un mismo proceso pueden compartir datos entre
ellos, ya que comparten el mismo espacio de memoria.
9
El modelo de servidor basado en hilos hereda muchas de las características de los
Servidores basados en procesos, entre ellas la de la simplicidad en su diseño e
implementación. Por otro lado, el compartir el espacio de memoria implica un riesgo de
seguridad que no tienen los servidores basado en procesos.
Hilo: Es un proceso totalmente aislado es un proceso inerte, es decir, para que un proceso
sea capaz de hacer algo, el proceso debe ser propietario de al menos un hilo (thread). El
hilo es el responsable de ejecutar el Código contenido en el espacio de direcciones del
proceso. De hecho, un proceso puede contener varios hilos y todos ellos ejecutando
código "simultáneamente" en el espacio de direcciones del proceso y compartiendo
recursos comunes.
Al compartir todos los hilos de un proceso la misma zona de memoria, si un hilo toca una
variable, todos los demás hilos del mismo proceso verán el nuevo valor de la variable. Si
no hay hilos ejecutando código en el espacio de direcciones del proceso no hay ninguna
razón para que el proceso continúe existiendo y el sistema destruirá automáticamente el
proceso y su espacio en memoria.
Servidores basado en sockets no bloqueantes o dirigidos por eventos
Socket: No son más que puntos o medios de comunicación entre dos aplicaciones que
permiten que un proceso hable (emita o reciba información) con otro proceso estando los
dos en distintas máquinas.
10
problema que se produzca a nivel de kernel puede ocasionar la caída de todo el sistema
completo.
Apache
Está diseñado para ser un Servidor Web potente y flexible que pueda funcionar en la más
amplia variedad de plataformas y entornos. Las diferentes plataformas y entornos, hacen
que a menudo sean necesarias diferentes características o funcionalidades. Apache se ha
adaptado siempre a una gran variedad de entornos a través de su diseño modular.
Este diseño permite a los administradores de Sitios Web elegir que características van a
ser incluidas en el servidor seleccionando que módulos se van a cargar, ya sea al compilar
o al ejecutar el servidor. Este es el más común y más utilizado en todo el mundo.
Además, es gratuito, y de Código abierto, así que podríamos decir que corre sobre
cualquier plataforma. Apache es una muestra, al igual que el Sistema
Operativo Linux (un Unix desarrollado inicialmente para PC), de que el trabajo voluntario y
cooperativo dentro de Internet es capaz de producir aplicaciones de calidad profesional
difíciles de igualar.
Microsoft IIS
Este tipo de servidor lo llevan sólo los sistemas Windows NT, por tanto añadimos Windows
2000 Professional, Windows 2000 Advanced Server, Windows XP Professional, los cuales
traen las versiones 4.0, 5.0 y 5.1, no obstante en la versión del Windows .NET Server
vendrá la versión 6.0 (dicho sistema está en fase beta y que se puede descargar desde la
misma sede de Microsoft, sólo es necesario registrarse).
En los sistemas Windows XP el IIS no viene instalado por defecto por tanto hemos de
tener el CD con el sistema completo a mano para instalarlo desde:
Sun Java System Web Server
Nginx (se pronuncia “enginx x”) es un Servidor http y proxy inverso gratuito, de Código
abierto y de alto rendimiento, además de ser Servidor proxy para IMAP y POP3.Este
11
servidor está actualmente manejando entre el 1% y el 4% de todos los dominios globales.
A pesar de ser todavía una versión “beta”, Nginx es conocido por su estabilidad, su gran
conjunto de características, una configuración sencilla y por consumir pocos recursos.
Como este servidor no provee actualmente de un adaptador directo para Merb, usted
requerirá utilizar un proxy reverso en Nginx con el fin de direccionar peticiones hacia uno o
varios procesos Merb distintos. Esto puede ejecutarse con cualquier Servidor de
aplicaciones basado en Rack, como Mongrel, Thin, Ebb o Glassfish.
Lighttp
Es un servidor Web para los Sistemas operativos Unix/Linux y Microsoft Windows. Este
servidor también conocido como Lighty, es una alternativa para el Servidor de páginas
Web Apache. Está diseñado para ser seguro, rápido (muy rápido a decir verdad),
compatible con los estandars y flexible a la vez que esta optimizado para entornos en los
cuales la velocidad es crítica.
Su huella de memoria es muy pequeña (en comparacion a otros servidores Web), una
ligera carga en el CPU y su enfoque en velocidad hacen de lighttpd perfecto para
servidores con demasiada carga. Este servidor Web es otro de los más ligeros que hay en
el mercado. Está especialmente pensado para hacer cargas pesadas sin perder balance,
utilizando poca RAM y poca de CPU. Algunas páginas populares que lo usan son
Youtube, Wikipedia y otras que soportan gran tráfico diariamente. También es gratuito y se
distribuye bajo Licencia BSD.
FUNCIONAMIENTO EN LA ACTUALIDAD
El uso de los Servicios Web integra la información que puede ser accedida desde distintos
dispositivos, desde distintas plataformas de Hardware o Software y que puede estar
guardada en distintos formatos. El lenguaje estándar para lograr esta integración es XML.
Además los servidores Web pueden disponer de un intérprete de otros lenguajes de
programación que ejecutan código embebido dentro del código HTML de las páginas que
contiene el sitio antes de enviar el resultado al cliente.
Apache
IIS
12
Tomcat
Cherokee
webfsd
Servidor
Servidor Apache
Servidor DHCP
Servidor Dedicado
Servidores Bind
Servidores FTP
Servidores OpenSSH
Servidores de Correo
13
CONCLUSIÓN
Los servidores en el mundo hoy en día son completamente imprescindibles sin ellos no
podríamos hablar por teléfono, las comunicaciones en un alto porcentaje desaparecerían,
la Telefonía móvil y fija se vería muy afectada, todos los negocios que trabajan en o con
sedes centrales repartiendo sus datos y recursos quedarían completamente paralizadas
(veamos por ejemplo, casas de seguros, bancos, hospitales…), si mañana no
hubiesen Servidores, o bueno, y porque no decirlo, administradores de sistemas, el país
tardaría muy poco en sumirse en el caos, un Sistema informático puede controlar Cámaras
de seguridad, el estado del tráfico, por ejemplo también utilizamos los sistemas
informáticos para hacer las predicciones del tiempo, y alguien puede pensar que se están
citando algunos ejemplos que podría procesar un solo sistema, si, pero ¿cómo recibiría
ese sistema datos de otros sistemas informáticos repartidos por el mundo si no tuviesen el
soporte de otros servidores y redes para comunicarse entre sí? simplemente no podrían.
BIBLIOGRAFÍA
14