<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Vicente Jorquera</title>
    <description>The latest articles on DEV Community by Vicente Jorquera (@jvicente_20).</description>
    <link>https://dev.to/jvicente_20</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F712120%2Ff4d0f23b-1c2a-4973-8aa4-00b9f8d001f4.jpg</url>
      <title>DEV Community: Vicente Jorquera</title>
      <link>https://dev.to/jvicente_20</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/jvicente_20"/>
    <language>en</language>
    <item>
      <title>Como desplegar tu app de NextJS en tu propio servidor GNU/Linux</title>
      <dc:creator>Vicente Jorquera</dc:creator>
      <pubDate>Wed, 28 Feb 2024 02:03:19 +0000</pubDate>
      <link>https://dev.to/jvicente_20/como-desplegar-tu-app-de-nextjs-en-tu-propio-servidor-gnulinux-2mbc</link>
      <guid>https://dev.to/jvicente_20/como-desplegar-tu-app-de-nextjs-en-tu-propio-servidor-gnulinux-2mbc</guid>
      <description>&lt;p&gt;En este artículo te cuento como desplegar tu aplicación de NextJS 14 o superior (igualmente funciona para versiones previas con pages router) en tu propio servidor de GNU/Linux. Cabe mencionar que este procedimiento funcionará tanto para distribuciones basadas en Debiando como Ubuntu server y distribuciones basadas en RHEL como Rocky Linux por ejemplo. De todas formas este proceso es el mismo tanto si se lleva en un entorno local con máquinas virtuales como si se lleva a cabo en un entorno cloud de &lt;strong&gt;AWS, Azure o Google Cloud&lt;/strong&gt;.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prerequisitos
&lt;/h2&gt;

&lt;p&gt;Antes de comenzar el despliegue necesitaremos de lo siguiente:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Servidor Linux&lt;/strong&gt; - En este caso en particular llevaré a cabo este proceso en &lt;a href="https://ubuntu.com/download/server" rel="noopener noreferrer"&gt;Ubuntu Server&lt;/a&gt;. Sin embargo, como he mencionado previamente puedes llevarlo a cabo en el servidor Linux de tu preferencia.&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;NodeJS&lt;/strong&gt; - Como nuestra app de NextJS debe ejecutarse sobre NodeJS debemos asegurarnos de que la versión de NodeJS que instalemos en nuestro servidor la igual o superior a la versión que tenemos instalada en el entorno de desarrollo. Lamentablemente muchas distribuciones vienen con repositorios desactualizados en cuanto a NodeJS y NPM se refiere, por eso aquí abajo te dejo dos enlaces donde puedes encontrar la versión más reciente de NodeJS acorde a tu distribución.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://nodejs.org/en" rel="noopener noreferrer"&gt;Web oficial&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/nodesource/distributions" rel="noopener noreferrer"&gt;NodeSource&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;

&lt;li&gt;&lt;p&gt;&lt;strong&gt;PM2&lt;/strong&gt; - Para asegurarnos de que nuestro proyecto se inicialice como servicio, es decir, que arranque a penas el servidor enciende y además nos ofrezca monitoreo gratuito (o más detallado mediante una suscripción) utilizaremos &lt;a href="https://www.npmjs.com/package/pm2" rel="noopener noreferrer"&gt;PM2&lt;/a&gt; un manejador de procesos avanzado para &lt;strong&gt;NodeJS&lt;/strong&gt;.&lt;/p&gt;&lt;/li&gt;

&lt;li&gt;

&lt;p&gt;&lt;strong&gt;Web Server&lt;/strong&gt; - Para permitir el tráfico externo hacia nuestra web, utilizaremos un servicio adicional que nos permitirá levantar un servidor web que redireccione a nuestro puerto 3000 o el que se haya seleccionado para que se ejecute nuestra aplicación de NextJS. Cabe mencionar que al añadir este webserver tendremos más ventajas como la de configurar un balanceador de carga para redirigir el tráfico o configurar varios servidores de NodeJS en el mismo físico y redirigir estas peticiones a través de nuestro web server. Para este proyecto en concreto estaré utilizando &lt;strong&gt;Nginx&lt;/strong&gt;, también existen otras opciones como &lt;strong&gt;httpd&lt;/strong&gt; o &lt;strong&gt;apache2&lt;/strong&gt; (mismo paquete, diferente nombre entre Debian / RHEL). Puedes descargar tu servidor web de preferencia en tu distro de la siguiente manera:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Distribuciones basadas en Debian:&lt;/strong&gt;
&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;

