You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session. Dismiss alert

ããã¼ãã©ã¯ã¼ãç¦å²¡æ ç¹ã®è²¬ä»»è ããã¦ããã¾ã é»ç° ã§ãã æ®æ®µã¯Railsã¨ã³ã¸ãã¢ã¨ã㦠ããã¼ãã©ã¯ã¼ãã¯ã©ã¦ãçµè²» ã®éçºãæ å½ãã¦ãã¾ãã æ®æ®µRailsã使ã£ã¦éçºããã¦ããæ¹ã§ããã°ãN+1åé¡ã«æ©ã¾ãããçµé¨ã¯å¤§æµã®æ¹ããããã§ã¯ãªãã§ããããã N+1ãªã¯ã¨ãªã®çºè¦ã«ã¯ bullet ã使ãã¨è¯ãã§ããã bulletã使ãã¨N+1ãªã¯ã¨ãªãçºè¦ãã¦ãããããã«ãå ·ä½çã«ããã«includesã追å ããªããã¨ææã¾ã§ãã¦ãããã®ã§å¤§å¤å©ããã¾ãã ããããå æ¥bulletã«è¨ããããã¾ã¾ã«includesãä»ãã¦ã¿ãã¨ãããN+1ã¯è§£æ¶ãããã®ã®ãã¹ãã¼ã¯ã¨ãªã«è¦èããããã¨ã¨ãªã£ãã®ã§ãincludes,preload, eager_loadã«ã¤ãã¦æ¹ãã¦èª¿ã¹ã¦ã¾ã¨ãã¦ã¿ããã¨ã«ãã¾ããã ï¼ã½ã¼ã¹èª¿æ»ããRailsã®ãã¼ã¸ã§ã³ã¯ 6.0.0.beta3 ã§ããï¼ i
åç (3件ä¸ã®1件ç®) Rubyã®å®è¡é度ã«èå³ããã£ã¦ã15å¹´ãããMRIã®éçºããã¦ãã¾ããèå³ãããã®ã§é·ãè¨äºã«ãªã£ã¡ãã£ããã¨ããè©«ã³ãã¾ãã é ãã¨è¨ã£ãã¨ããå¤åãå®è¡é度ãã®è©±ããã¦ãããã ã¨æãã¾ããããã以å¤ã«ãçµæ§ããããªãã¯ããããããã¾ããæãã¤ãã¨ããã§å°ããç´¹ä»ãã¾ãã (1) ããã°ã©ã ãä½ãã¯ãã Ruby ã¯çç£æ§ãé«ãè¨èªã¨è¨ããããã¨ãå¤ãã®ã§ãããã°ã©ã ãä½ãæ©ãã¯æ©ããã¨ããè©ä¾¡ãä¸è¬çã§ãã Cã§æ¸ãã¨2æ¥ããããå®è¡æéã¯0.1ç§ Rubyã§æ¸ãã¨1æ¥ããããå®è¡æéã¯10ç§ï¼Cã®100åï¼ ã¨ãããã極端ãªä»®å®ãç½®ãã¦ã¿ãã¨...
11. I'm yoku0825 â ã¨ããä¼æ¥ã®DBA â ãªã©ã¯ããªã â ãã¹ã°ããªã â ãã¤ã¨ã¹ãã¥ã¼ã¨ã â 家ã«å¸°ã㨠â å«ã®å¤« â ãããã®ç¶ â 馬鹿ã ãããããããããããªãã¦ããããã ã¤ã«ã«ããã¾ãã¾ãã«ã ã£ã 12. ã¯ããã« â ãµã³ãã«ãã¼ã¿ã¯ MySQLã®ãµã³ãã«ãã¼ã¿ ãã¼ã¹(worldãã¼ã¿ãã¼ã¹)ããã¤ã³ãã㯠ã¹ãå ¨ã¦åã£æã£ããã®ã§ã â http://dev.mysql.com/doc/index-other.html â ã³ã¼ãã¯githubã«ä¸ãã¦ããã¾ã â https://github.com/yoku0825/yapc_2014 â ãããâ¦ã¦ã³ã³ã¼ãã§ã⦠13. ã¯ããã« â ååãMySQLã¯1ã¤ã®ãã¼ãã«ã«ã¤ãåæã«1 ã¤ã®ã¤ã³ããã¯ã¹ãã使ãã¾ãã â Index mergeã¨ããããã©ã¢ã¬ã¯ä¾å¤ã ãçã£ã¦ ãã£ã¦ãéããªã
ã¯ããã« ãã¬ã³ããªã³ã°ã®ä»çµã¿ãªãã¦ç¥ããªãã¦ãããã©ã¦ã¶ãåæã«ãã£ã¦ããããããï¼ã å½æé§ãåºãã®ã¨ã³ã¸ãã¢ã ã£ãç§ã¯ããæã£ã¦ãã¾ããã å®éãå½æã®ç§ã¯ã¬ã³ããªã³ã°ã®ãã¬ãã®åãç¥ãã¾ããã§ããããç¹ã«æ¥åä¸ã§åé¡ã¯ããã¾ããã§ããã ãããããã®æã¯çªç¶è¨ªãã¾ããã ã¯ã©ã¤ã¢ã³ãã®è¦æã§ã¢ãã¡ã¼ã·ã§ã³ãå¤å½©ã«åãå ¥ããæ¡ä»¶ãå®è£ ããéã«ããã¹ã段éã§ä¸é¨ãã©ã¦ã¶ï¼SâfâriãEâgeï¼ã§ã¢ãã¡ã¼ã·ã§ã³ãã²ã©ãç¶æ³ã«ãªã£ã¦ãããã¨ãçºè¦ãã¾ããã (éçºä¸ã¯Chromeã§ç¢ºèªãè¡ã£ã¦ãããChromeã§ã¯ç¹ã«åé¡ã¯ãªãã£ãã®ã§çºè¦ãé ãã¾ããã) ããããã¯ãçã£ãããã«ããã©ã¼ãã³ã¹ã®æ¹åæ¹æ³ãã°ã°ããä¿®æ£ããæ¥ã ãç¶ãã¾ãããï¼æçµçã«ã¯ããªãã¨ããã«ããã©ã¦ã¶ã§ã®åä½ãæ ä¿ããç´åã¾ã§å®äºãã¾ãããï¼ ãã®æ¡ä»¶ãè½ã¡çããå¾ãæ¹ãã¦èªåã®èª¿ã¹ããã¨ãæ¯ãè¿ãã¨ãå±æçãª
ããã«ã¡ã¯ããµã¼ãã¹éçºé¨ã®èå¼ (@a_bicky) ã§ãã çªç¶ã§ãããRDBMS ã®æ¢åã®ãã¼ãã«ãè¦ã¦ã¿ãããä½ã§ãããªã«ã¤ã³ããã¯ã¹ã ãããªã®ï¼ãã¿ãããªçµé¨ã¯ããã¾ãããï¼ä¸è¦ãªã¤ã³ããã¯ã¹ã¯å®¹éãå§è¿«ããããæ¿å ¥ãé ããªã£ããã¨è¯ããã¨ãããã¾ããã ãããªããã§ãä»åã¯ã¬ã³ã¼ããæ¤ç´¢ããããã«å¿ è¦ãªã¤ã³ããã¯ã¹ã®åºç¤ç¥èã¨ãããè¦ãããä¸é©åãªã¤ã³ããã¯ã¹ã«ã¤ãã¦è§£èª¬ãã¾ããã¯ãã¯ãããã§ã¯ Rails ã®ãã¼ã¿ãã¼ã¹ã¨ãã¦ä¸»ã« MySQL 5.6ãMySQL ã®ã¹ãã¬ã¼ã¸ã¨ã³ã¸ã³ã¨ãã¦ä¸»ã« InnoDB ã使ã£ã¦ããã®ã§ãMySQL 5.6 ã® InnoDB ã«ã¤ãã¦è§£èª¬ãã¾ãã InnoDB ã®ã¤ã³ããã¯ã¹ã«é¢ããåºç¤ç¥è ã¤ã³ããã¯ã¹ã®æ§é (B+ æ¨) InnoDB ã§ã¯ B+ æ¨ã使ããã¦ãã¾ããB+ æ¨ã¯æ¬¡ã®ãããªç¹å¾´ãæã£ãæ¨æ§é ã§ãã 次æ°ã b ã¨ããã¨ã
Rubyã®æ¨æºæ·»ä»ã©ã¤ãã©ãªã¼ã®csvãã¡ã³ããã³ã¹ãã¦ããé è¤ã§ãã æ´å² csvã¯ååã®éãCSVãèªã¿æ¸ãããããã®ä¾¿å©ã©ã¤ãã©ãªã¼ã§ãã ãã¨ãã¨Rubyæ¬ä½ã¨ã¯å¥ã«éçºããã¦ããã®ã§ãããRuby 1.8.0ã®ã¨ãã«Rubyæ¬ä½ã«ãã³ãã«ããããã«ãªãã¾ãããdRubyãREXMLãRubyæ¬ä½ã«ãã³ãã«ãããã®ãåãã¿ã¤ãã³ã°ã§ããRuby 1.8.0ã®ã¨ãã«ãã³ãã«ããã©ã¤ãã©ãªã¼ããããå¢ãããã®ã§ããï¼ãã®é ã®æ§åããããURLãããã«ç½®ãã¦ããããã£ããã©è¦ã¤ããããªãã£ããããï¼ Rubyã§ã¯csvã®ããã«requireããã ãã§ä½¿ããã©ã¤ãã©ãªã¼ããæ¨æºæ·»ä»ã©ã¤ãã©ãªã¼ãã¨å¼ãã§ãã¾ããStringã®ããã«requireããªãã¦ã使ããã©ã¤ãã©ãªã¼ã¯ããããªãã ãããçµã¿è¾¼ã¿ã¯ã©ã¹ãããã ãã®å¾ãRuby 1.9.0ã®ã¿ã¤ãã³ã°ã§å®è£ ãFasterCSVã«ç½®ãæã
DBã®ã¬ã¤ã¤ã¼ãå«ãã¨ã³ããã¼ã¨ã³ããã¹ããDBã«ä¾åããã³ã³ãã¼ãã³ãã®èªåãã¹ããããããããã¨ãå ¨ã¦ã®ãã¹ããçµããã¾ã§ã«é·ãæéããããããã«ãªã£ã¦ãã¾ããã¨ãããã¾ããDBã®ã¯ã¨ãªå®è¡ã¯ãããã¯ã¼ã¯IOããã£ã¹ã¯IOãªã©ãå«ãã é«ã³ã¹ããªå¦çã ããã§ãã Docker ãå°ã工夫ãã¦ä½¿ãã¨ããæ軽ã«ãã¹ãä¸ã®DBã®ã¯ã¨ãªå®è¡ã«ãããæéãåæ¸ã§ãã¾ããèªåãã¹ããå®äºããã¾ã§ã®å¾ ã¡æéãç縮ããéçºã®ãã£ã¼ãããã¯ãµã¤ã¯ã«ãããæ©ãåããããã«ãªãã¾ãï¼ MariaDB ãç¨ããããã¸ã§ã¯ãã®å®ç¸¾ã§ã¯ãDBã¢ã¯ã»ã¹ãä¼´ããã¹ãã±ã¼ã¹ã 153件 ããã¾ãããããã®æ¹æ³ã«ãããã®ãã¹ãã¹ã¤ã¼ãã®ãã¼ã«ã«ç°å¢ã§ã®å®è¡æéãç´ 43% åæ¸ã§ãã¾ããï¼ç´ 145.7s â ç´ 83.3sï¼ã ã©ããã£ã¦ï¼ Docker 㧠tmpfs ã使ãã¾ãã tmpfs tmpfs ã¨ã¯ããã£ã¹
Ubiregi Advent Calendar 2018 ã® 18 æ¥ç®ã§ãã ã¦ãã¬ã¸ã§ã¯ããããã®ã客æ§ã®å¤§éã® POS ãã¼ã¿ããé ãããã¦ãããæ§ã ãªãããå¦çãå®è¡ããã¦ãã¾ããä»åã¯ç¹å®ã®ã±ã¼ã¹ã§ãããå¦çã®ä¸é¨ã 30 å以ä¸ããã£ã¦ããå¦çã 14 ç§ã§çµããããã«ãã話ã«ã¤ãã¦æ¸ãããã¨æãã¾ããååã® Ruby 2.5 ã® SEGV ã¨éã£ã話 - @watson1978 ã®æ¥è¨ ã«å¼ãç¶ã DTrace ã使ã£ã話ã«ãªãã¾ãã ã¯ããã« ã¦ãã¬ã¸ã§ã¯ CSV ãã¡ã¤ã«ã§ã客æ§ãç¹å®ã®ãã¼ã¿ããã¦ã³ãã¼ããããã¢ãããã¼ãã§ããæ©è½ãããã¾ããCSV ãã¡ã¤ã«ã«ã¨ã¯ã¹ãã¼ãããããCSV ãã¡ã¤ã«ãã DB ã«åãè¾¼ãå¦çã Worker ãèµ·åãã¦ãããå¦çãã¦ãã¾ãã 大éã®ãã¼ã¿ãä¿æãã¦ããã¢ã«ã¦ã³ãã¨åéã®ãã¼ã¿ãç¨æãã¦æå ã®ç°å¢ã§è©¦ããã¨ããæéããããã
æ¬è¨äºã¯ãä¸ä¼.com Advent Calendar 2018ã®4æ¥ç®ã®è¨äºã§ãã qiita.com å®é½å®®ã§ãã宿æ³äºæ¥æ¬é¨ã§Webããã³ãã¨ã³ãã®éçºããã¦ãã¾ãã ä»æ¥ã¯ãããã©ã¼ãã³ã¹æ¹åã«åãçµãããã³ãã¨ã³ãã¨ã³ã¸ãã¢ã®å¤ããé ãæ©ã¾ãã¦ããã§ãããããµã¼ããã¼ãã£ã¹ã¯ãªãã(3rd Party JavaScript)ã«ã¤ãã¦æ¸ãã¾ãã ãµã¼ããã¼ãã£ã¹ã¯ãªããã¨ã¯ ãµã¼ããã¼ãã£ã¹ã¯ãªããã¨ã¯ãå¤é¨ã®ãã¡ã¤ã³ããèªã¿è¾¼ãJavaScriptã®ãã¨ã§ããå ¸åçã«ã¯ãGoogle Analyticsçã®ã¹ã¯ãªãããããµã¼ããã¼ãã£ã¹ã¯ãªããã«è©²å½ãã¾ãã ä¸ä¼.comã§ã¯ããµã¼ããã¼ãã£ã¹ã¯ãªããããã¢ã¯ã»ã¹è§£æã»åºåã®ãªã¿ã¼ã²ãã£ã³ã°ã»A/Bãã¹ãçãæ§ã ãªç¨éã«ä½¿ç¨ãã¦ãã¾ãããããã®ã¹ã¯ãªããã¯ãä¸ã¤ä¸ã¤ã¯å°ããªãã®ã§ãããããç»é¢è¡¨ç¤ºã®ã¹ãã¼ãã«å¯¾ããã¤ã³ãã¯ãã¯æè
æè¡é¨ã®ãã«ã¿ã¤ã Rubyã³ããã¿ã®é è¤ï¼@mametterï¼ã§ããæ¨æ¥ã® Hackarade #04 ã®éå¬å ±åã«ç¶ãã2æ¥é£ç¶ã§è¨äºãæ稿ãã¾ãã ä»åã¯ãããæ¡ä»¶ä¸ã§ã®Rubyã®å®è¡é度ãé«éåãã話ãç´¹ä»ãã¾ãããã®æ¹åã¯ãã§ã«MRIã®å 端ã«ã³ãããããã¦ãã¦*1ãå¹´æ«ãªãªã¼ã¹äºå®ã®Ruby 2.6ã«å«ã¾ããäºå®ã§ãã ã²ã¨ãã¨ã§è¨ãã¨ããç°¡æ½ããããã¯ãã«ãç´¢å¼ã«ä½¿ããã¨ã§ãããã°ã©ã ã«ã¦ã³ã¿ããè¡çªå·ãè¨ç®ããã¢ã«ã´ãªãºã ãO(log N)ããO(1)ã«æ¹åãããããã«ãããTracePointæå¹æãã³ã¼ãã«ãã¬ãã¸æ¸¬å®ä¸ã§ãé·ã N ã®ã¡ã½ããã®å®è¡ã O(N log N) ãã O(N) ã«é«éåããããã¨ãããã¨ã§ããé ã«èª¬æãã¾ãã èæ¯ï¼Rubyã®ãã¤ãã³ã¼ãã®æ§é ãã®æé©åãç解ããã«ã¯ã¾ããRubyã®ãã¤ãã³ã¼ãã®ããç¹å¾´ãç¥ãå¿ è¦ãããã¾ãã ãã¨ãã° x
æ¦è¦ Railsãéçºããä¸ã§ããã©ã¼ãã³ã¹ãä½ä¸ãããªãããã®Tipsãã¡ã¢ Tips å®è¡æéã®å¤§ããå¦çã¯Jobã§éåæå®è¡ãã ãªã¯ã¨ã¹ãå ã§è¤æ°ãªå¦çãå®è¡ãã¦ãã¾ãã¨ãã¬ã¹ãã³ã¹ãé ããªãã¦ã¼ã¶ããªãã£ã®ä½ä¸ã«ã¤ãªããã¾ã ãªã¯ã¨ã¹ãå ã§å®è¡ããå¿ è¦ããªããã®ã¯ãActiveJobçã§éåæã«å®å¹ãããããããå¦çã§å®æçã«å¦çããããã« ãããã¨ã§ã¦ã¼ã¶ããªãã£ã®åä¸ãå³ãã¾ã æ¡ä»¶å¼å¤å®ãããSQLã§çµã åå¾ãã¦ãããã¼ã¿ã1件ãã¤æ¡ä»¶åæ ãã¦å¦çãããããã¯ã åå¾ãããã¼ã¿ãã®ãã®ãSQLã§çµãæ¹ãã¯ããã«ããã©ã¼ãã³ã¹ãè¯ããªãã¾ã ã«ã¼ãã®ä¸ã§æ¯åæ¡ä»¶å¼ã§åæ ãã¦ãã¾ãã¨ãã«ã¼ãã®ä¸ã§æ¯åSQLãèµ°ã£ã¦ãã¾ããã¨ãããã®ã§ã ããã©ã¼ãã³ã¹ãè¦æ±ãããå ´åã¯SQLã§çµãããSQLã§çµããè¨è¨ã«ãããã¨ããããããã¾ã Array ããã ActiveRecord:
Rails Developers Meetup 2018: Day 2( https://techplay.jp/event/655769 )ã§è¡ã£ãçºè¡¨ã®è³æã§ãã ActiveRecordã¯Webã¨ã³ã¸ãã¢éãå«ãï¼ï¼ï¼SQLãæ¸ããã¨ããRubyãªãã¸ã§ã¯ãã§æ°è»½ã«ãã¼ã¿ãã¼ã¹ã¸ã¢ã¯ã»ã¹ã§ããéâ¦
ä»äºãããªãããã§MySQLã®ã¯ã¨ãªã®è¯ãæªããå¤æããå¿ è¦ãããã¨ããEXPLAINã®å 容ã ãã ã¨ã©ã®ãããè¯ããªã£ããæªããªã£ãã®ãåãããªãã®ã§ SET long_query_time = 0; ãã¦rows_examined (ãã®ã¯ã¨ãªã§rows_sentè¡ã®çµæãè¿ãããã«ä½è¡ã«è§¦ã£ãã®ã)ãä¸ç·ã«æ示ããããã«ãã¦ãã(å°ãªãã¨ãMySQL 5.7æç¹ã§ã¯rows_examinedã¯slow_query_logã§ãã確èªã§ããªãã¯ãperformance_schemaãæå¹ãªãevents_statements_historyããã®ä»²éãã¡ã§ç¢ºèªã§ããã¨ã®ãã¨*1 MySQL :: MySQL 5.6 ãªãã¡ã¬ã³ã¹ããã¥ã¢ã« :: 22.9.6 ããã©ã¼ãã³ã¹ã¹ãã¼ãã¹ãã¼ãã¡ã³ãã¤ãã³ããã¼ãã«)ã ä¾: ä¸ã®ä¾ã®Beforeã¯ããã¨ãã¨DBAãæ¸ãã温ãã¿ã®ããSQLã§O
ãç¥ãã
ã©ã³ãã³ã°
ã©ã³ãã³ã°
ãªãªã¼ã¹ãé害æ å ±ãªã©ã®ãµã¼ãã¹ã®ãç¥ãã
ææ°ã®äººæ°ã¨ã³ããªã¼ã®é ä¿¡
å¦çãå®è¡ä¸ã§ã
j次ã®ããã¯ãã¼ã¯
kåã®ããã¯ãã¼ã¯
lãã¨ã§èªã
eã³ã¡ã³ãä¸è¦§ãéã
oãã¼ã¸ãéã
{{#tags}}- {{label}}
{{/tags}}