SlideShare una empresa de Scribd logo
1 de 24
Descargar para leer sin conexión
Rendimiento en Magento

   Manel R. Doménech (@manelio)
    Socio fundador de @onestic



@onestic                @SoporteMagento
Contenidos (1/2)
• Instalación básica de Magento.
• El sistema
  – Apache o nginx
  – PHP, APC, php-fpm
  – MySQL
• Primeras mejoras: sistema interno de caché.
• Sesiones: ¿dónde almacenarlas?
• Detección de cuellos de botella.
Contenidos (2/2)
• Precauciones con los módulos
• Benchmarking. Pruebas de carga.
• Caché externa y servicios externos
  – Ezapps_Zoom
  – Phoenix_VarnishCache
  – Cloudflare
• Escalado de infraestructura
Instalación básica de Magento
                          Sistema: Virtual. Intel Xeon
                          E5410, 4 cores. 4GB RAM.
                          50GB HD.


                          - Catálogo de   8 productos

- Cachés deshabilitadas          - Cachés habilitadas

Tiempo de carga de una           Tiempo de carga de una
página de catálogo               página de catálogo

2.35s                            .8s
Instalación básica de Magento

• Con 40K referencias la cosa cambia. Con
  cachés habilitadas:
  – Para una petición:
     • Tiempo medio de respuesta: 4s
     • Ratio de transacciones: .25 t/s
  – Para 10 peticiones concurrentes:
     • Tiempo medio de respuesta: 6.86s
     • Ratio de transacciones: 0.93 t/s
     • Concurrencia: 6.38
El sistema
• Apache o nginx: con nginx + php-fpm
  obtenemos un rendimiento mucho más
  elevado
• PHP
  – PHP 5.3
  – APC, imprescindible
• MySQL: para alto tráfico o gran cantidad de
  productos, se convierte en el cuello de botella.
Primeras mejoras: sistema interno
            de caché
• Uso intensivo de ficheros de configuración XML que Magento debe
  mezclar
• Bloques HTML
• Traducciones
• Colecciones
• Atributos y tipos EAV


      ¿Dónde almacenar esta información cacheada?

  ¡Cuidado con el uso de caché en disco y las invalidaciones de
                            caché!
Primeras mejoras: sistema interno
           de caché
• Motores de caché
  – Ficheros
  – Base de datos
  – Memoria (memcached, redis)
  – Híbrido, usando dos niveles de caché


              En nuestra experiencia,
  los mejores resultados los obtenemos con redis
Primeras mejoras: sistema interno
            de caché
• Flat tables: flat catalog, ¿siempre?
• Cuidado con la sobrecarga que añade el reindexado
  de tablas, especialmente las tablas de catálogo
  cuando éste es grande y las escrituras muy
  frecuentes. Por ejemplo, módulos de drop shipping.
• Cuidado también con las consultas de búsqueda
  fulltext. Conviene usar un motor especializado: solr,
  sphinx, lucene, elasticsearch.
Sesiones: ¿dónde almacenarlas?
• Cuando la base de datos se convierte en un
  cuello de botella, almacenar las sesiones en
  ella puede complicar aún más la situación.
• Por otro lado, si se opta por mantener
  diferentes servidores de frontend, es una
  forma de centralizar las sesiones.
• En este último caso es preferible utilizar
  memcached o redis para almacenar sesiones.
Detección de cuellos de botella
class OnProfiler {
   var $log = "/tmp/profile.log";
   static $t0 = 0;
                                                                      Método de ir por casa,
  function __construct($conf) {
    foreach($conf as $k => $v) $this->$k = $v;                        pero eficaz.
    self::$t0 = microtime(true);
    register_shutdown_function(array($this, 'shutdown'));
  }

  function shutdown() {
    $t1 = microtime(true); $tdelta = $t1 - self::$t0;
    $peak = memory_get_peak_usage(true);
    $this->log(date('Y-m-d H:i:s')."t".sprintf("%.2ft%.2f", $tdelta, $peak/1024/1024)."t".$_SERVER['REQUEST_URI']);
  }

  function log($str) {
    $f = fopen($this->log, "a"); fwrite($f, $str."n"); fclose($f);
  }
}
$prof = new OnProfiler(array('log' => '/tmp/profile.log',));
Detección de cuellos de botella
if ($_GET['_profile'] == 1) :
define('XHPROF_ROOT','/opt/xhprof-0.9.2');
xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);

