欢迎来到天天文库
浏览记录
ID:34520737
大小:481.18 KB
页数:28页
时间:2019-03-07
《From Python to Go… and Back Again!.pdf》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、FromPythontoGo,BenBangertMozillaOct14,2015MyPaththusFarFromPythontoGoPythonsince2004●WrotethefirstpartofPylons(Routes)in2005●MergedPylonswithrepoze.bfg->Pyramidin2010●Pyramidstillrocks!●MyworkatcompaniesinthistimewasinPython●StartedworkingatMozillain2011LifeatMozilla●FirstProject-Queuey○Not
2、ificationStorageSystematScale○Python+Cassandra○Neverused/deployed○Kazoosupportinglibwas!LifeatMozilla●SecondProject-heka○LearnedGoin2012○Go1.0justlaunched○Simple,fastlanguagetogetstartedin●OtherProjects○Pushsystem(firstprototypeinGo)●CurrentProject○PushSystem(continuingiterations)Goisawesom
3、e!●Simplelanguage●Niceconcurrencyprimitives●Fairlyconcisecode●MuchfasterthanPython●…andwhateverelsetheInternethassaidProblemsinGo-landGoroutineMemoryUse●Ver1.2○8kbstacksize(overoriginal4kb)○Expensiveforstandardsocketmodel■Onereader■OneWriter○RefactorPushtoonlyhavereadersperconn,poolofwriter
4、s●Ver1.4○2kbstacksize(withbettercontiguousstacksizingalgo)○Willrequirelargerefactorofcodetogobacktonewlyoptimalreader/writerperconn○RefactorstillmakessenseduetootherissuesfoundwithwriterpoolDebugging●Mosterrorsarebasicstrings(Add’tlintrospectionrequireserrorcastingtopullouterrors)●Basicstri
5、ngslackcontextoncall-stack●Manylibrariesusesimilarerrorstringsinmultipleplaces●Boilerplateforerrorhandlingistedious●Livedebuggingoptionattimewasgdb,notfun(godebugrecentlyavailablelookslikeagreatimprovement)GoroutineLeaks●Channelsareneat,butdangerous●Deadlockdetectordoesn’tspotgoroutineleaks
6、●Goexpertsstillcan’twriteleak-freecode●Goroutineleaksareannoyingtopin-down●AddingsuitableselectstatementsintroducesmoreboilerplateTesting●Everythingshouldbeaninterface!●Can’tmockanargumentunlessitsaninterface○Manylibrariesdon’tprovideinterfacesforcomplexstructs,soyougettofabricateacomplexin
7、terfacesothewholethingcanbemocked●Extensivesinterfacesneededallover,regardlessofappropriateness●Verylaborintensivetoachievehighdegreeoftesting(andmanyadditionalLoC)AReturntoPythonAquickPythonprototype….●Usedtwisted/Python2.7usingautobahnwebsocketlibrary●
此文档下载收益归作者所有