SlideShare uma empresa Scribd logo
1 de 18
SERVE LIKE A BOSS (PART TWO)
Server configuration
14 Sep 2015
Hamed Nemati
@hamednz
WEB SERVERS
 Apache
 Nginx
 Lighttpd
 Jetty
 Gunicorn (Python)
 Unicorn (Ruby)
APACHE
 World's most widely used web server
 Dynamic loadable modules
 Language support: Perl, Python, PHP and ...
 It’s being used by many high traffic websites
 Easy virtual hosting
NGINX
 Low memory footprint
 Language support: Ruby, Python, PHP and ...
 Reverse proxy, Load balancer and HTTP cache
REVERSE PROXY
 Hide the existence and characteristics of an origin server or servers
 Protect against common web-based attacks, such as DOS or DDOS
 Can do SSL termination [SSL termination proxy]
 Load balancing
 Caching
 Compressing content
LOAD BALANCER
Without Load Balancer With Load Balancer
• HAProxy
• Nginx
• Etc.
HTTP CACHE
Http Cache Backend
Is
Cached?Http Request
Cache Hit
Cache Miss
Yes
No
Cache Response
Backend response
MYSQL VARIABLES YOU SHOULD
CARE
 innodb_buffer_pool_size
 innodb_log_file_size
 max_connections
 innodb_file_per_table
 query_cache_size
 log_bin
 skip_name_resolve
SOME POINTS ON MYSQL ( /ETC/MY.CNF )
Mysql Server Memory Usage = core_mysql + Sum of Global Buffers + (number of Connection * Per thread memory variables)
Global buffers include:
key_buffer_size, innodb_buffer_pool_size, innodb_additional_mem_pool_size, innodb_log_buffer_size,
query_cache_size
Each thread for client connection uses:
thread_stack, net_buffer_length, max_allowed_packet, read_buffer_size, rean_rnd_buffer_size,
tmp_table_size, sort_buffer_size
Per thread variables include:
read_buffer_size, read_rnd_buffer_size, sort_buffer_size, join_buffer_size, thread_stack, net_buffer_length,
max_allowed_packet
USEFUL TOOLS FOR MYSQL
 MySQLTuner-perl: http://mysqltuner.com/
 MySQL Tuning Primer: https://launchpad.net/mysql-tuning-primer
 Percona Toolkit: https://www.percona.com/doc/percona-
toolkit/2.2/index.html
REDIS CONF
Just never forget to set:
 maxmemory <bytes>
MEMCACHED CONF
Just never forget to set:
 MAXCONN="“
 CACHESIZE=""
SERVING REQUESTS
Backend 1
Is
Static File?Http Request
No Hit on backed
Hit From Backend
Yes
No
Backend 2
File System
Round-robin or
other scheduling
algorithms
PHP-FPM
 It’s an alternative PHP FastCGI implementation
 Initial configuration is strait-forward
PHP
 Use memcache for sessions (php.ini):
session.save_handler = memcached
session.save_path = "localhost:11211“
 Enable and config PHP’s OPCache
 PHP has 2 modules (memcache and memcached) for communication
with memcached (software), always use “memcached”
SECURITY!
 Install and use CSF and Fail2Ban, else I assure you the pain is coming.
 Always run ‘mysql_secure_installation’ after MySQL installation
ENDED, BUT NOT FINISHED
Follow your dreams, but care to eat less before dreaming.
HAMED NEMATI
 hamed@atbox.io
 @hamednz
 New Idea Game Studio

Mais conteúdo relacionado

Mais procurados

A memcached implementation in Java
A memcached implementation in JavaA memcached implementation in Java
A memcached implementation in Java
elliando dias
 
Memcache and Drupal - Vaibhav Jain
Memcache and Drupal - Vaibhav JainMemcache and Drupal - Vaibhav Jain
Memcache and Drupal - Vaibhav Jain
Drupal Camp Delhi
 

Mais procurados (20)

High Performance Wordpress: “Faster, Cheaper, Easier : Pick Three”
High Performance Wordpress: “Faster, Cheaper, Easier : Pick Three”High Performance Wordpress: “Faster, Cheaper, Easier : Pick Three”
High Performance Wordpress: “Faster, Cheaper, Easier : Pick Three”
 