function onprofiler__shutdown_function() {
  $xhprof_data = xhprof_disable();                                      Xhprof fácil y cómodo
  include_once XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
  include_once XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";
  $xhprof_runs = new XHProfRuns_Default();
  $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");

echo <<<EOT
<div style="background-color: #FFFFFF; border: 1px solid red;
  padding: 10px; position: fixed;
  right: 10px; top: 53px;
  width: 300px; z-index: 100000;">
<h3>XHProf</h3>
<a href="http://xhprof.dev1.onestic.com/index.php?run=$run_id&source=xhprof_foo" target="_blank">view profile</a>
</div>
EOT;
}
register_shutdown_function("onprofiler__shutdown_function");
endif;
Detección de cuellos de botella
 • Ejemplo de resultado obtenido con xhprof
-> Mage_Catalog_Block_Product_List::getCountAllVendorProducts 20 10.3% 1,872,247 37.4% 565,912 19.9% 1,963,544 7.0% 853,464 3.0%

Las llamadas a este método duran 1.9s, de una duración total de 5.0s. Esto es un 37.4% de tiempo perdido contando los productos de
los vendedores.

-> Mage_Catalog_Block_Product_List_Toolbar::getLastPageNum 4 14.8% 145,695 2.9% 1,000 0.0% 19,976 0.1% 26,928 0.1%

En este caso, para obtener el último número de página de la lista de productos, se consumen 0.15s, un 2.9% del total.

-> Mage_Catalog_Block_Product_List::_beforeToHtml 1 2.9% 495,733 9.9% 85,986 3.0% 1,929,848 6.9% 1,513,256 5.3%

Casi lo mismo ocurre antes de renderizar la lista de productos: 0.50s, que es un 9.9% del total

-> AW_Sarp_Block_Catalog_Product_Price::getProduct 20 14.8% 621,377 12.4% 486,925 17.1% 2,533,088 9.0% 2,758,320 9.7%

Esta llamada consume 0.62s, un 12.4% del total.

-> Unirgy_Dropship_Helper_Data::loadCustomData 731 1.7% 649,759 13.0% 664,902 23.4% 6,912,152 24.6% 176,320 0.6%

Esta llamada consume 0.65s, un 13.0% del total.

13.0 + 12.4 + 9.9 + 2.9 + 37.4 = 75.6

Las llamadas a las anteriores funciones están suponiendo un 75.6% de la carga de la página. 3.79s
Detección de cuellos de botella
• Una vez identificados los cuellos de botella, es
  el momento de corregirlos. Casos habituales:
  – Consultas sin índices sobre tablas de módulos
  – Abuso de llamadas a funciones en vez de
    precalcular y reutilizar
  – Necesidad de cacheo de bloques costosos, como
    el de precio
  – Separar el renderizado de los ítems en las listas
    productos, y cachear estos bloques.
Detección de cuellos de botella
• Onestic_Profiler. Uso de redis para cálculo de
  acumulados de tiempo, memoria y consultas.
• Detalle de acumulados por bloque:
++++            renderView: frontend/default/agroterra/template/catalog/product/list/toolbarbottom.phtml
+++++             renderView: frontend/default/agroterra/template/page/html/pager.phtml
- - - - - 0.00183 renderView: frontend/default/agroterra/template/page/html/pager.phtml
- - - - 0.00380 renderView: frontend/default/agroterra/template/catalog/product/list/toolbarbottom.phtml
- - - 0.80834 renderView: frontend/default/agroterra/template/catalog/product/list.phtml
- - 1.27292 renderView: frontend/default/agroterra/template/catalog/category/view.phtml
Precauciones con los módulos
• Hay módulos que crean tablas, modifican
  consultas o añaden joins y no siempre hacen
  hincapié en el rendimiento. El problema
  puede no verse hasta que el tráfico crece o el
  catálogo aumenta.
• Cuidado con las colisiones de rewrites de
  clases. Ejemplo: Ashroeder_SMTPPro /
  Ebizmarts_Mailchimp
… ahora parece que Magento está
en forma sin el uso de esteroides
          anabólicos …




       ¡A reventarlo!
Benchmarking. Pruebas de carga.
• Multitud de herramientas
  – F5
  – Apache benchmark
  – BadBoy / Jmeter
  – Siege
     • Simula una serie de peticiones a la aplicación indicando
       el concurrencia, tiempo entre peticiones, repeticiones
       de la prueba y un fichero de URLs.
