Cuando se ajusta el rendimiento, lo que es más importante:
- ¿Tiempo de CPU o tiempo transcurrido?
- ¿Hay escenarios donde uno de ellos es más importante que el otro?
Un ejemplo: mientras se ajusta el rendimiento, el tiempo de CPU se reducirá en ~ 38%, pero el tiempo transcurrido aumenta en ~ 22%. ¿Es esto una mejora ?
sql-server
performance
performance-tuning
Introduzca el código
fuente
fuente
Respuestas:
El tiempo de CPU es la cantidad de tiempo de procesador que tarda el proceso. Esto no indica duración . El "tiempo transcurrido" representa la duración total de la tarea. Si una tarea dada usa un paralelismo de 8 (es decir, 8 subprocesos), y cada subproceso se usa a una velocidad del 100% durante toda la duración de la tarea, el tiempo de CPU podría ser de 8000 ms, mientras que el tiempo transcurrido solo sería de 1000 ms.
Por lo tanto, un "Tiempo transcurrido" más corto indica un tiempo de respuesta más rápido.
Es posible que desee un tiempo de CPU más corto y un tiempo transcurrido más largo si le preocupa la presión de la CPU y no le importa la experiencia del usuario.
Puede aceptar un tiempo de CPU más largo si eso resulta en una caída en el tiempo transcurrido, ya que eso podría indicar que el usuario está esperando menos, a expensas de una mayor utilización de la CPU.
Podría decirse que la métrica más importante para el ajuste de consultas serían los tiempos de espera .
fuente
Esto depende completamente de lo que esté optimizando y por qué. En el sentido más común, la velocidad de salida de la consulta, esto no es una mejora, como señaló Max Vernon en su respuesta.
Sin embargo, si su sistema está vinculado a la CPU, esto sería una mejora, ya que disminuyó la carga de la CPU. De hecho, si este fuera el caso, el resultado final también podría significar un retorno más rápido del conjunto de resultados.
Y si su sistema estaba vinculado al disco o a la memoria, este sería un resultado neutral, ya que no hay indicios de que haya mejorado o degradado estas medidas.
Entonces, el 95% de las veces, Max es absolutamente correcto, esto no es una mejora. En los pocos casos restantes, puede ser una mejora.
fuente