SELinux by Example
SELinux by ExampleSELinux by Example
SELinux by Example
 
Web performance across the HTTP to HTTPS transition
Web performance across the HTTP to HTTPS transitionWeb performance across the HTTP to HTTPS transition
Web performance across the HTTP to HTTPS transition
 
Storage based snapshots for KVM VMs in CloudStack
Storage based snapshots for KVM VMs in CloudStackStorage based snapshots for KVM VMs in CloudStack
Storage based snapshots for KVM VMs in CloudStack
 
Memcache d
Memcache dMemcache d
Memcache d
 
A memcached implementation in Java
A memcached implementation in JavaA memcached implementation in Java
A memcached implementation in Java
 
Memcache and Drupal - Vaibhav Jain
Memcache and Drupal - Vaibhav JainMemcache and Drupal - Vaibhav Jain
Memcache and Drupal - Vaibhav Jain
 
Drupal7 MEMCACHE
Drupal7 MEMCACHE Drupal7 MEMCACHE
Drupal7 MEMCACHE
 
Getting hands on-experience with UltraESB
Getting hands on-experience with UltraESBGetting hands on-experience with UltraESB
Getting hands on-experience with UltraESB
 
Speed up your site with Varnish
Speed up your site with VarnishSpeed up your site with Varnish
Speed up your site with Varnish
 
FreeBSD hosting
FreeBSD hostingFreeBSD hosting
FreeBSD hosting
 
Memcached B box presentation
Memcached B box presentationMemcached B box presentation
Memcached B box presentation
 
IT Operations for Web Developers
IT Operations for Web DevelopersIT Operations for Web Developers
IT Operations for Web Developers
 
Memcached And MySQL
Memcached And MySQLMemcached And MySQL
Memcached And MySQL
 
Cache all the things - A guide to caching Drupal
Cache all the things - A guide to caching DrupalCache all the things - A guide to caching Drupal
Cache all the things - A guide to caching Drupal
 
Caching Data For Performance
Caching Data For PerformanceCaching Data For Performance
Caching Data For Performance
 
Secure your IT infrastructure with GNU/Linux
Secure your IT infrastructure  with GNU/LinuxSecure your IT infrastructure  with GNU/Linux
Secure your IT infrastructure with GNU/Linux
 
Docker 1.9 release party - Docker Ha Noi
Docker 1.9 release party - Docker Ha NoiDocker 1.9 release party - Docker Ha Noi
Docker 1.9 release party - Docker Ha Noi
 
Administration and Management with UltraESB
Administration and Management with UltraESBAdministration and Management with UltraESB
Administration and Management with UltraESB
 
Advanced Web Hosting
Advanced Web HostingAdvanced Web Hosting
Advanced Web Hosting
 

Destaque

Catalyst landing page July 2016
Catalyst landing page July 2016Catalyst landing page July 2016
Catalyst landing page July 2016
Laurie Walmsley
 
Imagenología del tórax clase
Imagenología del tórax   claseImagenología del tórax   clase
Imagenología del tórax clase
Eliza Fj
 

Destaque (19)

Meg Slides
Meg SlidesMeg Slides
Meg Slides
 
Biochemistry exam 3 enzyme sugars nov2016 S Jamal
Biochemistry exam 3 enzyme sugars nov2016 S JamalBiochemistry exam 3 enzyme sugars nov2016 S Jamal
Biochemistry exam 3 enzyme sugars nov2016 S Jamal
 
Catalyst landing page July 2016
Catalyst landing page July 2016Catalyst landing page July 2016
Catalyst landing page July 2016
 
Game platform
Game platformGame platform
Game platform
 
Serve like a boss (part one)
Serve like a boss (part one)Serve like a boss (part one)
Serve like a boss (part one)
 
S.Duplij, A q-deformed generalization of the Hosszu-Gluskin theorem
S.Duplij, A q-deformed generalization of the Hosszu-Gluskin theoremS.Duplij, A q-deformed generalization of the Hosszu-Gluskin theorem
S.Duplij, A q-deformed generalization of the Hosszu-Gluskin theorem
 
The Fundamental Role of Technology in Transforming the NHS
The Fundamental Role of Technology in Transforming the NHSThe Fundamental Role of Technology in Transforming the NHS
The Fundamental Role of Technology in Transforming the NHS
 