Benchmarking. Pruebas de carga.
 • Siege
    – Invocación
     siege -m "5:c100,d1,r1,tractores" -v 
     --log=$HOME/log/domain.com-siege.log 
     -c 100 -d 1 -r 5 –f domain.com-test1.url.txt



    – Entrada en el log
**** 5:c100,d1,r1,tractores ****
2011-06-02 23:59:47, 45, 31.08, 0, 15.64, 1.45, 0.00, 22.64, 45, 55
Caché externa y servicios externos
        Ahora sí: esteroides anabolizantes


• FPC: Full Page Caché
• FPC con Phoenix_VarnishCache
• FPC con Ezapps_Zoom
• Precauciones con FPC: usuarios
  autentificados. Estrategias y ejemplos.
• Cloudflare: aligerar la carga del servidor
Caché externa y servicios externos

                    Cloudflare
            CDN y protección anti DDOS


          Varnish (Phoenix_VarnishCache)
                 Web caché, proxy


                      nginx

              php-fpm (Ezapps_Zoom)

               php-fpm (Magento)
Escalado de infraestructura
• Detectar qué capa puede sufrir problemas de
  rendimiento: frontend o servidor de base de
  datos. O ambas.
• Medida 1. Separar datos de mysql y ficheros
  de aplicación en dispositivos físicos diferentes.
• Medida 2. Separar aplicación y servidor de
  base de datos en instancias diferentes.
  Cuidado con el tráfico.
Escalado de infraestructura
• Medida 3: Servidores de frontend o de base
  de datos redundantes. Hay que prestar
  atención a:
  – Puntos únicos de fallo (balanceador de carga,
    servidor NFS)
  – Mantenimiento de sesiones
  – Lecturas y escrituras de MySQL
  – Replicaciones de MySQL
Y hasta aquí hemos llegado
         Manel R. Doménech (@manelio)
         Socio fundador y haciendo un poco de todo en @onestic

         Estoy terminando esta presentación en el Alaris y sin
         conexión a internet. Para que no quede vacía esta última
         diapositiva utilizaré un monigote del PowerPoint (que los
         acabo de encontrar) en vez de mi foto, que seguro que
         es más agradable de ver.




Ale. Podéis empezar a crucificarme.

Más contenido relacionado

La actualidad más candente

Curso TIC de PHP y MSQL Parte 3
Curso TIC de PHP y MSQL Parte 3Curso TIC de PHP y MSQL Parte 3
Curso TIC de PHP y MSQL Parte 3
Wilian
 
Practica 2 FTP
Practica 2 FTPPractica 2 FTP
Practica 2 FTP
Terrafx9
 

La actualidad más candente (19)

Pentaho BI
Pentaho BIPentaho BI
Pentaho BI
 
Varnish http cache
Varnish http cacheVarnish http cache
Varnish http cache
 
Presentacion backup recover - copia
Presentacion backup recover - copiaPresentacion backup recover - copia
Presentacion backup recover - copia
 
Instalación y Configuración de Pentaho BI y MySQL
Instalación y Configuración de Pentaho BI y MySQLInstalación y Configuración de Pentaho BI y MySQL
Instalación y Configuración de Pentaho BI y MySQL
 
Jvmmx jigsaw
Jvmmx jigsawJvmmx jigsaw
Jvmmx jigsaw
 
Ejercicio3 mysql
Ejercicio3 mysqlEjercicio3 mysql
Ejercicio3 mysql
 
Curso TIC de PHP y MSQL Parte 3
Curso TIC de PHP y MSQL Parte 3Curso TIC de PHP y MSQL Parte 3
Curso TIC de PHP y MSQL Parte 3
 
Manual ldap
Manual ldapManual ldap
Manual ldap
 
Tuning Lamp
Tuning LampTuning Lamp
Tuning Lamp
 
php
phpphp
php
 
Manual php y_mysql
Manual php y_mysqlManual php y_mysql
Manual php y_mysql
 
Practica 2 FTP
Practica 2 FTPPractica 2 FTP
Practica 2 FTP
 
Anatomia de Plone
Anatomia de PloneAnatomia de Plone
Anatomia de Plone
 
