Instalación y configuración de un servidor nginx + mysql + php en debian

  • 4 Respuestas
  • 3712 Vistas

0 Usuarios y 1 Visitante están viendo este tema.

Desconectado Okiz

  • *
  • Underc0der
  • Mensajes: 54
  • Actividad:
    0%
  • Reputación 0
  • Debian Linux
    • Ver Perfil


Hola buenas noches;

Os vengo a explicar como configurar un servidor web en debian usando nginx, php y mysql. Procederé a comentarles todos los comandos a usar y a la configuración de cada uno para que el servidor web funcione a la perfección yo lo estoy explicando sobre nginx pero es lo mismo para sus derivados, como ubuntu, linux mint etc... Antes de nada me gustaría resaltar la gran fluidez que tiene nginx también explicare como alojar más de un sitio web en el mismo servidor.

*Para no tener que estar tecleando todo el rato sudo nos loguearemos como root.


Lo primero que haremos será instalar nginx
Código: You are not allowed to view links. Register or Login
apt-get install nginx
Instalamos MySQL
Código: You are not allowed to view links. Register or Login
apt-get install mysql-server
Finalmente instalamos PHP
Código: You are not allowed to view links. Register or Login
apt-get install php5-fpm php5-mysql

· Configuración de PHP

Una vez tenemos todos nuestros servicios instalados procedemos a su configuración yo prefiero empezar por PHP debido a que es solamente la edición de un archivo, pero cada uno puede empezar por donde quiera ya que finalmente llegaremos a la misma meta. Editamos el archivo php.ini que se encuentra en /etc/php5/fpm/php.ini lo editaremos con nano:
Código: You are not allowed to view links. Register or Login
nano /etc/php5/fpm/php.ini
Ahora buscamos con CTRL+W:
Código: You are not allowed to view links. Register or Login
cgi.fix_pathinfo=1
Y lo reemplazamos por:
Código: You are not allowed to view links. Register or Login
cgi.fix_pathinfo=0
Presionamos CTRL + X y guardamos los cambios, una vez guardados los cambios procedemos a reiniciar el servicio:
Código: You are not allowed to view links. Register or Login
service php5-fpm restart


· Configuración de Nginx

Ahora procederemos a la configuración de nginx para ello nos iremos a "/etc/nginx/sites-enabled"
Código: You are not allowed to view links. Register or Login
cd /etc/nginx/sites-enabled
Una vez situados en el directorio nos encontraremos con un archivo llamado default ese archivo lo vamos a borrar y vamos a crear uno nuevo con el nombre de nuestra página web y le daremos permisos 777:
Código: You are not allowed to view links. Register or Login
rm -r default
Código: You are not allowed to view links. Register or Login
nano wintxcoders.com
Código: You are not allowed to view links. Register or Login
chmod 777 wintxcoders.com
Una vez tenemos nuestro archivo lo abrimos con nano y pegamos el siguiente código en él:
Código: You are not allowed to view links. Register or Login
nano wintxcoders.com
Código: You are not allowed to view links. Register or Login
server {
        listen 80 default_server ;
        #listen [::]:80 default_server ipv6only=on;

        root /usr/share/nginx/www/wintxcoders.com;
        index index.php index.html index.htm;

        # Make site accessible from http://localhost/
        server_name wintxcoders.com www.wintxcoders.com;

                 error_page 404 /404.html;
                 error_page 500 502 503 504 /50x.html;
                 location = /50x.html {
                 root /usr/share/nginx/www;
         }

         location ~ \.php$ {
                 try_files $uri =404;
                 fastcgi_split_path_info ^(.+\.php)(/.+)$;
                 fastcgi_pass unix:/var/run/php5-fpm.sock;
                 fastcgi_index index.php;
                 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                 include fastcgi_params;
         }

        location / {
                # First attempt to serve request as file, then
                # as directory, then fall back to displaying a 404.
                try_files $uri $uri/ /index.html;
                # Uncomment to enable naxsi on this location
                # include /etc/nginx/naxsi.rules
        }

        location /doc/ {
                alias /usr/share/doc/;
      autoindex on;
                allow 127.0.0.1;
                allow ::1;
                deny all;
        }

        # Only for nginx-naxsi used with nginx-naxsi-ui : process denied requests
        #location /RequestDenied {
        #       proxy_pass http://127.0.0.1:8080;
        #}

        #error_page 404 /404.html;

        # redirect server error pages to the static page /50x.html
        #
        #error_page 500 502 503 504 /50x.html;
        #location = /50x.html {
        #       root /usr/share/nginx/www;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #       fastcgi_split_path_info ^(.+\.php)(/.+)$;
        #       # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
        #
        #       # With php5-cgi alone:
        #       fastcgi_pass 127.0.0.1:9000;
 #       # With php5-fpm:
        #       fastcgi_pass unix:/var/run/php5-fpm.sock;
        #       fastcgi_index index.php;
        #       include fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #       deny all;
        #}
}


# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
#       listen 8000;
#       listen somename:8080;
#       server_name somename alias another.alias;
#       root html;
#       index index.html index.htm;
#
#       location / {
#               try_files $uri $uri/ =404;
#       }
#}


# HTTPS server
#
#server {
#       listen 443;
#       server_name localhost;
#
#       root html;
#       index index.html index.htm;
#
#       ssl on;
#       ssl_certificate cert.pem;
#       ssl_certificate_key cert.key;
#
#       ssl_session_timeout 5m;
#
#       ssl_protocols SSLv3 TLSv1;
#       ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv3:+EXP;
#       ssl_prefer_server_ciphers on;
#
#       location / {
#               try_files $uri $uri/ =404;
#       }
#}



// ¡OJO! //

Si nos fijamos donde pone root es la ruta donde alojaremos nuestro sitio web nosotros hemos creado una carpeta dentro de www llamada wintxcoders.com y le hemos dado permisos 777 seguidamente donde pone server_name pondremos el nombre de nuestro sitio web de esta manera podremos alojar mas de una web en nuestro servidor!

Código: You are not allowed to view links. Register or Login
root /usr/share/nginx/www/wintxcoders.com;
        index index.php index.html index.htm;

        # Make site accessible from http://localhost/
        server_name wintxcoders.com www.wintxcoders.com;

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////



Ahora nos vamos al sites-enabled que se encuentra en "/etc/nginx/sites-available" allí nos encontraremos otro archivo como el anterior llamado default, aremos lo mismo lo borramos y creamos otro llamado como nuestro sitio web.
Código: You are not allowed to view links. Register or Login
cd /etc/nginx/sites-available
Código: You are not allowed to view links. Register or Login
rm -r default
Código: You are not allowed to view links. Register or Login
nano wintxcoders.com
Pegamos el siguiente código:
Código: You are not allowed to view links. Register or Login
server {
        listen   80;
        #listen   [::]:80 default_server ipv6only=on;

        root /usr/share/nginx/www/wintxcoders.com;
        index index.php  index.html  index.htm;
        server_name wintxcoders.com www.wintxcoders.com;

        # --------------------------------------
        # Compression GZIP
        # --------------------------------------

        gzip on;
        gzip_types text/plain text/css application/json application/x-javascript text/javascript;
        gzip_comp_level 6;
        gzip_min_length 1000;

        # --------------------------------------
        # Directorio principal
        # --------------------------------------

        location / {
                try_files $uri $uri/ /index.php?q=$uri&$args;
                # include /etc/nginx/naxsi.rules
        }


        # --------------------------------------
        # Forzar algunas cabeceras.
        # Prohibir iframes y activar anti XSS
        # --------------------------------------

        add_header 'X-Frame-Options' 'DENY';
        add_header 'X-XSS-Protection' '1; mode=block';
        add_header 'Content-Security-Policy' 'frame-options \'deny\'';


        # --------------------------------------
        # Redirigir a dominio sin www.
        # --------------------------------------

        if ($host ~* ^www\.(.*)) {
                set $hww $1;
                rewrite ^/(.*)$ $scheme://$hww/$1 permanent;
        }


        # --------------------------------------
        # Deshabilitar directorios
        # --------------------------------------
        location /doc/ {
                alias /usr/share/doc/;
               autoindex on;
                allow 127.0.0.1;
                allow ::1;
                deny all;
        }

        # --------------------------------------
        # Logs y paginas de error.
        # --------------------------------------

        access_log /var/log/nginx/wintxcoders.access.log;
        error_log /var/log/nginx/wintxcoders.error.log;

        error_page 404 /404.html;
        error_page 500 502 503 504 /errores/50x.html;
        location = /errores/50x.html {
                root /var/www/;
        }

        # --------------------------------------
        # Pass the PHP scripts to FastCGI
        # --------------------------------------

        location ~ \.php$ {
                try_files $uri = 404;
                fastcgi_split_path_info ^(.+\.php)(/.+)$;
                fastcgi_cache microcache;
                fastcgi_cache_key $scheme$host$request_uri$request_method;
    fastcgi_cache_valid 301 302 404 30s;
                fastcgi_cache_valid 200 1s;
                fastcgi_cache_use_stale updating error timeout invalid_header http_500;
                fastcgi_pass_header Set-Cookie;
                fastcgi_pass_header Cookie;
                fastcgi_ignore_headers Cache-Control Expires Set-Cookie;
                fastcgi_pass unix:/var/run/php5-fpm.sock;
                fastcgi_index index.php;
                include fastcgi_params;
        }

        location ~ /\.ht {      deny all;       }
}

