Archivos de la categoría ‘Apache’

INSTALANDO DDCLIENT

Noviembre 30, 2007

Hoy en la madrugada no continué escribiendo este artículo porque estaba cansadísimo, ahora continuaré.

Ya tenemos nuestro servidor apache, pero de nada nos servirá si cada vez que la empresa que nos provee internet (ISP) nos cambia la IP. Para ello la comunidad Libre ha desarollado muchas herramientas para “liberarnos” de estas situaciones.

ddclient hace lo siguiente:

Nos conecta a www.dyndns.com automáticamente cada cierto tiempo, cuando detecta que nuestro ISP nos cambió la IP envía la señal a www.dyndns.com y cambia la IP y la relaciona con nuestro nombre de dominio. Para explicarlo mas claro, pondré el ejemplo de nuestros números telefónicos, tu seguramente sabes de memoria el número telefónico de tu mamá tal vez sea 55551278 pero ¿Qué pasaría si alguna empresa chafa como telmex, le cambiara el número cada vez que quisiera?. Bueno pues si eso sucediera tendríamos resuelto el problema con ddclient que sería como un vigilante en el número telefónico de tu mamá y que corre a avisarte cuando el número de tu mamá fue cambiado y te dice el número nuevo es 55555555. Pues esta función es igual en las IP de los servidores con IP dinámica, instalamos ddclient y cuando nuestra IP cambia le dice a www.dyndns.com que cambió la IP y que lo relacione con nuestro nombre de dominio.

Ahora es bueno explicar que es www.dyndns.compara entenderlo mejor, las máquinas y los seres humanos nos comunicamos con lenguajes diferentes, nosotros para hablar el lenguaje de las máquinas sería complicado y las máquinas aún no las hemos desarrollado para que entiendan nuestro lenguaje y hagan las cosas que queramos. Bien cuando nosotros nos conectamos a la red, cada página o servidor de páginas tienen un número para localizarlas este número es IP fija o en su defecto y para los que somos mortales IP dínamica, para conectarse a mi pagina web que tiene IP dinámica es muy difícil porque cambia continuamente, pero si fuera fija (te cobran un dineral al mes por tener IP fija) entonces siempre que pongas el mismo número te llevará a la página de ese servidor.

Tomemos como ejemplo a www.google.com.mx ellos tienen IP fija y esa IP fija es 72.14.205.147 si tu pones este número en la barra de direcciones de tu explorador iceweasel, firefox, netscape mozilla (por nombrar los mejores) te darás cuenta que abre la pagina de google aquí surge la pregunta ¿Qué es más fácil de recordar 72.14.205.147 ó www.google.com.mx? bien pues el primero es un lenguaje más fácil para la máquina pero no para el hombre y la segunda es más fácil para el hombre que para la máquina. Pues para eso sirve www.dyndns.com que nos brinda un nombre facil de recordar para los humanos, en mi caso yo decidí crear un nombre de dominio llamado angelclasico.ath.cx para relacionarlo con mi IP 148.125.1.25 que me da la empresa con la que contraté internet. Etonces la gente no va a tener que recordar mi IP sino angelclasicop.ath.cx y ese nunca va a cambiar.

Bien explicado lo anterior espero que le hayan entendido y sino fue así, pueden investigar más en internet, por ahora procederemos a instalar ddclient en el servidor, con el cual me conectaré remotamente con el programa que ya instalamos ssh y que ya explique anteriormente.

# sudo apt-get install ddclient

Entonces me sale un menu donde me pide seleccionar un servicio y como yo tengo cuenta en www.dyndns.com pues elegí www.dyndns.com Posteriormente me pregunta los dominios que tengo registrados y que quiero relacionar con ddclient para que los actualice.

DynDNS fully qualified domain names: angelclasico.ath.cx

y si tuviera varios dominios virtuales, entonces pongo separados por comas y sin espacios los nombres de dominio

angelclasico.ath.cx,otrodominio.ath.cx,otrositio.ath.cx

Posteriormente me pregunta

Username for dynamic DNS service: escribir-mi-nombre-de-usuario-de-dyndns

Password for dynamic DNS service: escribir-mi-password-de-usuario-de-dyndns