&lt;/ul&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;      sudo apt update &amp;amp;&amp;amp; sudo apt upgrade -y

      sudo apt install nginx
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Distribuciones basadas en RHEL&lt;/strong&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;      sudo dnf update -y // o con yum

      sudo yum update -y

      sudo dnf install nginx
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;(Opcional) Cuenta de AWS / Azure / Google Cloud&lt;/strong&gt; - Como mencioné previamente, el contenido de este artículo será válido para cualquiera de las nubes grandes, así también con tu propio servidor por esto este prerequisito es opcional. Sin embargo, con el fin de asegurar la disponibilidad de nuestra aplicación sería una buena inversión contratar los servicios de AWS, Azure o Google cloud.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Paso 1: Instalación de paquetes y dependencias
&lt;/h2&gt;

&lt;p&gt;Como con cualquier instalación de paquetes en cualquier distribución GNU/Linux es importante tener el caché del repositorio y las dependencias actualizadas, en esta ocación con &lt;strong&gt;Ubuntu&lt;/strong&gt; se hace de la siguiente manera:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo apt update &amp;amp;&amp;amp; sudo apt upgrade -y
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;El comando anterior se encargará de refrescar los repositorios en caso de que tengamos paquetes nuevos por instalar y el segundo se encargará de descargar e instalar dichos paquetes, al agregar &lt;strong&gt;-y&lt;/strong&gt; le decimos que queremos confirmar automáticamente la instalación de dicha paquetería.&lt;/p&gt;

&lt;h3&gt;
  
  
  Una vez con toda la paquetería actualizada, procedemos con la instalación del web server:
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo apt install nginx -y
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Una vez que el paquete termine de instalarse debemos inicializarlo, para esto ejectutamos los siguientes comandos:
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo systemctl start nginx

    sudo systemctl enable nginx

    sudo systemctl status nginx
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Los comandos hacen lo siguiente:
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;sudo systemctl start nginx&lt;/strong&gt; Inicializa el servicio de Nginx.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;sudo systemctl enable nginx&lt;/strong&gt; Carga el servicio en el arranque para que se ejecute a penas la máquina inicia.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;sudo systemctl status nginx&lt;/strong&gt; Muestra el estado del servicio, en este caso permitiéndonos saber el estado de nginx.&lt;/li&gt;
&lt;/ol&gt;

&lt;h3&gt;
  
  
  Finalmente deberíamos ver que el atributo &lt;strong&gt;loaded&lt;/strong&gt; y &lt;strong&gt;active&lt;/strong&gt; están correctos, tal como se ve en la siguiente imagen:
&lt;/h3&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fstatus_nginx.webp" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fstatus_nginx.webp" alt="Estado de Nginx" width="800" height="268"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Una vez tengamos instalado y funcionando NGINX podremos ver su web de ejemplo que viene precargada de forma automática una vez instalemos el servicio, para hacer esto tenemos varias formas, una podría ser utilizando &lt;strong&gt;curl&lt;/strong&gt; dentro de la misma terminal al localhost, sin embargo, lo que nos interesa es compartir nuestra aplicación con el mundo, por esto debemos asegurarnos de buscar por ahora la &lt;strong&gt;IP PÚBLICA&lt;/strong&gt; de la máquina en el navegador, obviamente en este punto es necesario habilitar una regla en el firewall del servidor y/o del servicio cloud, por ejemplo, en &lt;strong&gt;AWS&lt;/strong&gt; es necesario agregar una regla de entrada &lt;strong&gt;(inbound rule)&lt;/strong&gt; ya sea desde nuestra IP o cualquier IP al puerto 80 &lt;strong&gt;(HTTP)&lt;/strong&gt; o el puerto 443 &lt;strong&gt;(HTTPS)&lt;/strong&gt; si planeas agregar un certificado SSL al servidor.&lt;/p&gt;

