Comprender y resolver conflictos de dependencias ERESOLVE de npm

Resuelve los conflictos de dependencias de pares ERESOLVE de npm de la manera correcta: identifica el desajuste real, alinea las versiones, usa overrides de forma segura y conoce cuándo pnpm o Yarn son una mejor opción.
Publicado:
Aleksandar Stajić
Updated: 16 de marzo de 2026, 09:12
Comprender y resolver conflictos de dependencias ERESOLVE de npm

Ilustración

Comprendiendo y resolviendo conflictos de dependencias npm ERESOLVE

Un error npm ERESOLVE significa que npm no pudo construir un árbol de dependencias que satisfaga todas las reglas de versión, generalmente debido a las peer dependencies. Desde npm 7, las peer dependencies se manejan estrictamente durante la instalación, por lo que los conflictos que antes se instalaban "de todos modos" ahora fallan rápidamente.

Esa rigurosidad reduce las sorpresas en tiempo de ejecución, pero puede bloquear las instalaciones cuando un paquete espera versiones más antiguas que las de tu proyecto.

Triaje rápido: Encuentra el conflicto real

Antes de forzar nada, identifica quién requiere qué. Estos comandos suelen localizar al culpable en menos de un minuto.

npm -v
node -v

# mostrar cadena de dependencias
npm ls @tensorflow/tfjs
npm ls react

# mostrar requisitos de peer dependencies
npm view @tensorflow-models/handpose peerDependencies

# explicar por qué se eligió una versión
npm explain @tensorflow/tfjs

¿Por qué ocurren los conflictos de peer dependencies?

Las peer dependencies son contratos de compatibilidad. Una librería dice: "Yo no incluyo React / TFJS por mi cuenta; tú debes proporcionar una versión compatible". Los conflictos ocurren cuando dos paquetes exigen rangos de versiones incompatibles.

  • El paquete A requiere @tensorflow/tfjs ^3, pero tu proyecto instala @tensorflow/tfjs@4.
  • Un plugin requiere react@^17, mientras que tu aplicación está en react@18.
  • Mezclaste versiones mayores en una familia de paquetes (por ejemplo, tfjs core v4, backends todavía en v3).

Cómo solucionar npm ERESOLVE (De lo más seguro a lo más agresivo)

1) Alinear versiones (La mejor solución a largo plazo)

Mantén una versión mayor compatible en toda la familia de dependencias. Esta es la solución que sobrevive a la CI, los despliegues y las futuras actualizaciones.

// package.json (ejemplo: alinear la familia tfjs en v3)
{
  "dependencies": {
    "@tensorflow/tfjs": "^3.21.0",
    "@tensorflow/tfjs-backend-webgl": "^3.21.0",
    "@tensorflow/tfjs-backend-cpu": "^3.21.0",
    "@tensorflow-models/handpose": "^0.0.7"
  }
}
rm -rf node_modules package-lock.json
npm install

2) Usar "overrides" de npm (Forzado controlado, npm 8+)

Usa overrides cuando una dependencia transitiva atraiga la versión incorrecta. Esto es más seguro que --force, pero debes probar el comportamiento en tiempo de ejecución.

// package.json
{
  "overrides": {
    "@tensorflow/tfjs": "^4.0.0",
    "@tensorflow/tfjs-backend-webgl": "^4.0.0",
    "@tensorflow/tfjs-backend-cpu": "^4.0.0"
  }
}
rm -rf node_modules package-lock.json
npm install

3) --legacy-peer-deps (Desbloqueo rápido, menos seguridad)

Omite la resolución estricta de pares e instala de todos modos. Bueno para experimentos rápidos; arriesgado como predeterminado en producción.

npm install --legacy-peer-deps

4) --force (Último recurso)

Fuerza una instalación incluso cuando npm sabe que el árbol es inconsistente. Úselo solo si acepta posibles fallos en tiempo de ejecución.

npm install --force

5) Lista de verificación para una instalación limpia (corrige estados extraños del lockfile)

rm -rf node_modules package-lock.json
npm cache verify
npm install

npm vs pnpm vs Yarn: Diferencias prácticas

Los tres pueden tener conflictos de pares, pero difieren en velocidad, estrategia de node_modules y qué tan rápido exponen errores de dependencia "ocultos".

npm (v7+): estricto por defecto

  • Pros: detecta combinaciones de pares incompatibles de forma temprana; CI predecible.
  • Contras: bloquea las instalaciones con más frecuencia; la gente recurre a los flags.
  • Ideal para: equipos que prefieren la corrección estricta sobre la conveniencia.

pnpm: rápido, eficiente en disco, acceso a dependencias más estricto

pnpm utiliza un almacén global direccionable por contenido y enlaza paquetes. Las instalaciones suelen ser más rápidas y utilizan menos disco. Su diseño más estricto puede revelar antes la falta de dependencias directas.