Interface used for dynamic DNS service: eth0 ¿Recuerdas que cuando instalaste el sistema base te preguntó que interfaz? Pues esa interfaz es la que vas a poner aqu, aunque normalmente siempre es la interfaz eth0 la que se pone.

En caso de que al instalar mediante apt-get install ddclient no les aparezca la pantalla que les pregunta todo esto, es simple configurar con nano.

# sudo nano /etc/ddclient.conf

daemon=300
syslog=yes
mail=angelclasico@gmail.com
mail-failure=angelclasico@gmail.com
pid=/var/run/ddclient.pid
protocol=dyndns2
use=if, if=eth0
server=members.dyndns.org
protocol=dyndns2
login=
escribir-mi-nombre-de-usuario-de-dyndns

password=’
escribir-mi-password-de-usuario-de-dyndns-entre-comillas

angelclasico.ath.cx,otrodominio.ath.cx,otrositio.ath.cx

DOMINIOS VIRTUALES EN APACHE2

Noviembre 30, 2007

Después de tanto buscar y buscar, por fin pude configurar mis dominios virtuales, cuando ya se sabe hacer esto resulta muy fácil, pero cuando ya pasó mucho tiempo y no ves resultados, te desesperas un poco.

Aquí está la manera de como tener varios dominios virtuales, en lenguaje mortal como tener varios servidores con una sola IP ej. www.misitio1.com www.misitio2.com www.misitio3.com etc en una misma máquina.

Debemos tener en cuenta que es muy importante la carpeta /etc/apache2/sites-available ahí se fundamenta toda la estructura de los dominios virtuales, ahi existe un archivo llamado default que es un ejemplo de un dominio virtual, yo no etendí que ese era un dominio virtual, tampoco le entendí al código o parámetros pero con un poco mas de práctica creo que lo puedo dominar sin problemas. Pues este archivo, es en pocas palabras un dominio virtual que representaría a algo así como www.default.com y ahora nosotros crearemos nuestros dominios virtuales.

En mi caso decidí hacer mi dominio angelclasico y mediante la consola de comandos hice mi dominio virtual angelclasico

# sudo nano /etc/apache2/sites-available/angelclasico

Cuando abrió nano, me hice la vida lo mas sencilla que pude y establecí los parámetros muy sencillos comparados con el dominio virtual default que se encuentra como lo dice su nombre por default.
NameVirtualHost *:80
<VirtualHost *:80>
ServerAdmin angelclasico@gmail.com
ServerName http://angelclasico.ath.cx
DocumentRoot /home/angelclasico
ErrorLog /home/uoc_error_log
TransferLog /home/uoc_access_log
</VirtualHost>

Con CTRL+O (vocal) guarde los cambios y listo, solo me faltaba darlo de alta para que apache2 lo reconociera como dominio virtual y cuando alguien escribiera http://angelclasico.ath.cx en su explorador, no se fuera al dominio default, en este caso se dirigiría buscando por primera instancia en la carpeta  /home/angelclasico

Para darlo de alta tuve que cambiarme de directorio a:

# cd /etc/apache2/sites-available/angelclasico

# sudo a2ensite angelclasico

# sudo /etc/init.d/apache2 force-reload

Para entender el comando a2 significa apache2, en significa enabled (activado) y por último site significa sitio. Ahora con esta configuración cuando escriba la dirección http://angelclasico.ath.cx en algún navegador web, me dirigirá hacia el sitio de angelclasico. Claro que para que probar que funcionara tuve que darme de alta en www.dyndns.com para enlazar angelclasico.ath.cx con la IP dinámica que tengo. y al mismo tiempo en la carpeta /home/angelclasico/ puse un archivo llamado index.html para que me mostrara que funciona mi dominio virtual sin problema.

La linea que contiene las palabras force-reloaded es para forzar a apache2 a que vuelva como a reiniciarse, en este caso sería como recargarse con los nuevos parametros.

Si quiero agregar otro dominio virtual, simplemente repito los pasos que hice para angelclasico y activo mi sitio. También es importante mencionar que el dominio virtual default no me sirve y entonces tengo que desactivarlo y eso lo logro con el siguiente comando.

# sudo a2dissite default

