Académique Documents
Professionnel Documents
Culture Documents
04
Requisitos Previos
Antes de comenzar con esta guía, debe tener una cuenta de usuario independiente que no sea ro
ot, con privilegios de sudo configurados en su servidor. Puede aprender cómo hacerlo completand
o los pasos 1-4 en la configuración inicial del servidor de Ubuntu 16.04.
Podemos instalar Apache facilmente desde el gestor de paquetes de Ubuntu, apt. Un gestor de p
aquetes nos permite instalar con mayor facilidad un software desde un repositorio mantenido por
Ubuntu. Puede aprender más sobre cómo utilizar apt aquí.
Una vez que haya ingresado su contraseña, apt le dirá qué paquetes planea instalar y cuánto esp
acio adicional ocuparán en su disco. Ingrese Y y presione Enter para continuar, y la instalación co
ntinuará.
Nota: Si no conoce su dirección IP del servidor, vaya a la sección sobre cómo encontrar la direcci
ón IP de su servidor para encontrarla.
/etc/apache2/apache2.conf
...
ServerName dominio_del_servidor_o_IP
Guarde y cierre el archivo cuando termine.
Output
Syntax OK
Reinicie Apache para implementar los cambios:
Ahora, asumiendo que ha seguido las instrucciones iniciales de configuración del servidor para ha
bilitar el firewall UFW, asegúrese de que el firewall permita el tráfico HTTP y HTTPS. Puede aseg
urarse de que UFW tiene un perfil de aplicación para Apache así:
Ports:
80,443/tcp
Permitir el tráfico entrante para ese perfil:
http://la_ip_de_su_servidor
Verá la página web predeterminada de Apache y Ubuntu 16.04, que está disponible para fines inf
ormativos y de prueba. Debe ser algo como esto:
Si usted ve esta página, entonces su servidor web está correctamente instalado y accesible a trav
és del firewall.
Desde la línea de comando, puede encontrar esto de varias formas, primero puede utilizar la herr
amienta iproute2 para obtener su dirección escribiendo esto:
ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'
Esto regresará 1 o 2 líneas. Ambas son correctas, pero el equipo sólo puede ser capaz de usar u
na de ellas, así que es libre de probar con cada una de ellas.
Un método alternativo es utilizar la utilidad curl para ponerse en contacto con una parte externa q
ue le diga cómo se ve su servidor. Puede hacer esto preguntando a un servidor específico cuál es
su dirección IP:
Una vez más, podemos usar apt para adquirir e instalar nuestro software. Esta vez, también vamo
s a instalar otros paquetes "auxiliares" que permitirán a nuestros componentes comunicarse unos
con otros:
Una vez más, se le mostrará una lista de los paquetes que se van a instalar, junto con la cantidad
de espacio en disco que ocupará. Introduzca Y para continuar.
Durante la instalación, el servidor le pedirá que seleccione y confirme una contraseña para el usu
ario "root" de MySQL. Esta es una cuenta administrativa en MySQL que ha aumentado privilegios.
Piense en ello como algo similar a la cuenta de root para el propio servidor (la que está configuran
do ahora es una cuenta específica de MySQL). Asegúrese de que sea una contraseña segura, úni
ca, y no lo deje en blanco.
Cuando la instalación se haya completado, ejecutaremos un script simple de seguridad que nos p
ermite eliminar algunas configuraciones peligrosas y bloquear un poco el acceso a nuestro sistem
a de base de datos. Inicie el script interactivo ejecutando:
sudo mysql_secure_installation
Le pedirá que introduzca la contraseña que estableció para la cuenta root de MySQL. A continuac
ión, le preguntará si desea configurar el VALIDATE PASSWORD PLUGIN (Plugin de Validación d
e Contraseñas).
Advertencia: La activación de esta función es algo así como una cuestión de criterio. Si se habilita
, las contraseñas que no coinciden con los criterios especificados serán rechazadas por MySQL c
on un error. Esto causará problemas si se utiliza una contraseña débil en conjunción con el softwa
re que configura automáticamente las credenciales de usuario de MySQL, como los paquetes de
Ubuntu para phpMyAdmin. Es seguro dejar la validación desactivado, pero siempre se debe utiliz
ar contraseñas únicas y fuertes para las credenciales de base de datos.
Ingrese y para sí, o cualquier otra cosa para continuar sin habilitar.
En este punto, el sistema de base de datos ya está configurado y podemos seguir adelante.
Una vez más podemos aprovechar el sistema apt para instalar nuestros componentes. Vamos a i
ncluir algunos paquetes de ayuda, así, por lo que el código PHP se puede ejecutar en el servidor
Apache y hablar con nuestra base de datos MySQL:
En la mayoría de los casos, vamos a querer modificar la forma en que Apache sirve archivos cuan
do se solicita un directorio. Actualmente, si un usuario solicita un directorio del servidor, Apache b
uscará primero un archivo llamado index.html. Nosotros queremos decirle a nuestro servidor web
que elija los archivos PHP de preferencia, por lo que vamos a hacer Apache busque un archivo in
dex.php primero.
Para ello, escriba éste comando para abrir el archivo dir.conf en un editor de texto con privilegios
de root:
/etc/apache2/mods-enabled/dir.conf
<IfModule mod_dir.c>
DirectoryIndex index.php index.html index.cgi index.pl index.xhtml index.htm
</IfModule>
Cuando haya terminado, guarde y cierre el archivo presionando "CTRL-X". Va a tener que confirm
ar el guardado ingresando "Y" y luego pulsando "Enter" para confirmar la ubicación de almacena
miento de archivos.
Después de esto, tenemos que reiniciar el servidor web Apache para que nuestros cambios sean
reconocidos. Puede hacerlo hacerlo ejecutando esto:
Para mejorar la funcionalidad de PHP, podemos instalar opcionalmente algunos módulos adiciona
les.
Para ver las opciones disponibles para los módulos de PHP y bibliotecas, se puede canalizar los r
esultados de la búsqueda apt-cache dentro de less, un localizador que le permite desplazarse a tr
avés de la salida de otros comandos:
Los resultados son todos los componentes opcionales que se pueden instalar. Se le dará una bre
ve descripción de cada uno:
Por ejemplo, para averiguar lo que hace el módulo php-cli, podríamos escribir esto:
Output
…
Description-en: command-line interpreter for the PHP scripting language (default)
This package provides the /usr/bin/php command interpreter, useful for
testing PHP scripts from a shell or performing general shell scripting tasks.
.
PHP (recursive acronym for PHP: Hypertext Preprocessor) is a widely-used
open source general-purpose scripting language that is especially suited
for web development and can be embedded into HTML.
.
This package is a dependency package, which depends on Debian's default
PHP version (currently 7.0).
…
Si después de investigar, decide que le gustaría instalar un paquete, puede hacerlo utilizando el c
omando apt-get install como lo hemos venido haciendo para nuestro otro software.
Vamos a llamar a este script info.php. Para que Apache pueda buscar el archivo y lo trabaje corre
ctamente, se debe guardar en un directorio muy específico, al cual se le conoce como "raíz".
info.php
<?php
phpinfo();
?>
Cuando haya terminado, guarde y cierre el archivo.
Ahora podemos probar si nuestro servidor web puede visualizar correctamente el contenido gener
ado por un script PHP. Para probar esto, sólo tenemos que visitar esta página en nuestro navega
dor web. De nuevo necesitará la dirección IP pública del servidor.
http://dirección_IP_del_servidor/info.php
La página que verá debe ser algo como esto:
PHP info por defecto en Ubuntu 16.04
Esta página básicamente le da información sobre el servidor desde la perspectiva de PHP. Es útil
para la depuración y para asegurarse de que los ajustes se están aplicando correctamente.
Es posible que desee eliminar este archivo después de esta prueba, ya que en realidad podría da
r información sobre el servidor a los usuarios no autorizados. Para ello, puede escribir lo siguiente
:
sudo rm /var/www/html/info.php
Siempre se puede volver a crear esta página si necesita acceder a la información nuevamente..
Nota: Actualizaremos los enlaces a medida que se actualice la información a la versión 16.04.