Tu máquina de desarrollo. Instalando LAMP

Días atrás, os explicaba como instalar un servidor web en vuestra maquina de desarrollo bajo windows. Como poco a poco Linux penetra en nuestro mundo, hoy os comento como instalar un servidor web en vuestra maquina Linux: LAMP.

Primero de todo la necesidad. Si queréis empezar a dar pasos en el desarrollo web, necesitareis un servidor para poder ir probando. Si solo utilizáis HTML , CSS y JS, podéis ver vuestras paginas recién hechas con un simple explorador, pero. si estáis adentrándoos en los desarrollos webs dinámicos, que es lo mas normal en estos días, necesitáis un servidor, un lenguaje que interprete vuestros deseos y una base de datos.

En este articulo, vamos a presentar la instalación de LAMP:

Como indica el acrónimo, de trata de un conjunto de programas :el servidor web Apache,  la base de datos MySQL, y el interprete de PHP. Todo estos componentes que existen en la mayoría de distribuciones Linux, nos permiten dispones de una maquina para probar nuestros desarrollos y su instalación, veremos que es muy sencilla.

Instalando Apache

Para instalar el servidor web Apache nos basta con teclear la orden correspondiente, siempre como usuario administrador

En Centos/Red Hat/…

:# yum install httpd

En Debian/Ubuntu/….

:# sudo aptitude install apache2

Lo siguiente es ir contestando a las preguntas que pueda hacer el proceso de instalación, y al final podéis recibir algún mensaje de error como que Apache no puede determinar el nombre de dominio, o errores de permisos, que iremos corrigiendo a continuación.

Instalacion_ApacheA pesar de todo, apache esta instalado y funcionando, si estais con una maquina Centos, debereis arrancarlo con:

sudo service start httpd

y si quieres que tu servidor web Apache arranque cada vez que tu maquina se inicie,

sudo chkconfig httpd on

. En otros entornos, el arranque al inicio lo realiza automaticamente.

Si ahora abrís un explorador web y  tecleais “localhost” o 127.0.0.1 veréis aparecer la pagina por defecto de Apache, y si la leeis, ya os dice de donde sacara la información normalmente de “/var/www/html” …pero luego volveremos. Si esa maquina en donde estáis instalando, esta en la red, también podéis acceder desde cualquier otra de vuestra red tecleando únicamente la dirección IP que le corresponda, y que la podéis averiguar con:

:# ifconfig eth0 | grep inet | awk '{ print $2 }'

o

ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'

que te indicaran la dirección IP asignada a tu tarjeta.

Si estas detrás de un router, y deseas conocer tu dirección en Internet, lo podrías hacer con:

curl http://icanhazip.com

Aunque para que tu maquina se pudiera ver desde internet, deberías redirigir el trafico entrante por el puerto 80 y/o 443 a tu dirección IP interna,….pero no seas impaciente, porque todavía queda mucho por hacer.

 Instalando MySql (Ubuntu/Debian/…)

Para instalar nuestra base de datos, deberemos lanzar desde terminal:

sudo apt-get install mysql-server libapache2-mod-auth-mysql php5-mysql

En donde indicamos que deseamos instalar ademas del motor de la BD, las librerías para apache y php5.

Durante la instalación, nos solicitara la contraseña del usuario “root” en MySQL, y que será el que tendrá el control sobre la instalación, por lo que la contraseña debería ser fuerte.

2014-09-28_13h11_27Y como siempre, su repetición para asegurarnos que la hemos escrito bien

2014-09-28_13h13_19Cuando haya finalizado la instalación, podemos activarla con:

sudo mysql_install_db

Que nos dará distintos mensajes acerca de la instalación, y de como gestionarla.

Nos queda por asegurar la instalación, que lo haremos con:

sudo /usr/bin/mysql_secure_installation

 El sistema nos hará una serie de preguntas, os adjunto la imagen con mis respuestas, de cualquier forma, todo esto lo podremos cambiar en cualquier momento en “/etc/mysql/my.cnf” que es el fichero de configuración de mysql.

mysql_seguridad

