-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
High performance setup es ES
Esto es exactamente lo contrario de la configuración de bajo uso de memoria y normalmente quieres seguir esos consejos si quieres aumentar el rendimiento de ASF (en términos de velocidad de CPU), por el potencial costo de mayor uso de memoria.
ASF ya intenta preferir el rendimiento cuando se trata de un ajuste general equilibrado, por lo tanto no hay mucho que puedas hacer para aumentar su rendimiento, aunque tampoco estás completamente fuera de opciones. Sin embargo, ten en cuenta que esas opciones no están habilitadas por defecto, lo que significa que no son lo suficientemente buenas para considerarlas equilibradas para la mayoría de los usos, por lo tanto debes decidir si el uso aumentado de memoria que ofrecen es aceptable para ti.
Lo siguientes trucos involucran un serio aumento de uso de memoria y deben ser usados con precaución.
.NET Core runtime te permite modificar el recolector de basura de muchas formas, afinando eficazmente el proceso de recolección de basura de acuerdo a tus necesidades.
La forma recomendada de aplicar estas configuraciones es a través de las propiedades de entorno COMPlus_
. Por supuesto, también podrías usar otros métodos, por ejemplo, runtimeconfig.json
, pero algunas configuraciones son imposibles de establecer de esta manera, encima de eso ASF reemplazará tu runtimeconfig.json
personalizado en la siguiente actualización, por lo tanto recomendamos propiedades de entorno que puedas establecer fácilmente antes de ejecutar el proceso.
Consulta la documentación para todas las propiedades que puedes utilizar, a continuación mencionaremos las más importantes (en nuestra opinión):
Configura si la aplicación utiliza la recolección de basura de la estación de trabajo o la recolección de basura del servidor.
Puedes leer los específicos de la recolección de basura de servidor (server GC) en fundamentos de la recolección de basura.
ASF usa la recolección de basura de estación de trabajo por defecto. Esto se debe principalmente a un buen equilibrio entre uso de memoria y rendimiento, lo que es más que suficiente para solo unos bots, y normalmente un solo hilo GC concurrente en segundo plano es lo suficientemente rápido para manejar toda la memoria asignada por ASF.
Sin embargo, hoy tenemos muchos núcleos de CPU de los que ASF se puede beneficiarse en gran medida, teniendo un hilo GC dedicado por cada CPU vCore que esté disponible. Esto puede mejorar enormemente el rendimiento durante tareas pesadas de ASF tal como analizar las páginas de inventario o el inventario, ya que cada CPU vCore puede ayudar, en lugar de solo 2 (principal y GC). Servidor GC se recomienda para máquinas con 3 CPU vCores y más, estación de trabajo GC es forzado automáticamente si tu máquina solo tiene 1 CPU vCore, si tienes exactamente 2 entonces puedes considerar probar ambos (los resultados pueden variar).
El servidor GC en sí no da como resultado un aumento de la memoria muy grande solo por estar activo, pero tiene tamaños de generación mucho más grandes, y por lo tanto es mucho más perezoso cuando se trata de devolver memoria al sistema operativo. Puede que te encuentres en un buen lugar donde el servidor GC aumenta su rendimiento significativamente y te gustaría seguir usándolo, pero al mismo tiempo no puedes permitirte ese gran aumento de memoria que viene con su uso. Afortunadamente, hay una configuración que tiene lo "mejor de ambos mundos", usando la recolección de basura del servidor (server GC) con la propiedad de configuración GCLatencyLevel
establecida a 0
, lo que habilitará la recolección de elementos no utilizados del servidor, pero limitará la generación de tamaños y se enfocará más en la memoria. Alternativamente, también puedes experimentar con otra propiedad, GCHeapHardLimitPercent
, o incluso con ambas al mismo tiempo.
Sin embargo, si la memoria no es un problema (ya que la recolección de elementos no utilizados toma en cuenta la memoria disponible y se ajusta automáticamente), es mucho mejor idea no cambiar esas propiedades, logrando un mejor rendimiento como resultado.
Puedes habilitar todas las propiedades del recolector de basura (GC) estableciendo las variables de entorno COMPlus_
apropiadas. Por ejemplo, en Linux (shell):
export COMPlus_gcServer=1
./ArchiSteamFarm # For OS-specific build
O en Windows (powershell):
$Env:COMPlus_gcServer=1
.\ArchiSteamFarm.exe # For OS-specific build
- Asegúrate de que estás el valor predeterminado de
OptimizationMode
que esMaxPerformance
. Este es por mucho el ajuste más importante, ya que usar el valorMinMemoryUsage
tiene efectos dramáticos en el rendimiento. - Habilita la recolección de basura del servidor. La recolección de basura del servidor (server GC) se puede ver como activa inmediatamente por un aumento significativo de la memoria en comparación con la recolección de basura de la estación de trabajo (workstation GC).
- Si no puedes permitirte ese incremento de memoria, considera ajustar
GCLatencyLevel
y/oGCHeapHardLimitPercent
para lograr lo "mejor de ambos mundos". Sin embargo, si tu memoria se lo puede permitir, entonces es mejor mantenerlo en predeterminado - servidor GC ya se ajusta a sí mismo durante runtime y es lo suficientemente inteligente para usar menos memoria cuando tu sistema operativo realmente lo necesite.
Si habilitaste la recolección de elementos no utilizados del servidor (server GC) y dejaste las otras propiedades de configuración en sus valores por defecto, entonces tienes un rendimiento superior de ASF que debería funcionar muy rápido incluso con cientos o miles de bots activos. La CPU ya no debe hacer cuello de botella, ya que ASF es capaz de usar todo el poder de CPU cuando sea necesario, reduciendo el tiempo requerido al mínimo. El siguiente paso sería actualizar la CPU y RAM.
- 🏡 Inicio
- 🔧 Configuración
- 💬 Preguntas frecuentes
- ⚙️ Instalación (empezar aquí)
- 👥 Activador de juegos en segundo plano
- 📢 Comandos
- 🛠️ Compatibilidad
- 🧩 ItemsMatcherPlugin
- 📋 Gestión
- ⏱️ Rendimiento
- 📡 Comunicación remota
- 👪 Préstamo familiar de Steam
- 🔄 Intercambios
- ⌨️ Argumentos de la línea de comandos
- 🚧 Obsolescencia
- 🐳 Docker
- 🤔 Preguntas frecuentes adicionales
- 🚀 Configuración de alto rendimiento
- 🔗 IPC
- 🌐 Localización
- 📝 Registro
- 💾 Configuración de poca memoria
- 🕵🏼♂️ MonitoringPlugin
- 🔌 Plugins
- 🔐 Seguridad
- 🧩 SteamTokenDumperPlugin
- 📦 Aplicaciones de terceros
- 📵 Autenticación de dos factores