&lt;p&gt;Si todo ha ido como se espera, a este punto deberíamos ser capaces de buscar la IP pública de nuestra máquina en un navegador web y ver la siguiente pantalla de NGINX.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fnginx_running_on_ip.webp" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fnginx_running_on_ip.webp" alt="NGINX HOME PAGE" width="800" height="474"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  A continuación debemos preparar nuestro entorno de ejecución para nuestro código, para esto debemos descargar NodeJS, NPM y Git si tenemos un repositorio con el código.
&lt;/h3&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Instalación de Git&lt;/strong&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;       sudo apt install git -y
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Instalación de NodeJS&lt;/strong&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Como dije anteriormente necesitamos utilizar una fuente externa para descargarnos versiones recientes de NodeJS y en este caso instalaré la versión 20 LTS desde &lt;a href="https://github.com/nodesource/distributions" rel="noopener noreferrer"&gt;Node Source&lt;/a&gt; con los siguientes comandos aunque es recomendable que vayas a su &lt;a href="https://github.com/nodesource/distributions" rel="noopener noreferrer"&gt;Github&lt;/a&gt; para que encuentres los comandos actualizados.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash - &amp;amp;&amp;amp;\
    sudo apt-get install -y nodejs
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Cuando terminen de ejecutarse los comandos anteriores, tendremos la versión seleccionada de NodeJS y la última versión disponible de NPM que se empaqueta junto a NodeJS.&lt;/p&gt;

&lt;p&gt;Para visualizar la versión actual instalada en nuestro sistema podemos hacerlo con los siguientes comandos:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;       node -v

       npm -v
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Dichos comandos nos mostraran una salida como la siguiente:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    ubuntu@ubuntu:~$ node -v
    v20.11.1
    ubuntu@ubuntu:~$ npm -v
    10.4.0
    ubuntu@ubuntu:~$
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Instalación de PM2&lt;/strong&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Una vez tengamos instalado NodeJS bastará con ejectuar el comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;       sudo npm i -g pm2
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Es importante que utilicemos sudo ya que al menos &lt;strong&gt;Ubuntu Server&lt;/strong&gt; evitará que utilicemos el comando npm como un usuario normal y corriente, adicionalmente necesitaremos la banderilla &lt;code&gt;-g&lt;/code&gt; (global) que nos permitirá utilizar pm2 desde cualquier lugar del sistema operativo.&lt;/p&gt;

&lt;h2&gt;
  
  
  Paso 2: Clonar y compilar el proyecto en nuestro servidor
&lt;/h2&gt;

&lt;p&gt;En mi caso personal utilizo y recomiendo utilizar Git para llevar de forma fácil la última versión de nuestro código al servidor. Sin embargo, esto es opcional, ya que si gustas puedes copiar y pegar la carpeta del proyecto desde tu pc en el servidor, ya sea con &lt;strong&gt;Filezilla&lt;/strong&gt; o por ssh, en este punto lo importante es que definamos una ruta donde vamos a almacenar nuestro código.&lt;/p&gt;

&lt;p&gt;En este caso cree una carpeta llamada &lt;strong&gt;proyecto&lt;/strong&gt; y ahí dentro cloné mi app de NextJS desde Github quedando de la siguiente manera:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    ./proyecto/
    └── app-ejemplo
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Bien, con esto listo podemos asegurarnos de instalas los &lt;strong&gt;node_modules&lt;/strong&gt; y las dependencias que sean requeridas según el proyecto. En este caso estoy utilizando una aplicación extremadamente simple que solo muestra un &lt;strong&gt;Hola mundo de NextJS&lt;/strong&gt; cuando se ejecuta.&lt;/p&gt;

&lt;p&gt;Con todo esto listo, debemos crear una compilación de nuestra aplicación con el comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo npm run build

    // o podemos usar (ambos hacen lo mismo)

    sudo npm next build
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Esto comenzará el proceso de compilación de nuestra aplicación y si finalmente todo sale como se espera dentro del mismo directorio tendremos disponible la versión compilada del proyecto.&lt;/p&gt;