рлпортал
рлпорталрлпортал
рлпортал
 
OCCULT DISEASE - A CHALLENGE TO DIAGNOSTICIAN
OCCULT DISEASE - A CHALLENGE TO DIAGNOSTICIANOCCULT DISEASE - A CHALLENGE TO DIAGNOSTICIAN
OCCULT DISEASE - A CHALLENGE TO DIAGNOSTICIAN
 
CONCENTRACION Y DILUCION DE LA ORINA
CONCENTRACION Y DILUCION DE LA ORINA CONCENTRACION Y DILUCION DE LA ORINA
CONCENTRACION Y DILUCION DE LA ORINA
 
Capitalismo e socialismo
Capitalismo e socialismoCapitalismo e socialismo
Capitalismo e socialismo
 
Carat media news_letter-867report
Carat media news_letter-867reportCarat media news_letter-867report
Carat media news_letter-867report
 
Acampamento 1
Acampamento 1Acampamento 1
Acampamento 1
 
Oceania
OceaniaOceania
Oceania
 
Avances tc 2012
Avances tc 2012Avances tc 2012
Avances tc 2012
 
Glandula Mamaria
Glandula MamariaGlandula Mamaria
Glandula Mamaria
 
Imagenología del tórax clase
Imagenología del tórax   claseImagenología del tórax   clase
Imagenología del tórax clase
 
Digital Europe: Pushing the frontier, capturing the benefits
Digital Europe: Pushing the frontier, capturing the benefitsDigital Europe: Pushing the frontier, capturing the benefits
Digital Europe: Pushing the frontier, capturing the benefits
 
Carat media news_letter-report861
Carat media news_letter-report861Carat media news_letter-report861
Carat media news_letter-report861
 

Semelhante a Serve like a boss (part two)

Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
drupalcampest
 
Site Performance - From Pinto to Ferrari
Site Performance - From Pinto to FerrariSite Performance - From Pinto to Ferrari
Site Performance - From Pinto to Ferrari
Joseph Scott
 
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
MagentoImagine
 
Drupal Performance and Scaling
Drupal Performance and ScalingDrupal Performance and Scaling
Drupal Performance and Scaling
Gerald Villorente
 

Semelhante a Serve like a boss (part two) (20)

High Performance Wordpress
High Performance WordpressHigh Performance Wordpress
High Performance Wordpress
 
Experience In Building Scalable Web Sites Through Infrastructure's View
Experience In Building Scalable Web Sites Through Infrastructure's ViewExperience In Building Scalable Web Sites Through Infrastructure's View
Experience In Building Scalable Web Sites Through Infrastructure's View
 
Php version 5
Php version 5Php version 5
Php version 5
 
Nginx pres
Nginx presNginx pres
Nginx pres
 
Scaling PHP apps
Scaling PHP appsScaling PHP apps
Scaling PHP apps
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
 
Drupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance SitesDrupalcamp Estonia - High Performance Sites
Drupalcamp Estonia - High Performance Sites
 
MySQL native driver for PHP (mysqlnd) - Introduction and overview, Edition 2011
MySQL native driver for PHP (mysqlnd) - Introduction and overview, Edition 2011MySQL native driver for PHP (mysqlnd) - Introduction and overview, Edition 2011
MySQL native driver for PHP (mysqlnd) - Introduction and overview, Edition 2011
 
Zendcon scaling magento
Zendcon scaling magentoZendcon scaling magento
Zendcon scaling magento
 
Site Performance - From Pinto to Ferrari
Site Performance - From Pinto to FerrariSite Performance - From Pinto to Ferrari
Site Performance - From Pinto to Ferrari
 
Magento Imagine eCommerce Conference February 2011: Optimizing Magento For Pe...
Magento Imagine eCommerce Conference February 2011: Optimizing Magento For Pe...Magento Imagine eCommerce Conference February 2011: Optimizing Magento For Pe...
Magento Imagine eCommerce Conference February 2011: Optimizing Magento For Pe...
 
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
Magento's Imagine eCommerce Conference 2011 - Hosting Magento: Performance an...
 
