Este sitio utiliza cookies propias y de terceros. Si continúa navegando consideramos que acepta el uso de cookies. OK Más Información.

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

  • 4 Respuestas
  • 2866 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
« en: Febrero 15, 2016, 10:28:36 pm »


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: [Seleccionar]
apt-get install nginx
Instalamos MySQL
Código: [Seleccionar]
apt-get install mysql-server
Finalmente instalamos PHP
Código: [Seleccionar]
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: [Seleccionar]
nano /etc/php5/fpm/php.ini
Ahora buscamos con CTRL+W:
Código: [Seleccionar]
cgi.fix_pathinfo=1
Y lo reemplazamos por:
Código: [Seleccionar]
cgi.fix_pathinfo=0
Presionamos CTRL + X y guardamos los cambios, una vez guardados los cambios procedemos a reiniciar el servicio:
Código: [Seleccionar]
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: [Seleccionar]
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: [Seleccionar]
rm -r default
Código: [Seleccionar]
nano wintxcoders.com
Código: [Seleccionar]
chmod 777 wintxcoders.com
Una vez tenemos nuestro archivo lo abrimos con nano y pegamos el siguiente código en él:
Código: [Seleccionar]
nano wintxcoders.com
Código: [Seleccionar]
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: [Seleccionar]
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: [Seleccionar]
cd /etc/nginx/sites-available
Código: [Seleccionar]
rm -r default
Código: [Seleccionar]
nano wintxcoders.com
Pegamos el siguiente código:
Código: [Seleccionar]
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: [Seleccionar]
# --------------------------------------
        # 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: [Seleccionar]
cd /usr/share/nginx/www
Código: [Seleccionar]
mkdir wintxcoders.com
Código: [Seleccionar]
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: [Seleccionar]
/usr/share/nginx/www/wintxcoders.com
Código: [Seleccionar]
/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 - TURORIAL MYSQL

Conectado ANTRAX

  • *
  • Administrator
  • Mensajes: 5487
  • Actividad:
    23.33%
  • Reputación 35
  • ANTRAX
    • Ver Perfil
    • Underc0de
    • Email
  • Skype: underc0de.org
  • Twitter: @Underc0de
« Respuesta #1 en: Febrero 15, 2016, 10:40:14 pm »
Muy bueno! Me encantó!
Te dejo +c0in!

Saludos!
ANTRAX


Desconectado Okiz

  • *
  • Underc0der
  • Mensajes: 54
  • Actividad:
    0%
  • Reputación 0
  • Debian Linux
    • Ver Perfil
« Respuesta #2 en: Febrero 15, 2016, 10:44:32 pm »
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

  • *
  • Colaborador
  • *
  • Mensajes: 876
  • Actividad:
    1.67%
  • Reputación 4
  • La fisica es el sistema operativo del universo.
    • Ver Perfil
    • cl0udswz - Sequre
  • Skype: cl0udzwx
  • Twitter: @cl0udswzsequre
« Respuesta #3 en: Febrero 15, 2016, 11:26:57 pm »
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
« Respuesta #4 en: Febrero 16, 2016, 12:03:45 pm »
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: [Seleccionar]
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!

 

¿Te gustó el post? COMPARTILO!



[Tutorial]Instalación de ArchLinux Paso a Paso

Iniciado por Comandante Linux

Respuestas: 1
Vistas: 2835
Ú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: 3952
Ú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: 3857
Ú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: 3954
Ú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: 2418
Último mensaje Febrero 27, 2011, 07:53:14 pm
por Kodeinfect