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

Pentaho BI
Pentaho BIPentaho BI
Pentaho BIT.I.C
 
Presentacion backup recover - copia
Presentacion backup recover - copiaPresentacion backup recover - copia
Presentacion backup recover - copiaGonzalo del Pozo
 
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 MySQLT.I.C
 
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 3Wilian
 
Manual ldap
Manual ldapManual ldap
Manual ldapomarhl2
 
Manual php y_mysql
Manual php y_mysqlManual php y_mysql
Manual php y_mysqljohan reyes
 
Practica 2 FTP
Practica 2 FTPPractica 2 FTP
Practica 2 FTPTerrafx9
 
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...Adrián Lois
 
Ansible DevOps Day Peru 2016
Ansible DevOps Day Peru 2016Ansible DevOps Day Peru 2016
Ansible DevOps Day Peru 2016Raul Hugo
 
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 LinuxOlaf Reitmaier Veracierta
 
AlwaysOn en SQL Server 2016
AlwaysOn en SQL Server 2016AlwaysOn en SQL Server 2016
AlwaysOn en SQL Server 2016SpanishPASSVC
 
Aprendiendo REDIS en 20 minutos
Aprendiendo REDIS en 20 minutosAprendiendo REDIS en 20 minutos
Aprendiendo REDIS en 20 minutosGonzalo Chacaltana
 
Rendimiento en aplicaciones web con Symfony2
Rendimiento en aplicaciones web con Symfony2Rendimiento en aplicaciones web con Symfony2
Rendimiento en aplicaciones web con Symfony2Asier Marqués
 

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

Consejos de seguridad con Alfresco
Consejos de seguridad con AlfrescoConsejos de seguridad con Alfresco
Consejos de seguridad con AlfrescoToni de la Fuente
 
Escalabilidad - Apache y MySQL
Escalabilidad - Apache y MySQLEscalabilidad - Apache y MySQL
Escalabilidad - Apache y MySQLLorena Fernández
 
Exposicion Akelos
Exposicion AkelosExposicion Akelos
Exposicion Akelosdokeosla
 
Oracle Coherence (by Leonardo Torres Altez)
Oracle Coherence (by Leonardo Torres Altez)Oracle Coherence (by Leonardo Torres Altez)
Oracle Coherence (by Leonardo Torres Altez)barcelonajug
 
Aceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPAceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPJuan Belón Pérez
 
Aceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPAceleradores Php Final - Programador PHP
Aceleradores Php Final - Programador PHPJuan Belón Pérez
 
Aceleradores PHP Final - Programador PHP
Aceleradores PHP Final - Programador PHPAceleradores PHP Final - Programador PHP
Aceleradores PHP Final - Programador PHPJuan Belón Pérez
 
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 ES4David Ramirez
 
Interchange CMS - e-commerce
Interchange CMS - e-commerceInterchange CMS - e-commerce
Interchange CMS - e-commerceDavid Ramirez
 
Jvmmx docker jvm
Jvmmx docker jvmJvmmx docker jvm
Jvmmx docker jvmsuperserch
 
Scripting para Pentesters v1.0
Scripting para Pentesters v1.0Scripting para Pentesters v1.0
Scripting para Pentesters v1.0wcuestas
 
Seguridad y optimización en Magento
Seguridad y optimización en MagentoSeguridad y optimización en Magento
Seguridad y optimización en MagentoDevopensource
 

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 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
 
Interchange CMS - e-commerce
Interchange CMS - e-commerceInterchange CMS - e-commerce
Interchange CMS - e-commerce
 
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

El uso de las TIC's en la vida cotidiana.
El uso de las TIC's en la vida cotidiana.El uso de las TIC's en la vida cotidiana.
El uso de las TIC's en la vida cotidiana.241514949
 
Trabajo de tecnología excel avanzado.pdf
Trabajo de tecnología excel avanzado.pdfTrabajo de tecnología excel avanzado.pdf
Trabajo de tecnología excel avanzado.pdfedepmariaperez
 