Y automáticamente queda desabilitado a2 significa apache2, dis sinifica disabled y site significa sitio.

Ya es muy tarde, estoy cansado y tengo que dormir, pero adelantaré el siguiente paso porque es importante, muy importante ya que todos nosotros los mortales, tenemos IP Dinámica y para dirigir nuestro nombre de dominio a una dirección numérica que cambia, tendremos que darnos de alta en algún servidor gratuito de DNS como www.dyndns.com para que cuando nuestra IP cambie, pues www.dyndns.com actualice nuestra IP y la asocie con nuestro nombre de dominio. disculpen por la redundancia, pero escribo esto porque hay gente que no entiende muchos tecnicismos y tengo que ser como un DNS que traduce los tecnicismos a palabras mas sencillas.

INSTALANDO SSH PARA TENER ACCESO REMOTO

Noviembre 29, 2007

Como se habrán dado cuenta, ya intalamos nuestro servidor apache con soporte para MySQL PHP, MyWEBADMIN principalmente, poco a poco iremos integrando los paquetes que vayamos necesitanto.

Ahora es momento de instalar ssh para tener acceso remoto desde cualquier parte del mundo. Para iniciar la instalación comenzaremos en la línea de comandos.

$ sudo ap-get install ssh

Es importante que en tu maquina-servidor salgas con el comando exit, esto es para que evites husmeadores. Ahora que ya está instalado, podremos accesar a este servidor desde cualquier parte del mundo donde haya una conexión a internet. En mi caso como este servidor se encuentra a mi lado y tiene una IP interna, lo que haré será teclear el siguiente comando.

# ssh 192.168.1.101

Les pedirá el usuario, la contraseña y entonces es como si estuvieran físicamente usando esa maquina, cualquier comando que ustedes apliquen en la consola, afectará directamente a la que se están conectando.

Si les aparece algún mensaje como el siguiente

@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
Someone could be eavesdropping on you right now (man-in-the-middle attack)!
It is also possible that the RSA host key has just been changed.
The fingerprint for the RSA key sent by the remote host is
7d:36:2c:ce:f4:e6:b0:ca:d9:2d:76:b6:04:23:8r:81.
Please contact your system administrator.
Add correct host key in /home/mi-usuario/.ssh/known_hosts to get rid of this message.
Offending key in /home/mi-usuario/.ssh/known_hosts:2
RSA host key for 192.168.1.01 has changed and you have requested strict checking.
Host key verification failed.

Es porque algo anda mal, alguien se conecto a su máquina y podría estar espiando, solo es modificar unas líneas en unos archivos y listo, el problema podría quedar solucionado y eso se hace así.

La línea de arriba que dice  known_hosts:2 nos está menciona que del archivo /home/mi-usuario/.ssh/known_hosts debemos eliminar la línea 2 y con eso se corrige el la conexión ssh.

Instalando un servidor Apache en debian.

Noviembre 28, 2007

AVISO IMPORTANTE: Toda instalación es configurable después de la misma, así que no tengan temor de lo que vaya a suceder.

El primer paso que hago es descargar el disco mínimo para instalar vía red. Este disco lo descargo de la web de www.debian.org en donde están los isos o imágenes, descargo el disco que se llama netinstall y lo quemo.

Inserto el disco en el CDROM de la máquina donde instalaré el servidor apache, es importante decir que este será un servidor dedicado y que todos los datos se borrarán.

Arranco la máquina y le digo que me bootee desde el CDROM, para los que no saben esto significa que buscará algun sistema tomando buscando por inicio en el CDROM. Si no saben como hacerlo, busquen en internet bootear desde CDROM.

Iniciamos seleccionando el Lenguaje en que instalaremos, yo escojo Español porque ese es el idioma que hablo (que siendo correctos se debería decir castizo) y doy ENTER.

Ahora selecciono mi país que en mi caso es México y doy ENTER.

Escojo una localización en mi caso aparecen

es_MX.UTF-8

es_MX

Decido escoger la que sea, no importa y después me dice que que idiomas quiero elegir para darme soporte, en mi caso no escojo ninguno y continuo.

Ahora me pide establecer la distribución de mi teclado y decido por Español.