Implementación Docker Swarm en Amazon Web Services usando Auto Scaling Groups...
Implementación Docker Swarm en Amazon Web Services usando Auto Scaling Groups...Implementación Docker Swarm en Amazon Web Services usando Auto Scaling Groups...
Implementación Docker Swarm en Amazon Web Services usando Auto Scaling Groups...
 
Ansible DevOps Day Peru 2016
Ansible DevOps Day Peru 2016Ansible DevOps Day Peru 2016
Ansible DevOps Day Peru 2016
 
High Availability, Load Balancing and Replication on Linux
High Availability, Load Balancing and Replication on LinuxHigh Availability, Load Balancing and Replication on Linux
High Availability, Load Balancing and Replication on Linux
 
AlwaysOn en SQL Server 2016
AlwaysOn en SQL Server 2016AlwaysOn en SQL Server 2016
AlwaysOn en SQL Server 2016
 
Aprendiendo REDIS en 20 minutos
Aprendiendo REDIS en 20 minutosAprendiendo REDIS en 20 minutos
Aprendiendo REDIS en 20 minutos
 
Rendimiento en aplicaciones web con Symfony2
Rendimiento en aplicaciones web con Symfony2Rendimiento en aplicaciones web con Symfony2
Rendimiento en aplicaciones web con Symfony2
 

Similar a Rendimiento en magento

Exposicion Akelos
Exposicion AkelosExposicion Akelos
Exposicion Akelos
dokeosla
 
Scripting para Pentesters v1.0
Scripting para Pentesters v1.0Scripting para Pentesters v1.0
Scripting para Pentesters v1.0
wcuestas
 

Similar a Rendimiento en magento (20)

Performance en Drupal 7
Performance en Drupal 7Performance en Drupal 7
Performance en Drupal 7
 
Consejos de seguridad con Alfresco
Consejos de seguridad con AlfrescoConsejos de seguridad con Alfresco
Consejos de seguridad con Alfresco
 
Rendimiento extremo en php
Rendimiento extremo en phpRendimiento extremo en php
Rendimiento extremo en php
 
Escalabilidad - Apache y MySQL
Escalabilidad - Apache y MySQLEscalabilidad - Apache y MySQL
Escalabilidad - Apache y MySQL
 
Exposicion Akelos
Exposicion AkelosExposicion Akelos
Exposicion Akelos
 
Oracle Coherence (by Leonardo Torres Altez)
Oracle Coherence (by Leonardo Torres Altez)Oracle Coherence (by Leonardo Torres Altez)
Oracle Coherence (by Leonardo Torres Altez)
 
EC2 Cómputo en la nube a profundidad
EC2 Cómputo en la nube a profundidad EC2 Cómputo en la nube a profundidad
EC2 Cómputo en la nube a profundidad
 
De Mensajería hacia Logs con Apache Kafka
De Mensajería hacia Logs con Apache KafkaDe Mensajería hacia Logs con Apache Kafka
De Mensajería hacia Logs con Apache Kafka
 
Aceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPAceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHP
 
Aceleradores PHP Final - Programador PHP
Aceleradores PHP Final - Programador PHPAceleradores PHP Final - Programador PHP
Aceleradores PHP Final - Programador PHP
 
Aceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPAceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHP
 
Interchange CMS - e-commerce
Interchange CMS - e-commerceInterchange CMS - e-commerce
Interchange CMS - e-commerce
 
Interchange How-To for Red Hat Linux ES4
Interchange How-To for Red Hat Linux ES4Interchange How-To for Red Hat Linux ES4
Interchange How-To for Red Hat Linux ES4
 
Analisis de rendimiento_en_oracle
Analisis de rendimiento_en_oracleAnalisis de rendimiento_en_oracle
Analisis de rendimiento_en_oracle
 
Jvmmx docker jvm
Jvmmx docker jvmJvmmx docker jvm
Jvmmx docker jvm
 
EC2: Cómputo en la nube a profundidad
EC2: Cómputo en la nube a profundidadEC2: Cómputo en la nube a profundidad
EC2: Cómputo en la nube a profundidad
 
Workshop Técnicas Replicacion I
Workshop Técnicas Replicacion IWorkshop Técnicas Replicacion I
Workshop Técnicas Replicacion I
 
Docker y PostgreSQL
Docker y PostgreSQLDocker y PostgreSQL
Docker y PostgreSQL
 
