<?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: Kelvi Padilla</title>
    <description>The latest articles on DEV Community by Kelvi Padilla (@kesmile).</description>
    <link>https://dev.to/kesmile</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%2F327453%2F96e63de8-0581-4334-9aae-f3e2e6fd687f.jpeg</url>
      <title>DEV Community: Kelvi Padilla</title>
      <link>https://dev.to/kesmile</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/kesmile"/>
    <language>en</language>
    <item>
      <title>Como levantar un backend en minutos con Parse + docker compose</title>
      <dc:creator>Kelvi Padilla</dc:creator>
      <pubDate>Tue, 18 Apr 2023 17:07:08 +0000</pubDate>
      <link>https://dev.to/kesmile/como-levantar-un-backend-en-minutos-con-parse-docker-compose-2efh</link>
      <guid>https://dev.to/kesmile/como-levantar-un-backend-en-minutos-con-parse-docker-compose-2efh</guid>
      <description>&lt;h2&gt;
  
  
  ¿Qué es backend as a service?
&lt;/h2&gt;

&lt;p&gt;Es un servicio de backend que se presta a través de la nube y que se encarga de proveer apis para ser consumidos desde un frontend o app móvil según sea el caso, esto nos permite ahorrarnos el mantenimiento, la creación de plugins entre otras cosas, la lista de ventajas es muy larga y surge de la necesidad de ahorrar tiempo y costos en el desarrollo.&lt;/p&gt;

&lt;h3&gt;
  
  
  ¿Por qué parse-sever?
&lt;/h3&gt;

&lt;p&gt;Existen muchas opciones para tener un backend sin complicarnos en detalles técnicos como por ejemplo firebase, AWS amplify, Supabase entre otros más, estos nos ofrecen un servicio en la nube pero con la desventaja de que no podemos descargar el código fuente y por lo general nos limitamos a las opciones que nos ofrecen, en ocasiones necesitamos tener más control de lo que estamos haciendo y aquí es donde podemos utilizar parse-server, si lo necesitamos podemos descargar el código fuente y ejecutarlo desde express o correrlo desde una imagen de docker, otra de las ventajas es que existen muchos plugins gracias a la gran comunidad que hay detrás del proyecto, en nuestro caso utilizaremos docker compose porque crearemos funciones personalizadas y para ello solo debemos crear una carpeta llamada &lt;code&gt;src/cloud&lt;/code&gt; desde allí crear nuestro archivo &lt;code&gt;main.js&lt;/code&gt; que es el punto de entrada que reconoce parse-server, luego podemos compilar nuestra imagen, levantar la base de datos y levantar el dashboard para poder administrar nuestras clases todo desde docker compose.&lt;/p&gt;

&lt;p&gt;Una vez dicho todo esto es hora empezar a configurar todo nuestro proyecto para así tener un backend el cual te daras cuenta es muy fácil de configurar y mantener.&lt;/p&gt;

&lt;h3&gt;
  
  
  Creación del proyecto
&lt;/h3&gt;

&lt;p&gt;Para este proyecto estoy utilizando pnpm el cual tiene varias ventajas frente a npm y una de las principales para mi es que descarga las dependencias en paralelo y esto permite compilar la imagen de docker mucho más rápido.&lt;/p&gt;

&lt;p&gt;Para empezar debemos tener instalado pnpm y ejecutar el siguiente comando en nuestra terminal.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;pnpm init
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Nos preguntará el nombre del proyecto así como información general del proyecto, este comando nos creará el archivo &lt;code&gt;package.json&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Luego debemos configurar babel para poder utilizar la sintaxis más reciente de javascript, para ello debemos instalar primero las dependencias en nuestro proyecto.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;pnpm &lt;span class="nt"&gt;-i&lt;/span&gt; @babel/cli @babel/core @babel/node @babel/plugin-transform-runtime @babel/preset-env &lt;span class="nt"&gt;--save-dev&lt;/span&gt;