Presentación sobre la Inteligencia Artificial
Presentación sobre la Inteligencia ArtificialPresentación sobre la Inteligencia Artificial
Presentación sobre la Inteligencia Artificialcynserafini89
 
El uso de las tic en la vida ,lo importante que son
El uso de las tic en la vida ,lo importante  que sonEl uso de las tic en la vida ,lo importante  que son
El uso de las tic en la vida ,lo importante que son241514984
 
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptx
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptxEl_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptx
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptxAlexander López
 
Excel (1) tecnologia.pdf trabajo Excel taller
Excel  (1) tecnologia.pdf trabajo Excel tallerExcel  (1) tecnologia.pdf trabajo Excel taller
Excel (1) tecnologia.pdf trabajo Excel tallerValentinaTabares11
 
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).ppt
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).pptLUXOMETRO EN SALUD OCUPACIONAL(FINAL).ppt
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).pptchaverriemily794
 
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPO
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPOAREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPO
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPOnarvaezisabella21
 
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptx
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptxLAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptx
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptxAlexander López
 
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptx
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptxMedidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptx
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptxaylincamaho
 
Actividad integradora 6 CREAR UN RECURSO MULTIMEDIA
Actividad integradora 6    CREAR UN RECURSO MULTIMEDIAActividad integradora 6    CREAR UN RECURSO MULTIMEDIA
Actividad integradora 6 CREAR UN RECURSO MULTIMEDIA241531640
 
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptx
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptxCrear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptx
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptxNombre Apellidos
 
GonzalezGonzalez_Karina_M1S3AI6... .pptx
GonzalezGonzalez_Karina_M1S3AI6... .pptxGonzalezGonzalez_Karina_M1S3AI6... .pptx
GonzalezGonzalez_Karina_M1S3AI6... .pptx241523733
 
Mapa-conceptual-del-Origen-del-Universo-3.pptx
Mapa-conceptual-del-Origen-del-Universo-3.pptxMapa-conceptual-del-Origen-del-Universo-3.pptx
Mapa-conceptual-del-Origen-del-Universo-3.pptxMidwarHenryLOZAFLORE
 
Tecnologias Starlink para el mundo tec.pptx
Tecnologias Starlink para el mundo tec.pptxTecnologias Starlink para el mundo tec.pptx
Tecnologias Starlink para el mundo tec.pptxGESTECPERUSAC
 
FloresMorales_Montserrath_M1S3AI6 (1).pptx
FloresMorales_Montserrath_M1S3AI6 (1).pptxFloresMorales_Montserrath_M1S3AI6 (1).pptx
FloresMorales_Montserrath_M1S3AI6 (1).pptx241522327
 
Los Microcontroladores PIC, Aplicaciones
Los Microcontroladores PIC, AplicacionesLos Microcontroladores PIC, Aplicaciones
Los Microcontroladores PIC, AplicacionesEdomar AR
 
tics en la vida cotidiana prepa en linea modulo 1.pptx
tics en la vida cotidiana prepa en linea modulo 1.pptxtics en la vida cotidiana prepa en linea modulo 1.pptx
tics en la vida cotidiana prepa en linea modulo 1.pptxazmysanros90
 
La Electricidad Y La Electrónica Trabajo Tecnología.pdf
La Electricidad Y La Electrónica Trabajo Tecnología.pdfLa Electricidad Y La Electrónica Trabajo Tecnología.pdf
La Electricidad Y La Electrónica Trabajo Tecnología.pdfjeondanny1997
 
Presentación inteligencia artificial en la actualidad
Presentación inteligencia artificial en la actualidadPresentación inteligencia artificial en la actualidad
Presentación inteligencia artificial en la actualidadMiguelAngelVillanuev48
 

Último (20)

El uso de las TIC's en la vida cotidiana.
El uso de las TIC's en la vida cotidiana.El uso de las TIC's en la vida cotidiana.
El uso de las TIC's en la vida cotidiana.
 
Trabajo de tecnología excel avanzado.pdf
Trabajo de tecnología excel avanzado.pdfTrabajo de tecnología excel avanzado.pdf
Trabajo de tecnología excel avanzado.pdf
 