Instalando MariaDB (Centos/Red Hat/….)

 Mientras preparaba el articulo, me encontré un comentario acerca de instalar la base de datos MariaDB, en vez de MySQL, cosa que parece que se esta poniendo de moda, debido a la preocupación creciente que existe desde que Oracle compró a Sun en 2012, y paso a controlar MySQL, y como esto no es mas que un curso, en donde debemos aprender todos, me he decidido a instalar, en la version de Centos, MariaDb

 De forma, que siguiendo las instrucciones facilitadas en la propia pagina de mariadb, lo que vamos a hacer es crear ya un repositorio, y para eso, en nuestra terminal tecleamos:

# nano /etc/yum.repos.d/MariaDB.repo

y dentro del fichero introducimos para Centos 6 de 64 bits:

[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/10.0/centos6-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1

y lo guardamos, a continuación ya podemos proceder a la instalación con:

sudo yum install MariaDB-server MariaDB-client

Cuando finaliza la instalación, podemos escribir:

sudo /etc/init.d/mysql start

Si queremos que nuestra base de datos arranque al inicio, escribimos:

# chkconfig mysql on

y, como se hace con nuestro viejo mysql, aseguramos la instalacion utilizando el script que nos proporcionan, y que repasa los puntos mas debiles que a nosotros se nos olvida

# mysql_secure_installation

La instalación de PHP

Como siguiente paso, independientemente de la base de datos escogida, nos queda por instalar el interprete de PHP, y para ello deberemos escribir en la linea de comandos:

sudo apt-get install php5 libapache2-mod-php5 php5-mcrypt

En donde indicamos que deseamos instalar PHP y algunas librerías que necesitamos.

Cuando finalice el proceso de instalación, y antes de que se nos olvide, como vamos a empezar a escribir paginas php, seria conveniente que nuestro apache utilizara por defecto una pagina index.php en primer lugar. Para ello, abrimos :

sudo nano /etc/apache2/mods-enabled/dir.conf

y veremos esto:2014-09-28_18h00_26

Ahora, debemos mover el index.php del sitio en que se encuentra, a primer lugar, para que sea el primer intento. debería quedar como:

DirectoryIndex index.php index.html index.cgi index.pl index.php index.xhtml index.htm

Podemos cerrar el fichero. Mas tarde reiniciaremos Apache

A partir de este punto, deberíamos determinar que módulos de php necesitamos, para irlos instalando, para ver cuales hay disponibles, solo hace falta que hagáis

apt-cache search php5-

y os saldrá una lista como esta:

php5-common - Common files for packages built from the php5 source
php5-curl - CURL module for php5
php5-dev - Files for PHP5 module development
php5-json - JSON module for php5
php5-readline - Readline module for php5
php5-cgi - Lenguaje de guiones embebidos en HTML para servidores (binario CGI)
php5-cli - intérprete de órdenes para el lenguaje de guión php5
php5-dbg - Símbolos de depuración para PHP5
php5-gd - Módulo GD para php5
php5-gmp - Módulo GMP para php5
php5-ldap - Módulo LDAP para php5
php5-mysql - Módulo MySQL para php5
php5-odbc - Módulo ODBC para php5
php5-pgsql - Módulo PostgreSQL para php5
php5-pspell - Módulo pspell para php5
php5-recode - Módulo recode para php5
php5-snmp - Módulo SNMP para php5
php5-sqlite - Módulo SQLite para php5
php5-tidy - Módulo tidy para php5
php5-xmlrpc - Módulo XML-RPC para php5
php5-xsl - Módulo XSL para php5
libphp5-embed - HTML-embedded scripting language (Embedded SAPI library)
php5-adodb - Extension optimising the ADOdb database abstraction library
php5-apcu - APC User Cache for PHP 5
php5-enchant - Enchant module for php5
php5-fpm - server-side, HTML-embedded scripting language (FPM-CGI binary)
php5-gdcm - Grassroots DICOM PHP5 bindings
php5-gearman - PHP wrapper to libgearman
php5-gnupg - wrapper around the gpgme library
php5-interbase - interbase/firebird module for php5
php5-intl - internationalisation module for php5
php5-lasso - Library for Liberty Alliance and SAML protocols - PHP 5 bindings
php5-librdf - PHP5 language bindings for the Redland RDF library
php5-mapscript - php5-cgi module for MapServer
php5-memcache - memcache extension module for PHP5
php5-memcached - memcached extension module for PHP5, uses libmemcached
php5-midgard2 - Midgard2 Content Repository - PHP5 language bindings and module
php5-mongo - MongoDB database driver
php5-msgpack - PHP extension for interfacing with MessagePack
php5-mysqlnd - MySQL module for php5 (Native Driver)
php5-mysqlnd-ms - MySQL replication and load balancing module for PHP
php5-oauth - OAuth 1.0 consumer and provider extension
php5-pinba - Pinba module for PHP 5
php5-radius - PECL radius module for PHP 5
php5-redis - PHP extension for interfacing with Redis
php5-remctl - PECL module for Kerberos-authenticated command execution
php5-rrd - PHP bindings to rrd tool system
php5-sasl - Cyrus SASL Extension
php5-stomp - Streaming Text Oriented Messaging Protocol (STOMP) client module for PHP 5
php5-svn - PHP Bindings for the Subversion Revision control system
php5-tokyo-tyrant - PHP interface to Tokyo Cabinet's network interface, Tokyo Tyrant
php5-vtkgdcm - Grassroots DICOM VTK PHP bindings
php5-xcache - Fast, stable PHP opcode cacher
php5-xhprof - Hierarchical Profiler for PHP5
php5-exactimage - fast image manipulation library (PHP bindings)
php5-geoip - Módulo GeoIP para php5
php5-imagick - Módulo ImageMagick para php5
php5-imap - Módulo IMAP para php5
php5-mcrypt - Módulo MCrypt para php5
php5-ming - Módulo Ming para php5
php5-ps - módulo ps para PHP 5
php5-sybase - Módulo de servidor Sybase/MS SQL para php5
php5-xdebug - Módulo Xdebug para PHP 5

De cualquier forma, para empezar a trabajar con PHP ya esta todo preparado, de forma que ya instalaremos mas módulos cuando los necesitemos.

  Ahora, para comprobar que todo esta funcionando, escribimos en nuestra consola:

sudo nano /var/www/info.php

o abrimos nuestro editor de texto favorito y en el fichero  “/var/www/info.php” escribimos:

phpinfo();
?>

y lo guardamos, ya solo nos queda abrir nuestro explorador de internet y escribir:

http://localhost/info.php

y si todo ha ido bien, nos aparecerá una pagina con la informacion de instalacion de PHP, ahora ya podemos empezar a programar

 Instalando phpMyAdmin

Sin embargo, cuando llegue el momento de crear bases de datos o trabajar con ellas, nos ira muy bien disponer de este paquete que nos permite gestionarlas via web.

Para instalarlo, deberemos utilizar el repositorio EPEL, por lo que primero de todo lo deberemos configurar

# rpm -ivh http://ftp.jaist.ac.jp/pub/Linux/Fedora/epel/6/i386/epel-release-6-8.noarch.rpm

Con esto añadiremos los datos del repositorio en /etc/yum.repos.d

A continuacion, actualizaremos la base de datos de programas con:

# yum check-update

y ahora a instalar phpMyAdmin

# yum install phpMyAdmin

Cuando finalice, reiniciamos Apache

# service httpd restart

y comprobamos que todo ha ido bien tecleando en un navegador

http://localhost/phpmyadmin

phpmyadmin

Acerca de Miguel Garcia

Programador, Desarrollador web, Formador en distintas areas de informatica y director de equipos multidisciplinares.

Esta entrada fue publicada en Desarrollo Web, Linux y etiquetada , , , , , . Guarda el enlace permanente.

Una respuesta a Tu máquina de desarrollo. Instalando LAMP

  1. Pingback: ExtJS - Presentacion del frameworkRecursos para formacion

Deja un comentario