pnpm &lt;span class="nt"&gt;-i&lt;/span&gt; @babel/runtime &lt;span class="nt"&gt;--save&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Una vez tengamos las dependencias instaladas, debemos agregar un archivo de configuración en la raíz del proyecto llamado &lt;code&gt;babel.config.json&lt;/code&gt; y agregar el siguiente código:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"presets"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="s2"&gt;"@babel/preset-env"&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"plugins"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="s2"&gt;"@babel/plugin-transform-runtime"&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"env"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="nl"&gt;"debug"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
          &lt;/span&gt;&lt;span class="nl"&gt;"sourceMaps"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"inline"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
          &lt;/span&gt;&lt;span class="nl"&gt;"retainLines"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="kc"&gt;true&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;En nuestro archivo &lt;code&gt;package.json&lt;/code&gt; en la sección de scripts debemos agregar la siguiente línea para poder compilar nuestro código.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="nl"&gt;"build"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"npx babel src --out-dir dist --copy-files &amp;amp;&amp;amp; cp package.json dist/"&lt;/span&gt;&lt;span class="err"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Con esto ya podemos empezar a crear nuestras propias funciones, parse-server nos permite ejecutar funciones personalizadas solo debemos agregar nuestro código en el directorio llamado &lt;code&gt;src/cloud&lt;/code&gt;, luego debemos crear un archivo llamado main.js, este archivo es el que utiliza parse-server como punto de entrada, para más información puedes consultar la guía oficial en este &lt;a href="https://docs.parseplatform.org/cloudcode/guide/"&gt;link&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Hasta el momento solo hemos creado la estructura del proyecto y la configuración de babel, pero aun no lo podemos probar, la idea es poder correr nuestro código desde una imagen de docker para ello necesitamos crear nuestro Dockerfile, y agregar las siguientes instrucciones para poder compilar nuestro código, descargar dependencias y luego copiar todo a la imagen de parse-server, el cual quedaría de esta manera.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight docker"&gt;&lt;code&gt;&lt;span class="c"&gt;# ---------- Base ----------&lt;/span&gt;
&lt;span class="k"&gt;FROM&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;node:14-slim&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="k"&gt;AS&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;base&lt;/span&gt;
&lt;span class="k"&gt;RUN &lt;/span&gt;apt-get update &lt;span class="o"&gt;&amp;amp;&amp;amp;&lt;/span&gt; apt-get &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-y&lt;/span&gt; libpq-dev g++ make git openssh-client curl
&lt;span class="k"&gt;RUN &lt;/span&gt;curl &lt;span class="nt"&gt;-f&lt;/span&gt; https://get.pnpm.io/v6.16.js | node - add &lt;span class="nt"&gt;--global&lt;/span&gt; pnpm
&lt;span class="c"&gt;# ---------- Builder ----------&lt;/span&gt;
&lt;span class="c"&gt;# Creates:&lt;/span&gt;
&lt;span class="c"&gt;# - node_modules: production dependencies (no dev dependencies)&lt;/span&gt;
&lt;span class="c"&gt;# - dist: A production build compiled with Babel&lt;/span&gt;
&lt;span class="k"&gt;FROM&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;base&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="k"&gt;AS&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;builder&lt;/span&gt;
&lt;span class="k"&gt;WORKDIR&lt;/span&gt;&lt;span class="s"&gt; /app&lt;/span&gt;

&lt;span class="k"&gt;COPY&lt;/span&gt;&lt;span class="s"&gt; .npmrc package.json pnpm-lock.yaml babel.config.json ./&lt;/span&gt;
&lt;span class="k"&gt;RUN &lt;/span&gt;pnpm &lt;span class="nb"&gt;install&lt;/span&gt;
&lt;span class="k"&gt;COPY&lt;/span&gt;&lt;span class="s"&gt; ./src ./src&lt;/span&gt;
&lt;span class="k"&gt;RUN &lt;/span&gt;pnpm build

&lt;span class="c"&gt;# Remove dev dependencies&lt;/span&gt;
&lt;span class="k"&gt;RUN &lt;/span&gt;pnpm prune &lt;span class="nt"&gt;--prod&lt;/span&gt;

&lt;span class="c"&gt;# ---------- Release ----------&lt;/span&gt;
&lt;span class="k"&gt;FROM&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;parseplatform/parse-server:5.4.1&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="k"&gt;AS&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s"&gt;release&lt;/span&gt;
&lt;span class="k"&gt;COPY&lt;/span&gt;&lt;span class="s"&gt; --from=builder /app/node_modules /parse-cloud/node_modules&lt;/span&gt;
&lt;span class="k"&gt;COPY&lt;/span&gt;&lt;span class="s"&gt; --from=builder /app/dist /parse-cloud/&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Como te puedes dar cuenta estoy utilizando una imagen de nodejs v14 slim como primera capa de compilación, los pasos en el Dockerfile son los siguientes: Instalar pnpm, descargar las dependencias y compilar el proyecto, luego creamos una nueva imagen usando como base la imagen oficial de &lt;code&gt;parseplatform/parse-server&lt;/code&gt;, (versión 5.4.1) esto lo hacemos porque debemos copiar nuestro código y para ello debemos guardar las dependencias junto con el código ya compilado en la carpeta &lt;code&gt;parse-cloud&lt;/code&gt;, estar carpeta irá dentro de la imagen de parse, de esta manera podremos llamar a nuestras propias funciones.&lt;/p&gt;