Caching and tuning fun for high scalability
Caching and tuning fun for high scalabilityCaching and tuning fun for high scalability
Caching and tuning fun for high scalability
 
OpenStack Cinder Best Practices - Meet Up
OpenStack Cinder Best Practices - Meet UpOpenStack Cinder Best Practices - Meet Up
OpenStack Cinder Best Practices - Meet Up
 
Performance_Up.ppt
Performance_Up.pptPerformance_Up.ppt
Performance_Up.ppt
 
Drupal Performance and Scaling
Drupal Performance and ScalingDrupal Performance and Scaling
Drupal Performance and Scaling
 
Introduction to php
Introduction to phpIntroduction to php
Introduction to php
 
Linux advanced concepts - Part 2
Linux advanced concepts - Part 2Linux advanced concepts - Part 2
Linux advanced concepts - Part 2
 
Scaleable PHP Applications in Kubernetes
Scaleable PHP Applications in KubernetesScaleable PHP Applications in Kubernetes
Scaleable PHP Applications in Kubernetes
 
(phpconftw2012) PHP as a Middleware in Embedded Systems
(phpconftw2012) PHP as a Middleware in Embedded Systems(phpconftw2012) PHP as a Middleware in Embedded Systems
(phpconftw2012) PHP as a Middleware in Embedded Systems
 

Último

%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
masabamasaba
 
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
masabamasaba
 
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
masabamasaba
 
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
Medical / Health Care (+971588192166) Mifepristone and Misoprostol tablets 200mg
 
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Medical / Health Care (+971588192166) Mifepristone and Misoprostol tablets 200mg
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
masabamasaba
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 

Último (20)

%in Harare+277-882-255-28 abortion pills for sale in Harare
%in Harare+277-882-255-28 abortion pills for sale in Harare%in Harare+277-882-255-28 abortion pills for sale in Harare
%in Harare+277-882-255-28 abortion pills for sale in Harare
 
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park %in kempton park+277-882-255-28 abortion pills for sale in kempton park
%in kempton park+277-882-255-28 abortion pills for sale in kempton park
 
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
%in Rustenburg+277-882-255-28 abortion pills for sale in Rustenburg
 
%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
%+27788225528 love spells in Huntington Beach Psychic Readings, Attraction sp...
 
WSO2CON2024 - It's time to go Platformless
WSO2CON2024 - It's time to go PlatformlessWSO2CON2024 - It's time to go Platformless
WSO2CON2024 - It's time to go Platformless
 
%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto%in Soweto+277-882-255-28 abortion pills for sale in soweto
%in Soweto+277-882-255-28 abortion pills for sale in soweto
 
Announcing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK SoftwareAnnouncing Codolex 2.0 from GDK Software
Announcing Codolex 2.0 from GDK Software
 
WSO2Con2024 - From Code To Cloud: Fast Track Your Cloud Native Journey with C...
WSO2Con2024 - From Code To Cloud: Fast Track Your Cloud Native Journey with C...WSO2Con2024 - From Code To Cloud: Fast Track Your Cloud Native Journey with C...
WSO2Con2024 - From Code To Cloud: Fast Track Your Cloud Native Journey with C...
 
AI & Machine Learning Presentation Template
AI & Machine Learning Presentation TemplateAI & Machine Learning Presentation Template
AI & Machine Learning Presentation Template
 
%in tembisa+277-882-255-28 abortion pills for sale in tembisa
%in tembisa+277-882-255-28 abortion pills for sale in tembisa%in tembisa+277-882-255-28 abortion pills for sale in tembisa
%in tembisa+277-882-255-28 abortion pills for sale in tembisa
 
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
%+27788225528 love spells in Colorado Springs Psychic Readings, Attraction sp...
 
Crypto Cloud Review - How To Earn Up To $500 Per DAY Of Bitcoin 100% On AutoP...
Crypto Cloud Review - How To Earn Up To $500 Per DAY Of Bitcoin 100% On AutoP...Crypto Cloud Review - How To Earn Up To $500 Per DAY Of Bitcoin 100% On AutoP...
Crypto Cloud Review - How To Earn Up To $500 Per DAY Of Bitcoin 100% On AutoP...
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
WSO2CON 2024 - WSO2's Digital Transformation Journey with Choreo: A Platforml...
 