Scripting para Pentesters v1.0
Scripting para Pentesters v1.0Scripting para Pentesters v1.0
Scripting para Pentesters v1.0
 
Seguridad y optimización en Magento
Seguridad y optimización en MagentoSeguridad y optimización en Magento
Seguridad y optimización en Magento
 

Último

EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
FagnerLisboa3
 
Modulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdfModulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdf
AnnimoUno1
 

Último (15)

guía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Josephguía de registro de slideshare por Brayan Joseph
guía de registro de slideshare por Brayan Joseph
 
Avances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estosAvances tecnológicos del siglo XXI y ejemplos de estos
Avances tecnológicos del siglo XXI y ejemplos de estos
 
Desarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdfDesarrollo Web Moderno con Svelte 2024.pdf
Desarrollo Web Moderno con Svelte 2024.pdf
 
Presentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptxPresentación guía sencilla en Microsoft Excel.pptx
Presentación guía sencilla en Microsoft Excel.pptx
 
pruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNITpruebas unitarias unitarias en java con JUNIT
pruebas unitarias unitarias en java con JUNIT
 
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft FabricGlobal Azure Lima 2024 - Integración de Datos con Microsoft Fabric
Global Azure Lima 2024 - Integración de Datos con Microsoft Fabric
 
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptxEL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
EL CICLO PRÁCTICO DE UN MOTOR DE CUATRO TIEMPOS.pptx
 
EPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial UninoveEPA-pdf resultado da prova presencial Uninove
EPA-pdf resultado da prova presencial Uninove
 
presentacion de PowerPoint de la fuente de poder.pptx
presentacion de PowerPoint de la fuente de poder.pptxpresentacion de PowerPoint de la fuente de poder.pptx
presentacion de PowerPoint de la fuente de poder.pptx
 
Avances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvanaAvances tecnológicos del siglo XXI 10-07 eyvana
Avances tecnológicos del siglo XXI 10-07 eyvana
 
Trabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnologíaTrabajo Mas Completo De Excel en clase tecnología
Trabajo Mas Completo De Excel en clase tecnología
 
Presentación de elementos de afilado con esmeril
Presentación de elementos de afilado con esmerilPresentación de elementos de afilado con esmeril
Presentación de elementos de afilado con esmeril
 
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdfRefrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
Refrigerador_Inverter_Samsung_Curso_y_Manual_de_Servicio_Español.pdf
 
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptxPROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
PROYECTO FINAL. Tutorial para publicar en SlideShare.pptx
 
Modulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdfModulo-Mini Cargador.................pdf
Modulo-Mini Cargador.................pdf
 