&lt;p&gt;En esta punto ya tenemos nuestra imagen solo la debemos compilarla, para probarla debemos pasarle los parámetros de la base de datos como variables a docker y listo, si bien es posible hacerlo de esa manera es mucho más cómodo levantar la base de datos y &lt;code&gt;parse-dashboard&lt;/code&gt; (el administrador de parse-server) desde un docker compose, de esta manera con un par de comandos podemos tener corriendo todo fácilmente, para ello debemos crear nuestro archivo llamado &lt;code&gt;docker-compose.yml&lt;/code&gt; y agregar el siguiente código.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;version&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;3.9"&lt;/span&gt;
&lt;span class="na"&gt;services&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;mongo&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;image&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;mongo:4.2&lt;/span&gt;
    &lt;span class="na"&gt;restart&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;always&lt;/span&gt;
    &lt;span class="na"&gt;environment&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="na"&gt;MONGO_INITDB_ROOT_USERNAME&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${MONGO_ROOT_USERNAME}&lt;/span&gt;
      &lt;span class="na"&gt;MONGO_INITDB_ROOT_PASSWORD&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${MONGO_ROOT_PASSWORD}&lt;/span&gt;
    &lt;span class="na"&gt;networks&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;app-network&lt;/span&gt;
    &lt;span class="na"&gt;ports&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;27017:27017"&lt;/span&gt;
  &lt;span class="na"&gt;parse&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;build&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;.&lt;/span&gt;
    &lt;span class="na"&gt;environment&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_APPLICATION_ID=${APP_ID}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_MASTER_KEY=${MASTER_KEY}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_REST_API_KEY=${REST_API_KEY}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_CLIENT_KEY=${CLIENT_KEY}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_DATABASE_URI=${DATABASE_URI}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_MOUNT_PATH=/parse&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_CLOUD=/parse-cloud/cloud/main.js&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_MOUNT_GRAPHQL=true&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_SERVER_MOUNT_PLAYGROUND=true&lt;/span&gt;
    &lt;span class="na"&gt;ports&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;1337:1337"&lt;/span&gt;
    &lt;span class="na"&gt;entrypoint&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="pi"&gt;[&lt;/span&gt;&lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;/bin/sh"&lt;/span&gt;&lt;span class="pi"&gt;,&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;-c"&lt;/span&gt;&lt;span class="pi"&gt;,&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="s"&gt;sleep&lt;/span&gt;&lt;span class="nv"&gt; &lt;/span&gt;&lt;span class="s"&gt;5;&lt;/span&gt;&lt;span class="nv"&gt;  &lt;/span&gt;&lt;span class="s"&gt;node&lt;/span&gt;&lt;span class="nv"&gt; &lt;/span&gt;&lt;span class="s"&gt;./bin/parse-server"&lt;/span&gt;&lt;span class="pi"&gt;]&lt;/span&gt; &lt;span class="c1"&gt;#sleep few seconds for postgres to come up&lt;/span&gt;
    &lt;span class="na"&gt;depends_on&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;mongo&lt;/span&gt;
    &lt;span class="na"&gt;networks&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;app-network&lt;/span&gt;
  &lt;span class="na"&gt;parse-dashboard&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;image&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;parseplatform/parse-dashboard&lt;/span&gt;
    &lt;span class="na"&gt;ports&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s1"&gt;'&lt;/span&gt;&lt;span class="s"&gt;4040:4040'&lt;/span&gt;
    &lt;span class="na"&gt;environment&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
&lt;span class="c1"&gt;#      - PARSE_DASHBOARD_ALLOW_INSECURE_HTTP=true&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_TRUST_PROXY=1&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_COOKIE_SESSION_SECRET=${DASHBOARD_COOKIE_SESSION_SECRET}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_SERVER_URL=${DASHBOARD_SERVER_URL}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_MASTER_KEY=${MASTER_KEY}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_CLIENT_KEY=${CLIENT_KEY}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_APP_ID=${APP_ID}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_APP_NAME=MyParseApp&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_USER_ID=${DASHBOARD_USER_ID}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_USER_PASSWORD=${DASHBOARD_USER_PASSWORD}&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;MOUNT_PATH=/dashboard/&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;PARSE_DASHBOARD_GRAPHQL_SERVER_URL=${DASHBOARD_GRAPHQL_SERVER_URL}&lt;/span&gt;
    &lt;span class="na"&gt;command&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;parse-dashboard --dev&lt;/span&gt;
    &lt;span class="na"&gt;depends_on&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="s"&gt;parse&lt;/span&gt;
&lt;span class="na"&gt;networks&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;app-network&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;driver&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;bridge&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Lo que hacemos es levantar un contenedor de mongodb con las credenciales que nosotros queramos, luego se compila nuestra imagen y se levanta un contenedor con los parámetros de configuración, también levanta un contenedor con &lt;code&gt;parse-dashboard&lt;/code&gt; que es una imagen con el administrador de parse y por último todo se comunica sobre la misma red, y así nos ahorramos tiempo en ejecutar varios comando para realizar la misma operación, por último cabe mencionar que las variables que utiliza docker compose se guardan en un archivo llamado .env que debe ser creado en la raíz del proyecto.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;# .env file example
MONGO_ROOT_USERNAME=root
MONGO_ROOT_PASSWORD=example
APP_ID=parse
MASTER_KEY=parse@master123!
CLIENT_KEY=clientKey
REST_API_KEY=parseRestApiKey
DATABASE_URI=mongodb://root:example@mongo:27017/
DASHBOARD_SERVER_URL=http://localhost:1337/parse/
DASHBOARD_COOKIE_SESSION_SECRET=AB8849B6-D725-4A75-AA73-AB7103F0363F
DASHBOARD_APP_NAME=MyParseApp
DASHBOARD_USER_ID=admin
DASHBOARD_USER_PASSWORD=password
DASHBOARD_GRAPHQL_SERVER_URL=http://localhost:1337/graphql
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Para levantar nuestro docker compose lo podemos hacer con el siguiente comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;docker compose up &lt;span class="nt"&gt;--build&lt;/span&gt; &lt;span class="nt"&gt;--force-recreate&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;El comando anterior no es recomendado en producción, pero si necesitamos más documentación, en internet existen muchos tutoriales de comandos de docker compose en ambientes de producción.&lt;/p&gt;

&lt;p&gt;De este manera tenemos un backend en pocos minutos, ya solo debemos concentrarnos en las funcionalidades de nuestra aplicación, espero y les sirva este pequeño tutorial, tambien dejo el codigo fuente en &lt;a href="https://github.com/kesmile/app-parse-server-backend"&gt;github&lt;/a&gt;, para quien desee consultarlo, tambien estare utilizando este backend con mas articulos que deseo escribir mas adelante.&lt;/p&gt;

</description>
      <category>parseserver</category>
      <category>backend</category>
      <category>spanish</category>
      <category>docker</category>
    </item>
  </channel>
</rss>