Una vez pegado procedemos a guardar con CTRL + X



// ¡OJO! //

Si nos fijamos en el apartado logs nos dice donde quieres que guarde los logs tanto de acceso como de error y con el nombre que los quieres para cuando los quieras revisar

Código: You are not allowed to view links. Register or Login
# --------------------------------------
        # Logs y paginas de error.
        # --------------------------------------

        access_log /var/log/nginx/wintxcoders.access.log;
        error_log /var/log/nginx/wintxcoders.error.log;

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////


Una vez terminado esto vamos a crear el directorio donde se guardara nuestra web si es que no lo hemos creado anteriormente "/usr/share/nginx/www/wintxcoders.com"
Código: You are not allowed to view links. Register or Login
cd /usr/share/nginx/www
Código: You are not allowed to view links. Register or Login
mkdir wintxcoders.com
Código: You are not allowed to view links. Register or Login
chmod 777 wintxcoders.com



Bueno eso es todo respecto a la configuración del servidor web si queremos alojar alguna web más basta con crear un nuevo archivo en el sites-enabled cambiándole el nombre del server y cambiando el directorio root de los archivos de nuestra pagina web como por ejemplo:

Código: You are not allowed to view links. Register or Login
/usr/share/nginx/www/wintxcoders.com
Código: You are not allowed to view links. Register or Login
/usr/share/nginx/www/hostop.es
Si vuestro sitio web lleva una base de datos es tan simple como que os paséis por el siguiente post que os facilitare de otro tutorial - You are not allowed to view links. Register or Login

Conectado ANTRAX

  • *
  • Administrator
  • Mensajes: 5702
  • Actividad:
    93.33%
  • Country: ar
  • Reputación 37
  • ANTRAX
  • Skype: underc0de.org
  • Twitter: @Underc0de
    • Ver Perfil
    • Underc0de
    • Email
Muy bueno! Me encantó!
Te dejo +c0in!

Saludos!
ANTRAX


Desconectado Okiz

  • *
  • Underc0der
  • Mensajes: 54
  • Actividad:
    0%
  • Reputación 0
  • Debian Linux
    • Ver Perfil
Gracias, me dolían los dedos de escribir hoy jajaja hace unos años pregunté esta duda por aquí y bueno no quedo clara del todo pues años después y ya con mi pequeña experiencia con ello decidí aportar algo que centralice lo que viene siendo como montar un servidor web en un linux con nginx.

Gracias, Saludos!

Desconectado Cl0udswX

  • *
  • Ex-Staff
  • *****
  • Mensajes: 896
  • Actividad:
    33.33%
  • Country: 00
  • Reputación 4
  • La fisica es el sistema operativo del universo.
  • Skype: cl0udzwx
  • Twitter: @cl0udswx
    • Ver Perfil
    • cl0udswz - Sequre
Muy bueno en verdad..!!

Buena redacción, claridad y sencillez.

Saludos y gracias por el aporte sigue asi..!!
El talento se parece al tirador que da en un blanco que los demás no pueden alcanzar; el genio se parece al tirador que da en un blanco que los demás no pueden ver.

Desconectado Okiz

  • *
  • Underc0der
  • Mensajes: 54
  • Actividad:
    0%
  • Reputación 0
  • Debian Linux
    • Ver Perfil
Gracias chicos, se me olvidó poner que cuando se crea el sites-enabled sites-available y se tiene todo subido para que los cambios tengan efecto hacer un service nginx restart

Código: You are not allowed to view links. Register or Login
service nginx restart
Se que es básico pero bueno lo que quiero conseguir con este tutorial es que todo el mundo lo entienda.

Gracias!

 

[Tutorial]Instalación de ArchLinux Paso a Paso

Iniciado por Comandante Linux

Respuestas: 1
Vistas: 3205
Último mensaje Agosto 24, 2011, 09:40:45 pm
por Snifer
[Tutorial] Instalación de Mandriva 2011, paso a paso

Iniciado por Comandante Linux

Respuestas: 2
Vistas: 4240
Último mensaje Agosto 28, 2011, 07:06:37 pm
por Comandante Linux
4 herramientas para escanear un servidor Linux en busca de malware y rootkits

Iniciado por graphixx

Respuestas: 1
Vistas: 4711
Último mensaje Agosto 22, 2018, 03:40:49 pm
por Lautaro Villarreal Culic'
Manual de servidor samba en mandriva 2010 by k43l

Iniciado por k43l

Respuestas: 1
Vistas: 4314
Último mensaje Julio 03, 2010, 01:23:55 pm
por Darvein
Instala Tu Propio Servidor VPN con OpenVPN en Ubuntu 10.04

Iniciado por Kodeinfect

Respuestas: 0
Vistas: 2709
Último mensaje Febrero 27, 2011, 07:53:14 pm
por Kodeinfect