CursosEmpresasBlogLiveConfPrecios

Ciclo de vida de las tareas con FreeRTOS

Clase 16 de 30 • Curso de IoT: Programación de Microcontroladores ESP32

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Introducción a los microcontroladores

    Introducción a los microcontroladores

    10:48 min
  • 2
    La importancia de la industria IoT

    La importancia de la industria IoT

    16:08 min
  • 3
    Tipos de computadoras

    Tipos de computadoras

    12:50 min
  • 4
    Cómo escoger un microcontrolador

    Cómo escoger un microcontrolador

    14:59 min

Hardware

  • 5
    Características del ESP32

    Características del ESP32

    16:15 min

ESP-IDF

  • 6
    Documentación oficial del ESP-IDF

    Documentación oficial del ESP-IDF

    08:43 min
  • 7
    Instalación del ESP-IDF en Windows

    Instalación del ESP-IDF en Windows

    11:06 min
  • 8

    Instalación de ESP-IDF en macOS Ventura con M1 y Python 3.10

    03:46 min
  • 9

    Instalación de ESP-IDF en Ubuntu 22.04 con Python 3.10

    03:42 min
  • 10
    Lista de materiales

    Lista de materiales

    11:50 min
  • 11
    Proyectos con ESP-IDF

    Proyectos con ESP-IDF

    17:12 min
  • 12
    Primer proyecto

    Primer proyecto

    12:28 min

API Core

  • 13
    Hola mundo con ESP-IDF

    Hola mundo con ESP-IDF

    12:27 min
  • 14
    Sistemas Operativos en Tiempo Real

    Sistemas Operativos en Tiempo Real

    08:28 min
  • 15
    FreeRTOS con ESP32

    FreeRTOS con ESP32

    14:48 min
  • 16
    Ciclo de vida de las tareas con FreeRTOS

    Ciclo de vida de las tareas con FreeRTOS

    Viendo ahora
  • 17
    Almacenamiento con ESP32

    Almacenamiento con ESP32

    20:42 min

Peripherals API

  • 18
    Salida Digital con ESP32

    Salida Digital con ESP32

    14:37 min
  • 19
    Entrada Digital con ESP32

    Entrada Digital con ESP32

    13:24 min
  • 20
    Entrada Analógica con ESP32

    Entrada Analógica con ESP32

    19:44 min
  • 21
    Modulación de Ancho de Pulsos

    Modulación de Ancho de Pulsos

    09:20 min
  • 22
    Control PWM con ESP32 y LEDC

    Control PWM con ESP32 y LEDC

    19:47 min

Servidor Web

  • 23
    Redes y protocolos de Internet

    Redes y protocolos de Internet

    18:16 min
  • 24
    Redes WiFi

    Redes WiFi

    07:07 min
  • 25
    Loop de eventos

    Loop de eventos

    05:02 min
  • 26
    Conexión WiFi con ESP32

    Conexión WiFi con ESP32

    18:58 min
  • 27
    Servidor HTTP básico con ESP32

    Servidor HTTP básico con ESP32

    16:36 min

Smart Light

  • 28
    Dimmer LED via HTTP con ESP32

    Dimmer LED via HTTP con ESP32

    28:00 min
  • 29
    Aplicación Web con ESP32

    Aplicación Web con ESP32

    20:02 min