&lt;p&gt;Una vez completado el proceso de buildeo de nuestra app deberíamos ver lo siguiente:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;   ▲ Next.js 14.1.0

   Creating an optimized production build ...
 ✓ Compiled successfully
 ✓ Linting and checking validity of types
 ✓ Collecting page data
 ✓ Generating static pages (5/5)
 ✓ Collecting build traces
 ✓ Finalizing page optimization

Route (app)                              Size     First Load JS
┌ ○ /                                    137 B          84.3 kB
└ ○ /_not-found                          882 B            85 kB
+ First Load JS shared by all            84.1 kB
  ├ chunks/69-1b6d135f94ac0e36.js        28.9 kB
  ├ chunks/fd9d1056-cc48c28d170fddc2.js  53.4 kB
  └ other shared chunks (total)          1.87 kB


○  (Static)  prerendered as static content
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Evidentemente según el tamaño de la aplicación que se esté compilando y la cantidad de rutas que se tengan puede tardar más tiempo en compilar y a su vez mostrar más datos en la terminal.&lt;/p&gt;

&lt;h2&gt;
  
  
  Paso 3: Inicializar el proyecto como servicio con PM2
&lt;/h2&gt;

&lt;p&gt;A continuación debemos asegurarnos de que nuestro proyecto se ejecute automáticamente nada más encender el servidor, para lograr esto necesitamos ejecutar los siguientes comandos:&lt;/p&gt;

&lt;p&gt;Lo primero es situarse en la ruta donde raíz de nuestro proyecto, en mi caso en esta ruta:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    cd ./proyecto/app-ejemplo
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Una vez ubicados en la ruta raíz procedemos a ejecutar el siguiente comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    pm2 start npm --name 'my-app' -- start
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;El comando anterior se encargará de ejecutar nuestra aplicación de NextJS compilada y le asignará el nombre de &lt;strong&gt;my-app&lt;/strong&gt; al gestor de procesos &lt;strong&gt;pm2&lt;/strong&gt;, otro de los beneficios agregados de &lt;strong&gt;PM2&lt;/strong&gt; es que nuestra aplicación se reiniciará automáticamente si se crashea en producción.&lt;/p&gt;

&lt;p&gt;Una vez hayamos ejecutado el comando previo y tengamos éxito veremos la siguiente salida:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    [PM2] Starting /usr/bin/npm in fork_mode (1 instance)
    [PM2] Done.
    ┌────┬────────────────────┬──────────┬──────┬───────────┬──────────┬──────────┐
    │ id │ name               │ mode     │ ↺    │ status    │ cpu      │ memory   │
    ├────┼────────────────────┼──────────┼──────┼───────────┼──────────┼──────────┤
    │ 0  │ my-app             │ fork     │ 0    │ online    │ 0%       │ 7.6mb    │
    └────┴────────────────────┴──────────┴──────┴───────────┴──────────┴──────────┘
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Paso 4: Configurar NGINX para que dirija las peticiones en el puerto 80 a nuestra app
&lt;/h2&gt;

&lt;p&gt;Esto nos permitirá tener un despliegue escalable, ya que cuando aumenten las instancias de nuestra aplicación o tengamos diferentes servicios basados en la región desde donde se está haciendo la petición (por ejemplo) podremos configurarlo con mucha facilidad en nuestro servidor NGINX, por ahora, vamos a redireccionar las peticiones del puerto 80 al 3000 de la siguiente manera:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo nano /etc/nginx/sites-available/my-app.com
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Con el comando anterior abriremos un nuevo archivo llamado &lt;strong&gt;my-app.com&lt;/strong&gt; en la ruta &lt;strong&gt;/etc/nginx/sites-available/&lt;/strong&gt; en el editor &lt;strong&gt;nano&lt;/strong&gt;, si no tienes nano instalado, puedes reemplazar nano por &lt;strong&gt;vi&lt;/strong&gt; y seguro que funcionará en tu distribución. Continuando con la explicación, se recomienda que reemplaces &lt;strong&gt;my-app-com&lt;/strong&gt; por el nombre de tu aplicación o el dominio de tu web, esto no es estrictamente necesario pero es una práctica común en servidores de NGINX para diferenciar los sitios que existen dentro de &lt;strong&gt;NGINX&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;A continuación debemos pegar el siguiente código en el archivo que acabamos de crear: (UTILIZANDO LA IP)&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    server {
        listen 80;
        location / {
                proxy_pass http://localhost:3000;
        }
    }
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;En caso de tener un dominio personalizado se debe agregar este código:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    server {
        listen 80;
        server_name tudominio.com www.tudominio.com;
        location / {
            proxy_pass http://localhost:3000;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
        }
    }
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Esto le dice a NGINX que escuche en el puerto 80 y cuando reciba una petición internamente la redirija al puerto 3000 abierto en el localhost, de esta manera bastará con cargar la IP pública para acceder a nuestra aplicación.&lt;/p&gt;