corepack enable
corepack prepare pnpm@latest --activate

pnpm install

Yarn: herramientas sólidas para workspaces, resoluciones flexibles

Yarn es popular en monorepos. Dependiendo de la versión/configuración de Yarn puede parecer más permisivo, pero la gran ventaja son los workspaces y su capacidad para fijar versiones mediante resolutions.

corepack enable
corepack prepare yarn@stable --activate

yarn install

# package.json (Yarn) -> "resolutions": { "react": "18.2.0" }

Conclusión

Para producción: prefiera alinear versiones o overrides controlados. Use --legacy-peer-deps para desbloquear rápidamente y reserve --force como último recurso. Si las instalaciones son lentas o el repositorio es grande, pnpm suele ser una mejora sólida. Si los espacios de trabajo y el anclaje estricto son importantes, Yarn es una buena opción.

Fragmentos para copiar y pegar

# lo más seguro: alinear versiones
rm -rf node_modules package-lock.json
npm install

# controlado: overrides
# package.json -> "overrides": { "pkg": "version" }

# desbloqueo rápido
npm install --legacy-peer-deps

# último recurso
npm install --force

Related Articles

Impulsando la productividad con sistemas ERP: Un estudio de caso sobre bases de datos relacionales

Impulsando la productividad con sistemas ERP: Un estudio de caso sobre bases de datos relacionales

Arquitectura Multi-Inquilino de Grado Empresarial para una Plataforma Internacional

Arquitectura Multi-Inquilino de Grado Empresarial para una Plataforma Internacional

Loving Rocks es una plataforma de bodas de nivel empresarial diseñada con una verdadera arquitectura multiinquilino, bases de datos aisladas por inquilino e internacionalización integrada para escalabilidad global, seguridad y estabilidad operativa a largo plazo.

Cómo instalar PHP 8.3 en Ubuntu 22.04

Cómo instalar PHP 8.3 en Ubuntu 22.04

Guía actualizada para instalar PHP 8.3 en Ubuntu 22.04, incluyendo la integración con Apache y Nginx (PHP-FPM), extensiones y la ejecución de múltiples versiones de PHP en paralelo.

apache-ubuntu-17-10-install-certbot-lets-encrypt

how-to-make-sql-modeno_engine_substitution-permanent-in-mysql-my-cnf

Tendencias emergentes de Linux en 2026: Moldeando el futuro de la infraestructura de servidores

Tendencias emergentes de Linux en 2026: Moldeando el futuro de la infraestructura de servidores

Explora las tendencias clave de Linux de 2026, desde el dominio de Kubernetes y las distribuciones inmutables hasta la integración de IA y la seguridad eBPF.

linux-server-webserver-git-rechteverwaltung

Arquitectura Canónica, Diseño de URL, Lógica del Resolvedor, Especificación de API y Escalabilidad

Arquitectura Canónica, Diseño de URL, Lógica del Resolvedor, Especificación de API y Escalabilidad

Arquitectura de descubrimiento geobasada para portales multi-inquilino. Define URL canónicas, lógica de resolución, estrategia de caché y un modelo de lectura geográfico sin acoplamiento con CMS ni refactorización de base de datos. Diseñada para la estabilidad SEO, la escalabilidad y futuras extensiones como reservas y mapas.

Convertir MOV a MP4 Usando FFmpeg: Una Guía Sencilla

Convertir MOV a MP4 Usando FFmpeg: Una Guía Sencilla

Aprende a convertir videos MOV a MP4 usando FFmpeg con comandos fiables, procesamiento por lotes y optimización de calidad para compatibilidad web, de streaming y multiplataforma.

Marketing de bases de datos – Enfoque moderno para las relaciones con los clientes

Marketing de bases de datos – Enfoque moderno para las relaciones con los clientes

Visión general moderna de marketing de bases de datos: desde la estrategia de datos y la arquitectura técnica hasta la automatización, el RGPD y las mejores prácticas para relaciones sostenibles con los clientes.

Conversión de HEIC a JPG: Por qué deberías considerarla y cómo funciona

Conversión de HEIC a JPG: Por qué deberías considerarla y cómo funciona

HEIC ofrece compresión de imagen moderna y alta calidad, pero JPG sigue siendo el formato más compatible. Esta guía explica cuándo y cómo convertir HEIC a JPG usando herramientas y automatización de Linux.

Guía completa de Evaluation Harness: Dominando la evaluación del rendimiento de LLM

Guía completa de Evaluation Harness: Dominando la evaluación del rendimiento de LLM

Esta guía proporciona un recorrido detallado de Evaluation Harness, un marco de trabajo esencial para evaluar rigurosamente las capacidades de los modelos de lenguaje extensos (LLM) en los pipelines de LLMOps empresariales. Conozca la configuración, las mejores prácticas y las técnicas avanzadas para garantizar una evaluación comparativa y optimización de modelos confiables.