Asegurar un servidor Apache en CentOS 6

Es fácil tomar atajos al proteger un servidor, pero correrá el riesgo de perder datos en caso de que un atacante obtenga acceso de root a cualquiera de sus servidores. Incluso para instalaciones simples, debe asegurar su servidor de antemano. La seguridad de los servidores es un tema amplio y varía según el sistema operativo y las aplicaciones que se ejecutan en ellos.

Este tutorial se centra en proteger Apache en CentOS 6. Hay algunos pasos posteriores a la instalación que puede seguir para protegerse de la escalada de privilegios, así como de los ataques con privilegios insuficientes.

Sin más preámbulos, comencemos.

Paso 1: instalación del servidor web

Por supuesto, si no tiene instalado Apache o PHP, debe hacerlo ahora. Ejecute este comando como usuario root o use sudo:

yum install httpd php

Paso 2 - Asegurando tus directorios personales

Ahora que Apache está instalado, sigamos adelante y comencemos a protegerlo. Primero, queremos asegurarnos de que nadie más que el propietario pueda ver los directorios de otros usuarios. Cambiaremos todos los directorios de inicio a 700, para que solo los respectivos propietarios de los directorios de inicio puedan ver sus propios archivos. Ejecute este comando como root o use sudo:

chmod 700 /home
chmod 700 /home/*
chmod 700 /home/*/*

Al usar comodines, cubrimos todos los archivos que actualmente residen en el directorio de inicio.

Paso 3: aplique un parche de seguridad a Apache para la separación de privilegios de usuario

Antes de parchear Apache, primero debemos instalar el repositorio que contiene el paquete con el parche. Ejecute los siguientes comandos como root (o sudo).

yum install epel-release
yum install httpd-itk

Con "apache2-mpm-itk", podemos decir qué usuario PHP debe ejecutar según el host virtual. Agrega una nueva opción de configuración AssignUserId virtualhost-user virtualhost-user-group, que nos permite decirle a Apache / PHP que ejecute el código de usuario bajo una cuenta de usuario específica.

Si está compartiendo este servidor, supongo que ya ha creado un host virtual para Apache anteriormente. En ese caso, puede pasar al paso 4.

Paso 3 - Crea tu primer host virtual

Puede seguir la plantilla a continuación para crear un host virtual en Apache.

NameVirtualHost mytest.website

<VirtualHost mytest.website>

DocumentRoot /home/vhost-user/public_html
ServerName mytest.website
</VirtualHost>

Abra su editor de texto favorito /etc/httpd/conf.d/example-virtualhost.confy luego agregue el contenido de arriba. Aquí está el comando para usar nano:

nano /etc/httpd/conf.d/example-virtualhost.conf

Déjame explicarte la configuración aquí. Cuando especificamos "NameVirtualHost", en realidad le estamos diciendo al servidor web que estamos alojando múltiples dominios en una IP . Ahora, en este ejemplo, utilicé mytest.websitecomo dominio de ejemplo. Cambie eso al suyo o al dominio que elija. DocumentRootes lo que le dice a Apache dónde se encuentra el contenido. ServerNamees una directiva que usamos para decirle a Apache el dominio del sitio web. Y una última etiqueta, </VirtualHost>que le dice a Apache que ese es el final de la configuración del host virtual.

Paso 4: configurar Apache para que se ejecute como otro usuario

Como se mencionó anteriormente, parte de proteger su servidor incluye ejecutar Apache / PHP como un usuario separado para cada host virtual. Es simple decirle a Apache que haga esto después de aplicar el parche; todo lo que necesita hacer es agregar:

AssignUserId vhost-user vhost-user-group

... a su configuración. Así es como se vería el host virtual de ejemplo después de agregar esta opción:

NameVirtualHost mytest.website

<VirtualHost mytest.website>

DocumentRoot /home/vhost-user/public_html
ServerName mytest.website
AssignUserId vhost-user vhost-user-group

</VirtualHost>

La magia está en la línea que comienza con AssignUserId. Con esta opción, le estamos diciendo a Apache / PHP que se ejecute como el siguiente usuario / grupo.

Paso 5 - Ocultar la versión de Apache

Este paso es bastante simple; simplemente abra el archivo de configuración de Apache ejecutando el siguiente comando como usuario root:

nano /etc/httpd/conf/httpd.conf

Busque "ServerTokens" y cambie la opción después a "ProductOnly". Esto le dice a Apache que solo revele que es "Apache", en lugar de "Apache / 2.2" o algo similar.

Paso 6: reiniciar Apache para aplicar los cambios

Ahora que hemos asegurado el servidor, debemos reiniciar el servidor Apache. Haga esto ejecutando el siguiente comando como root o con sudo:

service httpd restart

Conclusión

Estos son solo algunos pasos que puede seguir para proteger su servidor. Una vez más, incluso si es alguien en quien confía que aloja un sitio web en su servidor, debe planear protegerlo. En los escenarios anteriores, incluso si una cuenta de usuario se ve comprometida, el atacante no habrá obtenido acceso a todo el servidor.

Dejar un comentario

ZPanel y Sentora en CentOS 6 x64

ZPanel y Sentora en CentOS 6 x64

ZPanel, un panel de control de alojamiento web popular, se bifurcó en 2014 a un nuevo proyecto llamado Sentora. Aprende a instalar Sentora en tu servidor con este tutorial.

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Cómo instalar Vtiger CRM Open Source Edition en CentOS 7

Aprende cómo instalar Vtiger CRM, una aplicación de gestión de relaciones con el cliente, en CentOS 7 para aumentar tus ventas y mejorar el servicio al cliente.

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Cómo instalar el servidor Counter-Strike 1.6 en Linux

Esta guía completa le mostrará cómo configurar un servidor Counter-Strike 1.6 en Linux, optimizando el rendimiento y la seguridad para el mejor juego. Aprende los pasos más recientes aquí.

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

Los ataques de ransomware van en aumento, pero ¿puede la IA ayudar a lidiar con el último virus informático? ¿Es la IA la respuesta? Lea aquí, sepa que la IA es una bendición o una perdición

ReactOS: ¿Es este el futuro de Windows?

ReactOS: ¿Es este el futuro de Windows?

ReactOS, un sistema operativo de código abierto y gratuito, está aquí con la última versión. ¿Puede satisfacer las necesidades de los usuarios de Windows de hoy en día y acabar con Microsoft? Averigüemos más sobre este estilo antiguo, pero una experiencia de sistema operativo más nueva.

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Whatsapp finalmente lanzó la aplicación de escritorio para usuarios de Mac y Windows. Ahora puede acceder a Whatsapp desde Windows o Mac fácilmente. Disponible para Windows 8+ y Mac OS 10.9+

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

Lea esto para saber cómo la Inteligencia Artificial se está volviendo popular entre las empresas de pequeña escala y cómo está aumentando las probabilidades de hacerlas crecer y dar ventaja a sus competidores.

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

Recientemente, Apple lanzó macOS Catalina 10.15.4, una actualización complementaria para solucionar problemas, pero parece que la actualización está causando más problemas que conducen al bloqueo de las máquinas Mac. Lee este artículo para obtener más información

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

¿Qué es un sistema de archivos de diario y cómo funciona?

¿Qué es un sistema de archivos de diario y cómo funciona?

Nuestra computadora almacena todos los datos de una manera organizada conocida como sistema de archivos de diario. Es un método eficiente que permite a la computadora buscar y mostrar archivos tan pronto como presiona buscar.