Despedida

  • 30
    Tu primer proyecto de IoT con ESP32

    Tu primer proyecto de IoT con ESP32

    01:23 min
  • Tomar el examen del curso
    • Diana Martinez

      Diana Martinez

      student•
      hace 3 años

      La razón por la que los logs del ejemplo al final, no salen intercalados uno a uno de forma ideal, es porque en la práctica FreeRTOS le asigna un tiempo fijo a cada tarea, por lo que mientras la tarea siga dentro de su tiempo disponible, seguirá ejecutando los printf que le corresponden, hasta que FreeRTOS le de paso a la siguiente.

      Es por eso que vemos varios "Task 1" juntos, luego varios "Task 2" juntos, y así sucesivamente.

        Luis Lagardera

        Luis Lagardera

        student•
        hace 3 años

        Se podría compartir una variable entre las tareas para este caso no? De esta manera una tarea esperaría por la otra y así si podríamos ver Task1 y luego Task2 hasta que se acaben los ciclos.

        Diana Martinez

        Diana Martinez

        student•
        hace 3 años

        Así es, aunque en FreeRTOS existen mecanismos específicos para comunicar tareas, es posible utilizar alguna variable global por ejemplo.

      Victor Armando Avendaño Osorio

      Victor Armando Avendaño Osorio

      student•
      hace 3 años

      Ahí os dejo mi código

      #include <stdio.h> #include "esp_chip_info.h" #include "freertos/FreeRTOS.h" #include "freertos/task.h" TaskHandle_t task1Handle = NULL; TaskHandle_t task1Handle2 = NULL; void task1(void *arg){ unsigned int counter = 0; while(1){ printf("Tarea 1, felicidades, count: %d\n", counter); counter++; if(counter == 5){ printf("tarea 2 suspendida\n"); vTaskSuspend(task1Handle2); } if (counter == 10){ printf("tarea 2 reanudada\n"); vTaskResume(task1Handle2); } if (counter == 15){ printf("tarea 2 eliminada\n"); vTaskDelete(task1Handle2); } if (counter == 15){ printf("tarea 1 finalizada\n"); vTaskDelete(NULL); } vTaskDelay(100 / portTICK_PERIOD_MS); } } void task2(void *arg){ unsigned int counter = 0; while(1){ printf("Tarea 2, felicidades, count: %d\n", counter); counter++; if (counter>15){ printf("tarea 2 finalizada\n"); vTaskDelete(NULL); } vTaskDelay(100 / portTICK_PERIOD_MS); } } void app_main(void) { xTaskCreatePinnedToCore(task1, "task1", 4096, NULL, 10, &task1Handle, 0); xTaskCreatePinnedToCore(task2, "task2", 4096, NULL, 10, &task1Handle2, 1); }

      Le puse un pequeño delay de 100ms porque sin eso algunos printf no salían y parecía que en el tiempo en el que se montaba la tarea 2 en el segundo núcleo le daba tiempo la la tarea 1 de ejecutarse en su totalidad y los log salían muy raro.

        Neftali Larios

        Neftali Larios

        student•
        hace un año

        Excelente aporte porque como lo hizo Diana no veia los mensajes de suspender, resumen y borrar, con tu codigo lo pude ver. Gracias.

      Julio Cardenas

      Julio Cardenas

      student•
      hace 2 años

      Ciclo de vida de las tareas con FreeRTOS

      task_lifecycle.jpg
      Luis Enrique Carreño Herreño

      Luis Enrique Carreño Herreño

      student•
      hace 2 años

      Estoy probando con el LilyGo TTGO LoRa 32, y obtenía la salida:

      I (313) app_start: Starting scheduler on CPU0 I (318) app_start: Starting scheduler on CPU1 I (318) main_task: Started on CPU0 I (328) main_task: Calling app_main() Task 1 count: 1 Task 1 count: 2 Task 1 count: 3 Task 2 suspended I (328) main_task: Returned from app_main() Task 2 count: 1 Task 2 count: 2 Task 2 count: 3 Task 2 count: 4 Task 2 count: 5 Task 2 count: 6 Task 2 count: 7 Task 2 count: 8 Task 2 count: 9 Task 2 count: 10 Task 2 count: 11 Task 2 count: 12 Task 2 count: 13 Task 2 count: 14 Task 2 count: 15 Task 2 deleted

      No se ve que la tarea 1 no controla la tarea. 2, ya que se la tarea 2 sigue ejecutándose después de que la tarea 1 la suspende, así que agregué al final del while de cada tarea un delay:

      while (1) { ... vTaskDelay(pdMS_TO_TICKS(100)); }

      Y de esa forma ya funciona como debe:

      I (313) app_start: Starting scheduler on CPU0 I (318) app_start: Starting scheduler on CPU1 I (318) main_task: Started on CPU0 I (328) main_task: Calling app_main() Task 1 count: 1 I (328) main_task: Returned from app_main() Task 2 count: 1 Task 1 count: 2 Task 2 count: 2 Task 1 count: 3 Task 2 suspended Task 1 count: 4 Task 1 count: 5 Task 1 count: 6 Task 1 count: 7 Task 1 count: 8 Task 1 count: 9 Task 1 count: 10 Task 2 resumed Task 2 count: 3 Task 1 count: 11 Task 2 count: 4 Task 1 count: 12 Task 2 deleted Task 1 count: 13 Task 1 count: 14 Task 1 count: 15 Task 1 deleted
        ALEJANDRO OLGUIN

        ALEJANDRO OLGUIN

        student•
        hace 2 años

        Gracias !

        Rogelio Meza

        Rogelio Meza

        student•
        hace un año

        En la esp32 CAM me paso exactamente lo mismo y de igual forma se arreglo solo con la linea vTaskDelay(pdMS_TO_TICKS(100));

        Muchisimas gracias c:

      Mariana Valencia Gallego

      Mariana Valencia Gallego

      student•
      hace 3 años

      En mi vida soy el core 1 entrando en pánico ;')

      Luis Ariel Torres

      Luis Ariel Torres

      student•
      hace 2 años

      Si task1 se ejecuta en el core 0 y task2 en el 1. ¿Cómo se arreglan los dos cores para compartir un recurso unico como es la UART?

        Diana Martinez

        Diana Martinez

        student•
        hace 2 años

        Todo eso lo coordina el sistema operativo, justo el trabajo de un sistema operativo es administrar los recursos, y pues del mismo modo que con las tareas, se pausa una y se permite la otra, o se puede tener una tarea dedicada (que también se pausará), pero en lugar de leer directamente al hardware, las demás intercambiarán mensajes con la única tarea que si lo hace.

        Diana Martinez

        Diana Martinez

        student•
        hace 2 años

        Con un FreeRTOS limpio (no el modificado por ESP-IDF), podrías configurar todos los parámetros de comportamiento del RTOS a tu gusto, pero en este caso se podrían configurar algunas cosas con el menuconfig.

      Andres Esteban Andrews Castillo

      Andres Esteban Andrews Castillo

      student•
      hace 3 años

      ¿cómo puedo detener el ciclo infinito desde la terminar? para no tener que cerrar y volver a abirla.

        Diana Martinez

        Diana Martinez

        student•
        hace 3 años

        En windows es Ctrl + ]

        Jesús Ramon

        Jesús Ramon

        student•
        hace 3 años

        y en linux?

      Juan Sebatian Ariza

      Juan Sebatian Ariza

      student•
      hace 2 años

      tengo una duda, no he logrado hacer que corra dos treas al tiempo, es muy curioso que cuando el conntador llega a 3 es cuando empieza la tarea 2, no se si sera un problema de mi placa o que pueda estr sucediendo.

      esta es la salida que obtengo con el monitor:

      Task 1 count: 1 Task 1 count: 2 Task 1 count: 3 Task 2 suspend I (332) main_task: Returned from app_main() Task 2 count: 1 Task 2 count: 2 Task 2 count: 3 Task 2 count: 4 Task 2 count: 5 Task 2 count: 6 Task 2 count: 7 Task 2 count: 8 Task 2 count: 9 Task 2 count: 10 Task 2 count: 11 Task 2 count: 12 Task 2 count: 13 Task 2 count: 14 Task 2 count: 15
        Diana Martinez

        Diana Martinez

        student•
        hace 2 años

        Creo que podría estarte faltando un delay o un delete, porque al parecer se está reiniciando tu aplicación, y eso pasa principalmente cuando una tarea se queda con todos los recursos y el kernel tiene que sacarla de ahí.

        Daniel Lopez Piña

        Daniel Lopez Piña

        student•
        hace un año

        Sigo teniendo el mismo problema, ya puse los delay y se me cicla la salida.

      Andrés González

      Andrés González

      student•
      hace 9 meses

      No logré que se ejecutaran en paralelo no lo sé

      #include <stdio.h>#include "freertos/FreeRTOS.h"#include "freertos/task.h" TaskHandle_t taskHandle1 = NULL;TaskHandle_t taskHandle2 = NULL; void task1(void *args){    int count = 0;    while(1){        count++;        printf("Task #1; count: %d\n", count);        if(count == 3 && taskHandle2 != NULL){            vTaskSuspend(taskHandle2);            printf("Task #2 suspend\n");        }        if(count == 10 && taskHandle2 != NULL){            vTaskResume(taskHandle2);            printf("Task #2 resume\n");        }        if(count == 12 && taskHandle2 != NULL){            vTaskDelete(taskHandle2);            printf("Task #2 delete\n");        }        if(count >= 15){            printf("Task #1 Ok\n");            vTaskDelete(NULL);        }    }} void task2(void *args){    int count = 0;    while(1){        count++;        printf("Task #2; count: %d\n", count);         if(count >= 15){            vTaskDelete(NULL);        }    }} void app_main(void){    // Parametros:     //      función,     //      nombre de la tarea,     //      espacio reservado en memoria,    //      datos iniciales de la tarea,    //      prioridad de la tarea,    //      Almacenar la tarea para manipularla,    //      # de Core        xTaskCreate(task1, "task1", 4096, NULL, 10, &taskHandle1); // Core 0 por defecto    xTaskCreatePinnedToCore(task2, "task2", 4096, NULL, 10, &taskHandle2, 1);}

      Gabriel Obregón

      Gabriel Obregón

      student•
      hace 9 meses

      eRTOS 

      Manejo de Tareas en FreeRTOS con ESP32

      En este documento, exploraremos cómo crear, pausar, reanudar y eliminar tareas en FreeRTOS utilizando un ESP32. También veremos cómo asignar tareas a diferentes núcleos del procesador y corregiremos errores comunes para evitar reinicios inesperados.

      1. Creación de Tareas

      Para iniciar, creamos una tarea simple que cuenta hasta 5 antes de eliminarse:

      #include <stdio.h>

      #include "freertos/FreeRTOS.h"

      #include "freertos/task.h"

      TaskHandle_t taskHandle1 = NULL;

      void task1(void *args) {

          int count = 0;

          while (1) {

              count++;

              printf("Task 1 count: %d\n", count);

              if (count > 5) {

                  vTaskDelete(NULL);

              }

          }

      }

      void app_main(void)

      {

          xTaskCreate(task1, "task1", 4096, NULL, 10, &taskHandle1);

      }

      Este código crea una tarea que se ejecuta en un bucle hasta que count supera 5, momento en el cual se elimina.

      2. Creación de una Segunda Tarea

      Para agregar una segunda tarea, modificamos el código para incluir task2:

      TaskHandle_t taskHandle2 = NULL;

      void task2(void *args) {

          int count = 0;

          while (1) {

              count++;

              printf("Task 2 count: %d\n", count);

          }

      }

      void app_main(void)

      {

          xTaskCreate(task1, "task1", 4096, NULL, 10, &taskHandle1);

          xTaskCreate(task2, "task2", 4096, NULL, 10, &taskHandle2);

      }

      Ahora, tenemos dos tareas ejecutándose en paralelo con la misma prioridad.

      3. Asignación de Tareas a Diferentes Núcleos

      Podemos ejecutar task2 en el segundo núcleo del ESP32 utilizando xTaskCreatePinnedToCore:

      void app_main(void)

      {

          xTaskCreate(task1, "task1", 4096, NULL, 10, &taskHandle1);

          xTaskCreatePinnedToCore(task2, "task2", 4096, NULL, 10, &taskHandle2, 1);

      }

      De esta manera, task1 se ejecuta en el núcleo 0 y task2 en el núcleo 1.

      4. Control de Ejecución de Tareas

      Ahora, task1 controlará la ejecución de task2. La lógica es la siguiente:

      • Cuando task1 llega a 3, suspende task2.
      • Cuando task1 llega a 10, reanuda task2.
      • Cuando task1 llega a 12, elimina task2.
      • Cuando task1 llega a 15, se elimina a sí misma.

      Código actualizado:

      void task1(void *args) {

          int count = 0;

          while (1) {

              count++;

              printf("Task 1 count: %d\n", count);

              if (count == 3) {

                  vTaskSuspend(taskHandle2);

                  printf("Task 2 suspended\n");

              }

              if (count == 10) {

                  vTaskResume(taskHandle2);

                  printf("Task 2 resumed\n");

              }

              if (count == 12) {

                  vTaskDelete(taskHandle2);

                  printf("Task 2 deleted\n");

              }

              if (count == 15) {

                  printf("Task 1 deleted\n");

                  vTaskDelete(NULL);

              }

          }

      }

      Este código permite que task1 gestione task2 de manera controlada.

      5. Compilación y Ejecución

      Para compilar y subir el código al ESP32, ejecutamos en la terminal:

      idf.py build

      idf.py -p COM3 flash

      idf.py -p COM3 monitor

      Observaremos la ejecución en el monitor serie, donde task1 contará y suspenderá, reanudará y eliminará task2 en los momentos adecuados.

      6. Consideraciones Finales

      • Evita el uso de >= en los condicionales para evitar ejecuciones repetidas y errores de kernel.
      • Las impresiones pueden no aparecer en orden exacto, ya que FreeRTOS ejecuta tareas lo más rápido posible.
      • Asignar tareas a núcleos específicos puede mejorar el rendimiento, pero requiere planificación.

      Este ejercicio nos ayuda a comprender cómo FreeRTOS maneja tareas y cómo podemos controlarlas eficientemente.

      Julio Cardenas

      Julio Cardenas

      student•
      hace 2 años

      Este es mi codigo utilizando vTaskDelay

      #include <stdio.h> #include "freertos/FreeRTOS.h" #include "freertos/task.h" #include "time.h" TaskHandle_t taskHandle_1; TaskHandle_t taskHandle_2; const TickType_t taskDelay_1 = 500 / portTICK_PERIOD_MS; const TickType_t taskDelay_2 = 700 / portTICK_PERIOD_MS; time_t elapsed_time_1; time_t elapsed_time_2; int counter_1 = 0; int counter_2 = 0; void task_1(void *args) { while (true) { time(&elapsed_time_1); printf("Task 1 counter: %d seconds: %lld\n", counter_1, elapsed_time_1); counter_1++; vTaskDelay(taskDelay_1); switch (counter_1) { case 10: printf("Suspendiendo la tarea 2\n"); vTaskSuspend(taskHandle_2); break; case 20: printf("Resumiendo la tarea 2\n"); vTaskResume(taskHandle_2); break; case 30: printf("Eliminando la tarea 2\n"); vTaskDelete(taskHandle_2); break; case 50 ... 60: printf("Eliminando la tarea 1\n"); vTaskDelete(taskHandle_1); break; default: break; }; } } void task_2(void *args) { while (true) { time(&elapsed_time_2); printf("Task 2 counter: %d seconds: %lld\n", counter_2, elapsed_time_2); counter_2++; vTaskDelay(taskDelay_2); if (counter_2 > 50) { printf("Finalizando la tarea 2\n"); vTaskDelete(taskHandle_2); } } } void app_main(void) { xTaskCreate( task_1, //Nombre de la funcion que implementa la tarea "Tarea_1", //Nombre descriptivo de la tarea con fines de debugging 4096, //El tamaño del task stack en bytes NULL, //pointer a un parametro cuando la tarea esta siendo creada 10, //Prioridad de la tarea un numero &taskHandle_1 //apuntador para referenciar la tarea. ); //creamos la tarea asociandola al segundo core xTaskCreatePinnedToCore( task_2, //Nombre de la funcion que implementa la tarea "Tarea_2", //Nombre descriptivo de la tarea con fines de debugging 4096, //El tamaño del task stack en bytes NULL, //pointer a un parametro cuando la tarea esta siendo creada 10, //Prioridad de la tarea un numero &taskHandle_2, //apuntador para referenciar la tarea. 1 // core 0 y core 1 ); }

    Escuelas

    • Desarrollo Web
      • Fundamentos del Desarrollo Web Profesional
      • Diseño y Desarrollo Frontend
      • Desarrollo Frontend con JavaScript
      • Desarrollo Frontend con Vue.js
      • Desarrollo Frontend con Angular
      • Desarrollo Frontend con React.js
      • Desarrollo Backend con Node.js
      • Desarrollo Backend con Python
      • Desarrollo Backend con Java
      • Desarrollo Backend con PHP
      • Desarrollo Backend con Ruby
      • Bases de Datos para Web
      • Seguridad Web & API
      • Testing Automatizado y QA para Web
      • Arquitecturas Web Modernas y Escalabilidad
      • DevOps y Cloud para Desarrolladores Web
    • English Academy
      • Inglés Básico A1
      • Inglés Básico A2
      • Inglés Intermedio B1
      • Inglés Intermedio Alto B2
      • Inglés Avanzado C1
      • Inglés para Propósitos Específicos
      • Inglés de Negocios
    • Marketing Digital
      • Fundamentos de Marketing Digital
      • Marketing de Contenidos y Redacción Persuasiva
      • SEO y Posicionamiento Web
      • Social Media Marketing y Community Management
      • Publicidad Digital y Paid Media
      • Analítica Digital y Optimización (CRO)
      • Estrategia de Marketing y Growth
      • Marketing de Marca y Comunicación Estratégica
      • Marketing para E-commerce
      • Marketing B2B
      • Inteligencia Artificial Aplicada al Marketing
      • Automatización del Marketing
      • Marca Personal y Marketing Freelance
      • Ventas y Experiencia del Cliente
      • Creación de Contenido para Redes Sociales
    • Inteligencia Artificial y Data Science
      • Fundamentos de Data Science y AI
      • Análisis y Visualización de Datos
      • Machine Learning y Deep Learning
      • Data Engineer
      • Inteligencia Artificial para la Productividad
      • Desarrollo de Aplicaciones con IA
      • AI Software Engineer
    • Ciberseguridad
      • Fundamentos de Ciberseguridad
      • Hacking Ético y Pentesting (Red Team)
      • Análisis de Malware e Ingeniería Forense
      • Seguridad Defensiva y Cumplimiento (Blue Team)
      • Ciberseguridad Estratégica
    • Liderazgo y Habilidades Blandas
      • Fundamentos de Habilidades Profesionales
      • Liderazgo y Gestión de Equipos
      • Comunicación Avanzada y Oratoria
      • Negociación y Resolución de Conflictos
      • Inteligencia Emocional y Autogestión
      • Productividad y Herramientas Digitales
      • Gestión de Proyectos y Metodologías Ágiles
      • Desarrollo de Carrera y Marca Personal
      • Diversidad, Inclusión y Entorno Laboral Saludable
      • Filosofía y Estrategia para Líderes
    • Diseño de Producto y UX
      • Fundamentos de Diseño UX/UI
      • Investigación de Usuarios (UX Research)
      • Arquitectura de Información y Usabilidad
      • Diseño de Interfaces y Prototipado (UI Design)
      • Sistemas de Diseño y DesignOps
      • Redacción UX (UX Writing)
      • Creatividad e Innovación en Diseño
      • Diseño Accesible e Inclusivo
      • Diseño Asistido por Inteligencia Artificial
      • Gestión de Producto y Liderazgo en Diseño
      • Diseño de Interacciones Emergentes (VUI/VR)
      • Desarrollo Web para Diseñadores
      • Diseño y Prototipado No-Code
    • Contenido Audiovisual
      • Fundamentos de Producción Audiovisual
      • Producción de Video para Plataformas Digitales
      • Producción de Audio y Podcast
      • Fotografía y Diseño Gráfico para Contenido Digital
      • Motion Graphics y Animación
      • Contenido Interactivo y Realidad Aumentada
      • Estrategia, Marketing y Monetización de Contenidos
    • Desarrollo Móvil
      • Fundamentos de Desarrollo Móvil
      • Desarrollo Nativo Android con Kotlin
      • Desarrollo Nativo iOS con Swift
      • Desarrollo Multiplataforma con React Native
      • Desarrollo Multiplataforma con Flutter
      • Arquitectura y Patrones de Diseño Móvil
      • Integración de APIs y Persistencia Móvil
      • Testing y Despliegue en Móvil
      • Diseño UX/UI para Móviles
    • Diseño Gráfico y Arte Digital
      • Fundamentos del Diseño Gráfico y Digital
      • Diseño de Identidad Visual y Branding
      • Ilustración Digital y Arte Conceptual
      • Diseño Editorial y de Empaques
      • Motion Graphics y Animación 3D
      • Diseño Gráfico Asistido por Inteligencia Artificial
      • Creatividad e Innovación en Diseño
    • Programación
      • Fundamentos de Programación e Ingeniería de Software
      • Herramientas de IA para el trabajo
      • Matemáticas para Programación
      • Programación con Python
      • Programación con JavaScript
      • Programación con TypeScript
      • Programación Orientada a Objetos con Java
      • Desarrollo con C# y .NET
      • Programación con PHP
      • Programación con Go y Rust
      • Programación Móvil con Swift y Kotlin
      • Programación con C y C++
      • Administración Básica de Servidores Linux
    • Negocios
      • Fundamentos de Negocios y Emprendimiento
      • Estrategia y Crecimiento Empresarial
      • Finanzas Personales y Corporativas
      • Inversión en Mercados Financieros
      • Ventas, CRM y Experiencia del Cliente
      • Operaciones, Logística y E-commerce
      • Gestión de Proyectos y Metodologías Ágiles
      • Aspectos Legales y Cumplimiento
      • Habilidades Directivas y Crecimiento Profesional
      • Diversidad e Inclusión en el Entorno Laboral
      • Herramientas Digitales y Automatización para Negocios
    • Blockchain y Web3
      • Fundamentos de Blockchain y Web3
      • Desarrollo de Smart Contracts y dApps
      • Finanzas Descentralizadas (DeFi)
      • NFTs y Economía de Creadores
      • Seguridad Blockchain
      • Ecosistemas Blockchain Alternativos (No-EVM)
      • Producto, Marketing y Legal en Web3
    • Recursos Humanos
      • Fundamentos y Cultura Organizacional en RRHH
      • Atracción y Selección de Talento
      • Cultura y Employee Experience
      • Gestión y Desarrollo de Talento
      • Desarrollo y Evaluación de Liderazgo
      • Diversidad, Equidad e Inclusión
      • AI y Automatización en Recursos Humanos
      • Tecnología y Automatización en RRHH
    • Finanzas e Inversiones
      • Fundamentos de Finanzas Personales y Corporativas
      • Análisis y Valoración Financiera
      • Inversión y Mercados de Capitales
      • Finanzas Descentralizadas (DeFi) y Criptoactivos
      • Finanzas y Estrategia para Startups
      • Inteligencia Artificial Aplicada a Finanzas
      • Domina Excel
      • Financial Analyst
      • Conseguir trabajo en Finanzas e Inversiones
    • Startups
      • Fundamentos y Validación de Ideas
      • Estrategia de Negocio y Product-Market Fit
      • Desarrollo de Producto y Operaciones Lean
      • Finanzas, Legal y Fundraising
      • Marketing, Ventas y Growth para Startups
      • Cultura, Talento y Liderazgo
      • Finanzas y Operaciones en Ecommerce
      • Startups Web3 y Blockchain
      • Startups con Impacto Social
      • Expansión y Ecosistema Startup
    • Cloud Computing y DevOps
      • Fundamentos de Cloud y DevOps
      • Administración de Servidores Linux
      • Contenerización y Orquestación
      • Infraestructura como Código (IaC) y CI/CD
      • Amazon Web Services
      • Microsoft Azure
      • Serverless y Observabilidad
      • Certificaciones Cloud (Preparación)
      • Plataforma Cloud GCP

    Platzi y comunidad

    • Platzi Business
    • Live Classes
    • Lanzamientos
    • Executive Program
    • Trabaja con nosotros
    • Podcast

    Recursos

    • Manual de Marca

    Soporte

    • Preguntas Frecuentes
    • Contáctanos

    Legal

    • Términos y Condiciones
    • Privacidad
    • Tyc promociones
    Reconocimientos
    Reconocimientos
    Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
    Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
    Logo reconocimientoPrimera Startup EdTech · 2018
    Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
    Logo reconocimientoCEO Mejor Emprendedor del año · 2024
    De LATAM conpara el mundo
    YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads