SlideShare una empresa de Scribd logo
1 de 24
Descargar para leer sin conexión
DeNA loves Perl
     Tokiharu Noto
    (DeNA Co., Ltd.)




           1
agenda
• How much / why does DeNA love Perl?
 • outline of Perl usage in DeNA
• YAPC-driven Open Source from DeNA
 • mobamail: mail delivery for mobile phone
• Mobage-town Open Platform
• ambivalent love for Perl
                    2
DeNA services
powered by Perl




       3
How many DeNA
  engineers love Perl?
• about 100 engineers
 • > 50 engineers in mbga.jp team
• YAPC::Asia Tokyo 2009 speakers
 • Hideo Kimura (modern Catalyst)
 • Toru Yamaguchi (Perl DB test using
     MySQL::Sandbox)
 •   Tadashi Matsuda (MobaSiF::Template)

                     4
Why does DeNA
          love Perl?
• bidders: Java + Oracle
• In 2003, Kawasaki has started developing
    mbok.jp with Perl
•   In 2006, ex-bidders engineers joined to
    Moba* services
    • dev/edit/exec speed++, readability++,
      productivity++ (also for biz people)
•   The whole DeNA have loved Perl since

                       5
DeNA scalable
              web architecture MySQL
                               M           w/replication
    Load
   Balancer                    S S S ...
                                  .
                                  .
                                  .        partitioning
                                              mbga > 90
                               M
    Load                       S S S ...     MySQL
   Balancer            LVS
                                             +Senna
                      DNS RR
                  .
                  .
                  .
mbga > 1300                            memcached
  servers     httpd+fcgi
               servers             .
                                   .
                           6
                                   .
MobaSiF
    DeNA original WAF
                                •   Open Source since
                                    YAPC::Asia Tokyo 2008
 web applications               •   pros
      dispatcher                  •   common modules for
          pictgraph converter         mobile web
           handset ditector       •   simple, light-weight, fast
MobaSiF    template engine        •   stable

   mod_fastcgi
                                •   cons
                                  •   no PSGI/Plack ;-)
     Apache                       •   $_::F, $rhData
                                  •   no test...
                                  •   too free for a large team...
                                7
YAPC-driven
        Open Source
• 2008
 • MobaSiF
• 2009
 • MobaSiF::Template (Matsuda)
 • mobamail - fast mail delivery daemon for
    mobile phones

                    8
mail delivery
   for mobile phones
• Mobile phone carriers deny SMTP
  connection at their own discretion (   ).

 • “spam?”
 • especially when senders try to send mails
    with high speed...
 • conflict with our wish “more speeeeedy!”
                         9
mail delivery
    for mobile phones
• 1.09 (109 million) users / 3 carrier ≒ ISP
• MX (cf. dig -t MX <domainname>)
 • docomo.ne.jp: 4 IP addresses
 • ezweb.ne.jp: 1 IP address
 • softbank.ne.jp: 1 IP address
                    10
mail delivery
      for mobile phones
+,PC -./0,"#$%&'(&)123456-78"#*%&'(&)9:1;<=>?@A4BC1DEFG!


"#$!                                            !!
                                                !!
%&'(&)!                                         !!

"#*!
%&'(&)!                              !!

H,IJ-./0,"#$%&'(&)-31KLM6-78"#*%&'(&)9:1;<=>?@A4BC1D4NG!


"#$!      OPQR,A! OPQR,B   OPQR,C
%&'(&)!



"#*!
%&'(&)!                              !!
                                11
before mobamail

• At first (2004-), we used qmail, postfix
 • slow injection
   • main: sendmail command
   • SMTP/QMTP...
• We have to make our own original server...
                     12
mobamail
• implemented in pure Perl
• ≠ MTA (no SMTP receive, relay)
• injection = insert into a table in MySQL
• high speed table2mail to mobile phones
• max speed (depend on carrier-side config)
 • docomo+au: 500,000 mails/h
    softbank: 20,000 mails/h

                     13
mobamail strategy
•   provide tuning params                •  connection closed,
    for best effort under the               timeout, ...
    carriers permission:
                                     •   timeout
    •  num of connection
                                         •  connect()
    •  connect() interval
                                         •  wait for response
    •  mail per connection
                                         •  unused connection
    •  mail interval (in one
                                     •   error count
       connection)
                                         => retry_interval
    •  interval after denied



                                14
mobamail architecture
                                IO::Select   MX

                   ‘docomo’                  MX
                                             .
                                    SMTP     .
                                             .    docomo
                        ‘au’                 MX
‘dist’ daemon                                MX
                   ‘softbank’                .
                                             .
                                             .      au
                                             MX
                     ‘default’               MX
                                             .
                                             .
                                             .    softbank
                 ‘send’ daemon
   MySQL
                    processes                MX
                                             MX
                                             . other ISP
                                             .
                                             .
           one server      15
current operation
                              MX
                              MX
                              .
                              .
                              .    docomo
mobamail
                              MX
                              MX
              SIELLA ENGINE   .
                              .
                              .      au
                              MX
mobamail                      MX
                              .
                              .
                              .    softbank
               better
                              MX
            performance
                              MX
           without tuning     . other ISP
                              .
                       16     .
mobamail
  will be available at...

• http://sourceforge.jp/projects/moba/
• http://d.hatena.ne.jp/tokiharu/ (w/RSS)


                      17
Mobage-town Open Platform
            18
DeNA & Perl, again



        19
DeNA dev policy

•
    •                   ...

    •
    •         =>

    •     /

•                             ...




                   20
ambivalent love
•   100          Perl                    CPAN                         ?

    •                           (                         )

    •                                           ...

•   DeNA     Perl

    •                       :
                                                      (       )

    •                                    =

        →

•         CPAN          (                             )           !



                                    21
DeNA gonna
              love CPAN
•
•   Some pilot projects depend on a lot of CPAN
    modules (and Catalyst)
•
    •   dev policy for the large team
    •   more test code
    •   MobaSiF next generation


                            22
DeNA loves Perl!
• a Perl community cosists of 100 engineers
• Let’s write code together!
 • as DeNA software engineer / architect
 • as developer of Mobage-town
    applications
 • as CPAN author
                     23
DeNA loves Perl!



       24

Más contenido relacionado

La actualidad más candente (7)

Torquebox - O melhor dos dois mundos
Torquebox - O melhor dos dois mundosTorquebox - O melhor dos dois mundos
Torquebox - O melhor dos dois mundos
 
Dean Keynote Ladis2009 Google
Dean Keynote Ladis2009 GoogleDean Keynote Ladis2009 Google
Dean Keynote Ladis2009 Google
 
Membase Meetup Chicago - january 2011
Membase Meetup Chicago - january 2011Membase Meetup Chicago - january 2011
Membase Meetup Chicago - january 2011
 
Lightweight Grids With Terracotta
Lightweight Grids With TerracottaLightweight Grids With Terracotta
Lightweight Grids With Terracotta
 
ZK_Arch_notes_20081121
ZK_Arch_notes_20081121ZK_Arch_notes_20081121
ZK_Arch_notes_20081121
 
Puppet: Orchestration framework?
Puppet: Orchestration framework?Puppet: Orchestration framework?
Puppet: Orchestration framework?
 
程序员0806期敏捷与性能的博弈
程序员0806期敏捷与性能的博弈程序员0806期敏捷与性能的博弈
程序员0806期敏捷与性能的博弈
 

Destacado (9)

ALA Member Benefits Guide
ALA Member Benefits GuideALA Member Benefits Guide
ALA Member Benefits Guide
 
Guice2.0
Guice2.0Guice2.0
Guice2.0
 
Megrisoft Corporate Fact Sheet
Megrisoft Corporate Fact SheetMegrisoft Corporate Fact Sheet
Megrisoft Corporate Fact Sheet
 
Ala Fall PD Day Presentation v2
Ala Fall PD Day Presentation v2Ala Fall PD Day Presentation v2
Ala Fall PD Day Presentation v2
 
Ala Fall PD Day Presentation
Ala Fall PD Day PresentationAla Fall PD Day Presentation
Ala Fall PD Day Presentation
 
Cultivating Campus Collaborations
Cultivating Campus CollaborationsCultivating Campus Collaborations
Cultivating Campus Collaborations
 
Savy Training 16.05.2009
Savy Training 16.05.2009Savy Training 16.05.2009
Savy Training 16.05.2009
 
Cognotes - Sunday June 26
Cognotes - Sunday June 26Cognotes - Sunday June 26
Cognotes - Sunday June 26
 
A list of companies
A list of companiesA list of companies
A list of companies
 

Similar a Dena Loves Perl

State of the art: server-side javaScript - NantesJS
State of the art: server-side javaScript - NantesJSState of the art: server-side javaScript - NantesJS
State of the art: server-side javaScript - NantesJS
Alexandre Morgaut
 
Mom those things v1
Mom those things v1 Mom those things v1
Mom those things v1
von gosling
 
豆瓣技术架构的发展历程 @ QCon Beijing 2009
豆瓣技术架构的发展历程 @ QCon Beijing 2009豆瓣技术架构的发展历程 @ QCon Beijing 2009
豆瓣技术架构的发展历程 @ QCon Beijing 2009
Qiangning Hong
 
Gear6 Webinar - MySQL Scaling with Memcached
Gear6 Webinar - MySQL Scaling with MemcachedGear6 Webinar - MySQL Scaling with Memcached
Gear6 Webinar - MySQL Scaling with Memcached
Gear6
 
Galera Multi Master Synchronous My S Q L Replication Clusters
Galera  Multi Master  Synchronous  My S Q L  Replication  ClustersGalera  Multi Master  Synchronous  My S Q L  Replication  Clusters
Galera Multi Master Synchronous My S Q L Replication Clusters
PerconaPerformance
 
State of the art - server side JavaScript - web-5 2012
State of the art - server side JavaScript - web-5 2012State of the art - server side JavaScript - web-5 2012
State of the art - server side JavaScript - web-5 2012
Alexandre Morgaut
 
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan KoomanOpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
OpenNebula Project
 

Similar a Dena Loves Perl (20)

Mvc express presentation
Mvc express presentationMvc express presentation
Mvc express presentation
 
Hong Qiangning in QConBeijing
Hong Qiangning in QConBeijingHong Qiangning in QConBeijing
Hong Qiangning in QConBeijing
 
State of the art: server-side javaScript - NantesJS
State of the art: server-side javaScript - NantesJSState of the art: server-side javaScript - NantesJS
State of the art: server-side javaScript - NantesJS
 
Squeak DBX
Squeak DBXSqueak DBX
Squeak DBX
 
Mom those things v1
Mom those things v1 Mom those things v1
Mom those things v1
 
豆瓣技术架构的发展历程 @ QCon Beijing 2009
豆瓣技术架构的发展历程 @ QCon Beijing 2009豆瓣技术架构的发展历程 @ QCon Beijing 2009
豆瓣技术架构的发展历程 @ QCon Beijing 2009
 
Operating CloudStack: Sharing My Tool Box @ApacheCon NA'15
Operating CloudStack: Sharing My Tool Box @ApacheCon NA'15Operating CloudStack: Sharing My Tool Box @ApacheCon NA'15
Operating CloudStack: Sharing My Tool Box @ApacheCon NA'15
 
Apache Spark 2.0: Faster, Easier, and Smarter
Apache Spark 2.0: Faster, Easier, and SmarterApache Spark 2.0: Faster, Easier, and Smarter
Apache Spark 2.0: Faster, Easier, and Smarter
 
SLES 11 SP2 PerformanceEvaluation for Linux on System z
SLES 11 SP2 PerformanceEvaluation for Linux on System zSLES 11 SP2 PerformanceEvaluation for Linux on System z
SLES 11 SP2 PerformanceEvaluation for Linux on System z
 
State of the art server side java script
State of the art server side java scriptState of the art server side java script
State of the art server side java script
 
TorqueBox at DC:JBUG - November 2011
TorqueBox at DC:JBUG - November 2011TorqueBox at DC:JBUG - November 2011
TorqueBox at DC:JBUG - November 2011
 
XS Boston 2008 Network Topology
XS Boston 2008 Network TopologyXS Boston 2008 Network Topology
XS Boston 2008 Network Topology
 
Gear6 Webinar - MySQL Scaling with Memcached
Gear6 Webinar - MySQL Scaling with MemcachedGear6 Webinar - MySQL Scaling with Memcached
Gear6 Webinar - MySQL Scaling with Memcached
 
What's New in Docker 1.12 (June 20, 2016) by Mike Goelzer & Andrea Luzzardi
What's New in Docker 1.12 (June 20, 2016) by Mike Goelzer & Andrea LuzzardiWhat's New in Docker 1.12 (June 20, 2016) by Mike Goelzer & Andrea Luzzardi
What's New in Docker 1.12 (June 20, 2016) by Mike Goelzer & Andrea Luzzardi
 
What's New in Docker 1.12 by Mike Goelzer and Andrea Luzzardi
What's New in Docker 1.12 by Mike Goelzer and Andrea LuzzardiWhat's New in Docker 1.12 by Mike Goelzer and Andrea Luzzardi
What's New in Docker 1.12 by Mike Goelzer and Andrea Luzzardi
 
Galera Multi Master Synchronous My S Q L Replication Clusters
Galera  Multi Master  Synchronous  My S Q L  Replication  ClustersGalera  Multi Master  Synchronous  My S Q L  Replication  Clusters
Galera Multi Master Synchronous My S Q L Replication Clusters
 
State of the art - server side JavaScript - web-5 2012
State of the art - server side JavaScript - web-5 2012State of the art - server side JavaScript - web-5 2012
State of the art - server side JavaScript - web-5 2012
 
End to End Processing of 3.7 Million Telemetry Events per Second using Lambda...
End to End Processing of 3.7 Million Telemetry Events per Second using Lambda...End to End Processing of 3.7 Million Telemetry Events per Second using Lambda...
End to End Processing of 3.7 Million Telemetry Events per Second using Lambda...
 
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan KoomanOpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
OpenNebulaConf 2014 - ONE BIT to rule them all - Stefan Kooman
 
OpenNebula Conf 2014 | ONE BIT to rule them all - Stefan Kooman
OpenNebula Conf 2014 | ONE BIT to rule them all - Stefan KoomanOpenNebula Conf 2014 | ONE BIT to rule them all - Stefan Kooman
OpenNebula Conf 2014 | ONE BIT to rule them all - Stefan Kooman
 

Último

+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Victor Rentea
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 

Último (20)

MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 
Strategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a FresherStrategies for Landing an Oracle DBA Job as a Fresher
Strategies for Landing an Oracle DBA Job as a Fresher
 
AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024Manulife - Insurer Transformation Award 2024
Manulife - Insurer Transformation Award 2024
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
Apidays New York 2024 - APIs in 2030: The Risk of Technological Sleepwalk by ...
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
 
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ..."I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
 
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
Navigating the Deluge_ Dubai Floods and the Resilience of Dubai International...
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 