Me empieza a detectar la red y muestra que tengo dos tarjetas de red ethernet, entonces elijo siempre la opción eth0

Posteriormente comienza a configurar la red via DHCP y siempre me dice que produjo un fallo al ralizar la configuracion automatica no le hago caso y doy continuar y puedo dejarlo para después usando la opción No configurar la red en este momento pero es mejor configurarla manualmente, si desean configurarla tendrán que hacer lo siguiente.

Me aparece un menú donde aparece la opción Configurar la red manualmente y me pide la Dirección IP esto significa que esa será la IP interna que usará de manera fija dentro de una red. Lo normal es siempre cambiar el último número (creo que le llaman octeto si me equivo lo siento) y lo mejor es que le llamen como lo establezco 192.168.1.100

La siguiente opción aparece sola Mascara de Red por defecto deberá ser 255.255.255.0 en caso de que no aparezca esta, entonces pónganla.

Viene otra opción que se llama Pasarela también el parametro aparece solo, aquí si es importante saber esta opción, ya que esto se refiere a la IP del router de nuestro Proveedor de Internet (ISP) Infinitum usa la pasarela 192.168.1.54 si no mal recuerdo y la gran mayoría utiliza el 192.168.1.1 así que deben investigarlo poniendo en su navegador alguna de estas dos y si aparece una pagina web de su ISP con información de su router entonces pongan esta dirección. En mi caso la Pasarela es 192.168.1.1 lo mas común.

Viene otra opción Direcciones de Servidores de Nombres 192.168.1.1

Nombre de la Máquina Siempre viene por defecto debian pero sean ingeniosos y pongale un nombre atractivo, yo le puse FPSOR-LDKS.

Nombre de Dominio Esta opción aparece nuevamente pero no es la misma de la configuración DHCP por lo tanto esta se queda en blanco.

Escoja una Réplica Debian Esto es para descargar el soft que necesitemos, yo antes usaba el de México (nisamox) pero después me gusto mucho la réplica de Francia y decidí hacerlo así, ustedes decidan.

Posteriormente les pide que seleccionen la réplica de algunos de los servidores que hay en el país que escogieron, yo me quedé con Francia y escogí ftp.fr.debian.org porque es la que mas me resuelto los problemas cuando necesito resolverlos.

Información de proxy HTTP lo dejo en blanco, ¿Porqué? porque así lo quise y a continuación comienza a trabajar la máquina, por eso pongo Trabaja.

Trabaja Comprobando la réplica

Escoger la replica Debian prefiero escoger la opción stable que ya fue probada.

Trabaja Cargando Componentes adicionales

Si en algún momento les aparece Réplica Debian no Existente se debe a que no fue configurado correctamente DHCP y la opción Direcciones de Servidores de nombres la pudieron dejar con algún parámetro no correcto, siendo que debe dejarse como lo establecí anteriormente. De la misma manera si se queda trabada la máquina en Cargando Componentes Adicionales, solamente reinicien la instalación y repitan los pasos descritos previamente.

En caso de que no se pueda conectar la máquina a ninguna réplica, no se preocupen después lo cofiguraremos correctamente.

Particionado de Discos Utilizo la opcion Guiado – utilizar todo el disco, en este paso se borrará toda la información contenida en su disco.

Selecciono el disco que deseo particionar y selecciono la opción Guiado – Utilizar todo el disco porque es la que mas me conviene ¿Porqué? Porque así lo decidí, así que continuemos porque esto no nos interesa tanto, para esta saber mas de esto pueden buscar mas información en otra web del porque.

Todos los ficheros en una partición (Recomendado para novatos). Así que selecciono esta opción y acepto Finalizar el particionado y escribir los cambios en el disco.

¿Desea escribir los cambios en los discos? Le doy en la opción Si y entonces comienza el borrado de los datos contenidos en el Disco Duro.

Configurar la zona horaria Pues como escogí México y vivo en el distrito Federal, entonces selecciono la que mas me conviene.

Clave del superusuario En esta opción elijo una clave un poco larga y sin sentido para evitar intrusos y que mi clave sea más difícil de descifrar, yo decidí escogerla con letras, números y caracteres especiales, dando un total de 16 caracteres y me pide reingresar la clave para comprobar que la escribí igual que la primera.