Presentación sobre la Inteligencia Artificial
Presentación sobre la Inteligencia ArtificialPresentación sobre la Inteligencia Artificial
Presentación sobre la Inteligencia Artificial
 
El uso de las tic en la vida ,lo importante que son
El uso de las tic en la vida ,lo importante  que sonEl uso de las tic en la vida ,lo importante  que son
El uso de las tic en la vida ,lo importante que son
 
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptx
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptxEl_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptx
El_Blog_como_herramienta_de_publicacion_y_consulta_de_investigacion.pptx
 
Excel (1) tecnologia.pdf trabajo Excel taller
Excel  (1) tecnologia.pdf trabajo Excel tallerExcel  (1) tecnologia.pdf trabajo Excel taller
Excel (1) tecnologia.pdf trabajo Excel taller
 
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).ppt
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).pptLUXOMETRO EN SALUD OCUPACIONAL(FINAL).ppt
LUXOMETRO EN SALUD OCUPACIONAL(FINAL).ppt
 
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPO
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPOAREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPO
AREA TECNOLOGIA E INFORMATICA TRABAJO EN EQUIPO
 
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptx
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptxLAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptx
LAS_TIC_COMO_HERRAMIENTAS_EN_LA_INVESTIGACIÓN.pptx
 
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptx
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptxMedidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptx
Medidas de formas, coeficiente de asimetría y coeficiente de curtosis.pptx
 
Actividad integradora 6 CREAR UN RECURSO MULTIMEDIA
Actividad integradora 6    CREAR UN RECURSO MULTIMEDIAActividad integradora 6    CREAR UN RECURSO MULTIMEDIA
Actividad integradora 6 CREAR UN RECURSO MULTIMEDIA
 
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptx
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptxCrear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptx
Crear un recurso multimedia. Maricela_Ponce_DomingoM1S3AI6-1.pptx
 
GonzalezGonzalez_Karina_M1S3AI6... .pptx
GonzalezGonzalez_Karina_M1S3AI6... .pptxGonzalezGonzalez_Karina_M1S3AI6... .pptx
GonzalezGonzalez_Karina_M1S3AI6... .pptx
 
Mapa-conceptual-del-Origen-del-Universo-3.pptx
Mapa-conceptual-del-Origen-del-Universo-3.pptxMapa-conceptual-del-Origen-del-Universo-3.pptx
Mapa-conceptual-del-Origen-del-Universo-3.pptx
 
Tecnologias Starlink para el mundo tec.pptx
Tecnologias Starlink para el mundo tec.pptxTecnologias Starlink para el mundo tec.pptx
Tecnologias Starlink para el mundo tec.pptx
 
FloresMorales_Montserrath_M1S3AI6 (1).pptx
FloresMorales_Montserrath_M1S3AI6 (1).pptxFloresMorales_Montserrath_M1S3AI6 (1).pptx
FloresMorales_Montserrath_M1S3AI6 (1).pptx
 
Los Microcontroladores PIC, Aplicaciones
Los Microcontroladores PIC, AplicacionesLos Microcontroladores PIC, Aplicaciones
Los Microcontroladores PIC, Aplicaciones
 
tics en la vida cotidiana prepa en linea modulo 1.pptx
tics en la vida cotidiana prepa en linea modulo 1.pptxtics en la vida cotidiana prepa en linea modulo 1.pptx
tics en la vida cotidiana prepa en linea modulo 1.pptx
 
La Electricidad Y La Electrónica Trabajo Tecnología.pdf
La Electricidad Y La Electrónica Trabajo Tecnología.pdfLa Electricidad Y La Electrónica Trabajo Tecnología.pdf
La Electricidad Y La Electrónica Trabajo Tecnología.pdf
 
Presentación inteligencia artificial en la actualidad
Presentación inteligencia artificial en la actualidadPresentación inteligencia artificial en la actualidad
Presentación inteligencia artificial en la actualidad
 

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.