%in ivory park+277-882-255-28 abortion pills for sale in ivory park
%in ivory park+277-882-255-28 abortion pills for sale in ivory park %in ivory park+277-882-255-28 abortion pills for sale in ivory park
%in ivory park+277-882-255-28 abortion pills for sale in ivory park
 
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
%+27788225528 love spells in Boston Psychic Readings, Attraction spells,Bring...
 
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
Abortion Pills In Pretoria ](+27832195400*)[ 🏥 Women's Abortion Clinic In Pre...
 
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
Abortion Pill Prices Tembisa [(+27832195400*)] 🏥 Women's Abortion Clinic in T...
 
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
%+27788225528 love spells in Knoxville Psychic Readings, Attraction spells,Br...
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 

Serve like a boss (part two)

  • 1. SERVE LIKE A BOSS (PART TWO) Server configuration 14 Sep 2015 Hamed Nemati @hamednz
  • 2. WEB SERVERS  Apache  Nginx  Lighttpd  Jetty  Gunicorn (Python)  Unicorn (Ruby)
  • 3. APACHE  World's most widely used web server  Dynamic loadable modules  Language support: Perl, Python, PHP and ...  It’s being used by many high traffic websites  Easy virtual hosting
  • 4. NGINX  Low memory footprint  Language support: Ruby, Python, PHP and ...  Reverse proxy, Load balancer and HTTP cache
  • 5. REVERSE PROXY  Hide the existence and characteristics of an origin server or servers  Protect against common web-based attacks, such as DOS or DDOS  Can do SSL termination [SSL termination proxy]  Load balancing  Caching  Compressing content
  • 6. LOAD BALANCER Without Load Balancer With Load Balancer • HAProxy • Nginx • Etc.
  • 7. HTTP CACHE Http Cache Backend Is Cached?Http Request Cache Hit Cache Miss Yes No Cache Response Backend response
  • 8. MYSQL VARIABLES YOU SHOULD CARE  innodb_buffer_pool_size  innodb_log_file_size  max_connections  innodb_file_per_table  query_cache_size  log_bin  skip_name_resolve
  • 9. SOME POINTS ON MYSQL ( /ETC/MY.CNF ) Mysql Server Memory Usage = core_mysql + Sum of Global Buffers + (number of Connection * Per thread memory variables) Global buffers include: key_buffer_size, innodb_buffer_pool_size, innodb_additional_mem_pool_size, innodb_log_buffer_size, query_cache_size Each thread for client connection uses: thread_stack, net_buffer_length, max_allowed_packet, read_buffer_size, rean_rnd_buffer_size, tmp_table_size, sort_buffer_size Per thread variables include: read_buffer_size, read_rnd_buffer_size, sort_buffer_size, join_buffer_size, thread_stack, net_buffer_length, max_allowed_packet
  • 10. USEFUL TOOLS FOR MYSQL  MySQLTuner-perl: http://mysqltuner.com/  MySQL Tuning Primer: https://launchpad.net/mysql-tuning-primer  Percona Toolkit: https://www.percona.com/doc/percona- toolkit/2.2/index.html
  • 11. REDIS CONF Just never forget to set:  maxmemory <bytes>
  • 12. MEMCACHED CONF Just never forget to set:  MAXCONN="“  CACHESIZE=""
  • 13. SERVING REQUESTS Backend 1 Is Static File?Http Request No Hit on backed Hit From Backend Yes No Backend 2 File System Round-robin or other scheduling algorithms
  • 14. PHP-FPM  It’s an alternative PHP FastCGI implementation  Initial configuration is strait-forward
  • 15. PHP  Use memcache for sessions (php.ini): session.save_handler = memcached session.save_path = "localhost:11211“  Enable and config PHP’s OPCache  PHP has 2 modules (memcache and memcached) for communication with memcached (software), always use “memcached”
  • 16. SECURITY!  Install and use CSF and Fail2Ban, else I assure you the pain is coming.  Always run ‘mysql_secure_installation’ after MySQL installation
  • 17. ENDED, BUT NOT FINISHED Follow your dreams, but care to eat less before dreaming.
  • 18. HAMED NEMATI  hamed@atbox.io  @hamednz  New Idea Game Studio