Nombre completo para el nuevo usuario Entonces escribo mi nombre separado de un espacio Juan Perez sin acentos.

Nombre del usuario para la cuenta Se me antojo ponerle juanitobodoque, aquí si que no están permitidos los espacios.

Establecer contraseña Me piden que escriba la contraseña de mi usuario juanitobodoque y confirmarla para que no me equivocara.

Instalando el sistema base En este momento comienza la instalación del sistema. Se puede tardar un poco, pero dejen trabajar su maquinita.

Como estamos instalando nuestro sistema por red, entonces nuestra instalación puede tardar un poco y dependerá de la velocidad de descarga que tengas contratada con tu ISP. Te recomiendo entonces ir a traer un cafecito, una cervecita o algo para distraerte mientras se descargan todos los programas. Aunque también para hacerme publicidad, podrían ver algunos de mis videos que tengo en youtube y de los cuales les dejo los enlaces para que los miren mientras se instala su sitema base de Debian Linux, les pido que voten para que pueda darme una idea si les gustaron o no.

http://www.youtube.com/results?search_query=angelclasico&search=Search

Configuración de Popularity-contest Esta opción envía estadísticas a los programadores del mundo GNU y yo decidí activarla en agradecimiento a todo lo que han desarrollado y que el día de hoy me sirve tanto.

Seleccionar e instalar programas Solo instalo el sistema estandar porque quiero dejar lo mas limpio posible mi servidor casero.

instalacion completada Selecciono continuar.

Reinicia el sistema y saco el disco de la charola para que no se vuelva a instalar el sistema

Bien hemos conseguido instalar el sistema base sobre el cual correra nuestro servidor.

Login: juanitobodoque

Pass: ****************

Con esto ya debí haber ingresado al sistema, ahora me convierto en root (administrador) para que pueda instalar todos los programas necesarios.

El primer programa a instalar es sudo escribiendo en la línea de comandos

# apt-get install sudo

Ejecuto la siguiente línea para actualizar la lista de programas, archivos y todo lo nuevo que haya instalado, para que pueda localizarlos con el comando locate.

# updatedb

Ahora localizo el archivo sudoers mediante la línea de comandos

# locate sudoers

Modifico el archivo para darle privilegios al único usuario existente aparte del root.

# nano /etc/sudoers

Agrego la siguiente línea al final del documento que me dará privilegios para modificar muchas cosas sin que tenga que entrar con la cuenta de root, ya que entrar con el root a realizar tareas cuando estás en internet, pues te trae muchos problemas de seguridad.

juanitobodoque ALL=(ALL) ALL

Presionas la tecla Ctrl+O (vocal o) para guardar los cambios y luego presionas ENTER, con esto se guardan los cambios y para salir presionas Ctrl+X.

Ya fuera de nano (editor de textos) ejecutas el comando exit, para salir de la cuenta root. Ahora quedas con la cuenta juanitobodoque que ya posee privilegios.

Es hora de comenzar a instalar todo lo necesario para nuestro servidor web casero con pintas profesionales.

$ sudo apt-get install apache2

Y comienza a instalar apache2 que es nuestro servidor web, esto tardará un poco dependiendo la velocidad de transferencia y recepción de tu conexión a internet.

Ahora procederemos a instalar php4 para tener un servidor con todo lo necesario.

$ sudo apt-get install php4

Comienza la instalación de php5

Posteriormente instalaremos nuestro soft base de datos y otras aplicaciones para poder manejarlas de mejor manera.

$ sudo apt-get install mysql-client

$ sudo apt-get install mysql-admin

$ sudo apt-get install mysql-query-browser

$ sudo apt-get install phpmyadmin

Bien pues ya casi está listo nuestro sistema para ser usado, lo que falta es configurar los programas para que funcionen bien, pero eso lo explicaré en otro post porque es muy tarde y tengo que dormir.

Solo para que vean que su servidor apache funciona, en la barra de direcciones de su explorador favorito tecleen la IP que ingresaron al configurar DHCP que en mi caso fue 192.168.1.101 y deberá leerse la frase IT WORKS, que significa que está trabajando.