&lt;p&gt;En este momento ya deberíamos tener nuestra aplicación funcionando y visible a través de NGINX como podemos ver en la siguiente imagen:&lt;/p&gt;

&lt;h2&gt;
  
  
  Paso 5: Configurando nuestra app de PM2 como servicio
&lt;/h2&gt;

&lt;p&gt;Como mencioné al inicio de este artículo, una funcionalidad específica de esta guía era hacer que nuestra aplicación sea accesible por el mundo nada más encendamos el servidor, sin la necesidad de estar manualmente encendiendo la app con pm2. El proceso es bastante simple y se realiza con el siguiente comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    pm2 startup systemd
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Esto nos arrojará el siguiente resultado:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    ubuntu@ubuntu:~/proyecto/app-ejemplo$ pm2 startup systemd
    [PM2] Init System found: systemd
    [PM2] To setup the Startup Script, copy/paste the following command:
    sudo env PATH=$PATH:/usr/bin /usr/lib/node_modules/pm2/bin/pm2 startup systemd -u ubuntu --hp /home/ubuntu
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Finalmente copiamos la última línea y la ejecutamos en nuestra terminal. Volvemos a ejecutar &lt;strong&gt;pm2 save&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Luego nos queda inicializar nuestro servicio con systemd (Es importante considerar que &lt;strong&gt;ubuntu&lt;/strong&gt; se refiere al usuario en la máquina):&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;    sudo systemctl start pm2-ubuntu &amp;amp;&amp;amp; sudo systemctl status pm2-ubuntu
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;En caso de que nos arroje un error, solo debemos reiniciar el servidor y posteriormente volver a ejecutar únicamente el comando previo con el que iniciamos el proceso.&lt;/p&gt;

&lt;p&gt;Felicidades, si llegaste a este punto ya tienes tu aplicación de NEXTJS ejecutándose en tu servidor web con NGINX y PM2.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fshot-so-large.webp" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fblog-vicente-jorquera.s3.amazonaws.com%2Finstalar-nextjs-en-tu-servidor-linux%2Fshot-so-large.webp" alt="Imagen final" width="800" height="450"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Referencias
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Cómo correr un servidor de nodejs con nginx:&lt;/strong&gt; &lt;a href="https://blog.logrocket.com/how-to-run-a-node-js-server-with-nginx/" rel="noopener noreferrer"&gt;https://blog.logrocket.com/how-to-run-a-node-js-server-with-nginx/&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Cómo usar PM2 para configurar un entorno de producción con PM2:&lt;/strong&gt; &lt;a href="https://www.digitalocean.com/community/tutorials/how-to-use-pm2-to-setup-a-node-js-production-environment-on-an-ubuntu-vps" rel="noopener noreferrer"&gt;https://www.digitalocean.com/community/tutorials/how-to-use-pm2-to-setup-a-node-js-production-environment-on-an-ubuntu-vps&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Despliegue de NextJS manualmente&lt;/strong&gt;: &lt;a href="https://nextjs.org/docs/app/building-your-application/deploying" rel="noopener noreferrer"&gt;https://nextjs.org/docs/app/building-your-application/deploying&lt;/a&gt;&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>webdev</category>
      <category>beginners</category>
      <category>nextjs</category>
      <category>linux</category>
    </item>
  </channel>
</rss>