Rendimiento en magento

  • 1. Rendimiento en Magento Manel R. Doménech (@manelio) Socio fundador de @onestic @onestic @SoporteMagento
  • 2. Contenidos (1/2) • Instalación básica de Magento. • El sistema – Apache o nginx – PHP, APC, php-fpm – MySQL • Primeras mejoras: sistema interno de caché. • Sesiones: ¿dónde almacenarlas? • Detección de cuellos de botella.
  • 3. Contenidos (2/2) • Precauciones con los módulos • Benchmarking. Pruebas de carga. • Caché externa y servicios externos – Ezapps_Zoom – Phoenix_VarnishCache – Cloudflare • Escalado de infraestructura
  • 4. Instalación básica de Magento Sistema: Virtual. Intel Xeon E5410, 4 cores. 4GB RAM. 50GB HD. - Catálogo de 8 productos - Cachés deshabilitadas - Cachés habilitadas Tiempo de carga de una Tiempo de carga de una página de catálogo página de catálogo 2.35s .8s
  • 5. Instalación básica de Magento • Con 40K referencias la cosa cambia. Con cachés habilitadas: – Para una petición: • Tiempo medio de respuesta: 4s • Ratio de transacciones: .25 t/s – Para 10 peticiones concurrentes: • Tiempo medio de respuesta: 6.86s • Ratio de transacciones: 0.93 t/s • Concurrencia: 6.38
  • 6. El sistema • Apache o nginx: con nginx + php-fpm obtenemos un rendimiento mucho más elevado • PHP – PHP 5.3 – APC, imprescindible • MySQL: para alto tráfico o gran cantidad de productos, se convierte en el cuello de botella.
  • 7. Primeras mejoras: sistema interno de caché • Uso intensivo de ficheros de configuración XML que Magento debe mezclar • Bloques HTML • Traducciones • Colecciones • Atributos y tipos EAV ¿Dónde almacenar esta información cacheada? ¡Cuidado con el uso de caché en disco y las invalidaciones de caché!
  • 8. Primeras mejoras: sistema interno de caché • Motores de caché – Ficheros – Base de datos – Memoria (memcached, redis) – Híbrido, usando dos niveles de caché En nuestra experiencia, los mejores resultados los obtenemos con redis
  • 9. Primeras mejoras: sistema interno de caché • Flat tables: flat catalog, ¿siempre? • Cuidado con la sobrecarga que añade el reindexado de tablas, especialmente las tablas de catálogo cuando éste es grande y las escrituras muy frecuentes. Por ejemplo, módulos de drop shipping. • Cuidado también con las consultas de búsqueda fulltext. Conviene usar un motor especializado: solr, sphinx, lucene, elasticsearch.
  • 10. Sesiones: ¿dónde almacenarlas? • Cuando la base de datos se convierte en un cuello de botella, almacenar las sesiones en ella puede complicar aún más la situación. • Por otro lado, si se opta por mantener diferentes servidores de frontend, es una forma de centralizar las sesiones. • En este último caso es preferible utilizar memcached o redis para almacenar sesiones.
  • 11. Detección de cuellos de botella class OnProfiler { var $log = "/tmp/profile.log"; static $t0 = 0; Método de ir por casa, function __construct($conf) { foreach($conf as $k => $v) $this->$k = $v; pero eficaz. self::$t0 = microtime(true); register_shutdown_function(array($this, 'shutdown')); } function shutdown() { $t1 = microtime(true); $tdelta = $t1 - self::$t0; $peak = memory_get_peak_usage(true); $this->log(date('Y-m-d H:i:s')."t".sprintf("%.2ft%.2f", $tdelta, $peak/1024/1024)."t".$_SERVER['REQUEST_URI']); } function log($str) { $f = fopen($this->log, "a"); fwrite($f, $str."n"); fclose($f); } } $prof = new OnProfiler(array('log' => '/tmp/profile.log',));
  • 12. Detección de cuellos de botella if ($_GET['_profile'] == 1) : define('XHPROF_ROOT','/opt/xhprof-0.9.2'); xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY); function onprofiler__shutdown_function() { $xhprof_data = xhprof_disable(); Xhprof fácil y cómodo include_once XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php"; include_once XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php"; $xhprof_runs = new XHProfRuns_Default(); $run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo"); echo <<<EOT <div style="background-color: #FFFFFF; border: 1px solid red; padding: 10px; position: fixed; right: 10px; top: 53px; width: 300px; z-index: 100000;"> <h3>XHProf</h3> <a href="http://xhprof.dev1.onestic.com/index.php?run=$run_id&source=xhprof_foo" target="_blank">view profile</a> </div> EOT; } register_shutdown_function("onprofiler__shutdown_function"); endif;
  • 13. Detección de cuellos de botella • Ejemplo de resultado obtenido con xhprof -> Mage_Catalog_Block_Product_List::getCountAllVendorProducts 20 10.3% 1,872,247 37.4% 565,912 19.9% 1,963,544 7.0% 853,464 3.0% Las llamadas a este método duran 1.9s, de una duración total de 5.0s. Esto es un 37.4% de tiempo perdido contando los productos de los vendedores. -> Mage_Catalog_Block_Product_List_Toolbar::getLastPageNum 4 14.8% 145,695 2.9% 1,000 0.0% 19,976 0.1% 26,928 0.1% En este caso, para obtener el último número de página de la lista de productos, se consumen 0.15s, un 2.9% del total. -> Mage_Catalog_Block_Product_List::_beforeToHtml 1 2.9% 495,733 9.9% 85,986 3.0% 1,929,848 6.9% 1,513,256 5.3% Casi lo mismo ocurre antes de renderizar la lista de productos: 0.50s, que es un 9.9% del total -> AW_Sarp_Block_Catalog_Product_Price::getProduct 20 14.8% 621,377 12.4% 486,925 17.1% 2,533,088 9.0% 2,758,320 9.7% Esta llamada consume 0.62s, un 12.4% del total. -> Unirgy_Dropship_Helper_Data::loadCustomData 731 1.7% 649,759 13.0% 664,902 23.4% 6,912,152 24.6% 176,320 0.6% Esta llamada consume 0.65s, un 13.0% del total. 13.0 + 12.4 + 9.9 + 2.9 + 37.4 = 75.6 Las llamadas a las anteriores funciones están suponiendo un 75.6% de la carga de la página. 3.79s
  • 14. Detección de cuellos de botella • Una vez identificados los cuellos de botella, es el momento de corregirlos. Casos habituales: – Consultas sin índices sobre tablas de módulos – Abuso de llamadas a funciones en vez de precalcular y reutilizar – Necesidad de cacheo de bloques costosos, como el de precio – Separar el renderizado de los ítems en las listas productos, y cachear estos bloques.
  • 15. Detección de cuellos de botella • Onestic_Profiler. Uso de redis para cálculo de acumulados de tiempo, memoria y consultas. • Detalle de acumulados por bloque: ++++ renderView: frontend/default/agroterra/template/catalog/product/list/toolbarbottom.phtml +++++ renderView: frontend/default/agroterra/template/page/html/pager.phtml - - - - - 0.00183 renderView: frontend/default/agroterra/template/page/html/pager.phtml - - - - 0.00380 renderView: frontend/default/agroterra/template/catalog/product/list/toolbarbottom.phtml - - - 0.80834 renderView: frontend/default/agroterra/template/catalog/product/list.phtml - - 1.27292 renderView: frontend/default/agroterra/template/catalog/category/view.phtml
  • 16. Precauciones con los módulos • Hay módulos que crean tablas, modifican consultas o añaden joins y no siempre hacen hincapié en el rendimiento. El problema puede no verse hasta que el tráfico crece o el catálogo aumenta. • Cuidado con las colisiones de rewrites de clases. Ejemplo: Ashroeder_SMTPPro / Ebizmarts_Mailchimp
  • 17. … ahora parece que Magento está en forma sin el uso de esteroides anabólicos … ¡A reventarlo!
  • 18. Benchmarking. Pruebas de carga. • Multitud de herramientas – F5 – Apache benchmark – BadBoy / Jmeter – Siege • Simula una serie de peticiones a la aplicación indicando el concurrencia, tiempo entre peticiones, repeticiones de la prueba y un fichero de URLs.
  • 19. Benchmarking. Pruebas de carga. • Siege – Invocación siege -m "5:c100,d1,r1,tractores" -v --log=$HOME/log/domain.com-siege.log -c 100 -d 1 -r 5 –f domain.com-test1.url.txt – Entrada en el log **** 5:c100,d1,r1,tractores **** 2011-06-02 23:59:47, 45, 31.08, 0, 15.64, 1.45, 0.00, 22.64, 45, 55
  • 20. Caché externa y servicios externos Ahora sí: esteroides anabolizantes • FPC: Full Page Caché • FPC con Phoenix_VarnishCache • FPC con Ezapps_Zoom • Precauciones con FPC: usuarios autentificados. Estrategias y ejemplos. • Cloudflare: aligerar la carga del servidor
  • 21. Caché externa y servicios externos Cloudflare CDN y protección anti DDOS Varnish (Phoenix_VarnishCache) Web caché, proxy nginx php-fpm (Ezapps_Zoom) php-fpm (Magento)
  • 22. Escalado de infraestructura • Detectar qué capa puede sufrir problemas de rendimiento: frontend o servidor de base de datos. O ambas. • Medida 1. Separar datos de mysql y ficheros de aplicación en dispositivos físicos diferentes. • Medida 2. Separar aplicación y servidor de base de datos en instancias diferentes. Cuidado con el tráfico.
  • 23. Escalado de infraestructura • Medida 3: Servidores de frontend o de base de datos redundantes. Hay que prestar atención a: – Puntos únicos de fallo (balanceador de carga, servidor NFS) – Mantenimiento de sesiones – Lecturas y escrituras de MySQL – Replicaciones de MySQL
  • 24. Y hasta aquí hemos llegado Manel R. Doménech (@manelio) Socio fundador y haciendo un poco de todo en @onestic Estoy terminando esta presentación en el Alaris y sin conexión a internet. Para que no quede vacía esta última diapositiva utilizaré un monigote del PowerPoint (que los acabo de encontrar) en vez de mi foto, que seguro que es más agradable de ver. Ale. Podéis empezar a crucificarme.