Dena Loves Perl

  • 1. DeNA loves Perl Tokiharu Noto (DeNA Co., Ltd.) 1
  • 2. agenda • How much / why does DeNA love Perl? • outline of Perl usage in DeNA • YAPC-driven Open Source from DeNA • mobamail: mail delivery for mobile phone • Mobage-town Open Platform • ambivalent love for Perl 2
  • 4. How many DeNA engineers love Perl? • about 100 engineers • > 50 engineers in mbga.jp team • YAPC::Asia Tokyo 2009 speakers • Hideo Kimura (modern Catalyst) • Toru Yamaguchi (Perl DB test using MySQL::Sandbox) • Tadashi Matsuda (MobaSiF::Template) 4
  • 5. Why does DeNA love Perl? • bidders: Java + Oracle • In 2003, Kawasaki has started developing mbok.jp with Perl • In 2006, ex-bidders engineers joined to Moba* services • dev/edit/exec speed++, readability++, productivity++ (also for biz people) • The whole DeNA have loved Perl since 5
  • 6. DeNA scalable web architecture MySQL M w/replication Load Balancer S S S ... . . . partitioning mbga > 90 M Load S S S ... MySQL Balancer LVS +Senna DNS RR . . . mbga > 1300 memcached servers httpd+fcgi servers . . 6 .
  • 7. MobaSiF DeNA original WAF • Open Source since YAPC::Asia Tokyo 2008 web applications • pros dispatcher • common modules for pictgraph converter mobile web handset ditector • simple, light-weight, fast MobaSiF template engine • stable mod_fastcgi • cons • no PSGI/Plack ;-) Apache • $_::F, $rhData • no test... • too free for a large team... 7
  • 8. YAPC-driven Open Source • 2008 • MobaSiF • 2009 • MobaSiF::Template (Matsuda) • mobamail - fast mail delivery daemon for mobile phones 8
  • 9. mail delivery for mobile phones • Mobile phone carriers deny SMTP connection at their own discretion ( ). • “spam?” • especially when senders try to send mails with high speed... • conflict with our wish “more speeeeedy!” 9
  • 10. mail delivery for mobile phones • 1.09 (109 million) users / 3 carrier ≒ ISP • MX (cf. dig -t MX <domainname>) • docomo.ne.jp: 4 IP addresses • ezweb.ne.jp: 1 IP address • softbank.ne.jp: 1 IP address 10
  • 11. mail delivery for mobile phones +,PC -./0,"#$%&'(&)123456-78"#*%&'(&)9:1;<=>?@A4BC1DEFG! "#$! !! !! %&'(&)! !! "#*! %&'(&)! !! H,IJ-./0,"#$%&'(&)-31KLM6-78"#*%&'(&)9:1;<=>?@A4BC1D4NG! "#$! OPQR,A! OPQR,B OPQR,C %&'(&)! "#*! %&'(&)! !! 11
  • 12. before mobamail • At first (2004-), we used qmail, postfix • slow injection • main: sendmail command • SMTP/QMTP... • We have to make our own original server... 12
  • 13. mobamail • implemented in pure Perl • ≠ MTA (no SMTP receive, relay) • injection = insert into a table in MySQL • high speed table2mail to mobile phones • max speed (depend on carrier-side config) • docomo+au: 500,000 mails/h softbank: 20,000 mails/h 13
  • 14. mobamail strategy • provide tuning params • connection closed, for best effort under the timeout, ... carriers permission: • timeout • num of connection • connect() • connect() interval • wait for response • mail per connection • unused connection • mail interval (in one • error count connection) => retry_interval • interval after denied 14
  • 15. mobamail architecture IO::Select MX ‘docomo’ MX . SMTP . . docomo ‘au’ MX ‘dist’ daemon MX ‘softbank’ . . . au MX ‘default’ MX . . . softbank ‘send’ daemon MySQL processes MX MX . other ISP . . one server 15
  • 16. current operation MX MX . . . docomo mobamail MX MX SIELLA ENGINE . . . au MX mobamail MX . . . softbank better MX performance MX without tuning . other ISP . 16 .
  • 17. mobamail will be available at... • http://sourceforge.jp/projects/moba/ • http://d.hatena.ne.jp/tokiharu/ (w/RSS) 17
  • 19. DeNA & Perl, again 19
  • 20. DeNA dev policy • • ... • • => • / • ... 20
  • 21. ambivalent love • 100 Perl CPAN ? • ( ) • ... • DeNA Perl • : ( ) • = → • CPAN ( ) ! 21
  • 22. DeNA gonna love CPAN • • Some pilot projects depend on a lot of CPAN modules (and Catalyst) • • dev policy for the large team • more test code • MobaSiF next generation 22
  • 23. DeNA loves Perl! • a Perl community cosists of 100 engineers • Let’s write code together! • as DeNA software engineer / architect • as developer of Mobage-town applications • as CPAN author 23