闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柤鍝ユ暩娴犳氨绱撻崒娆掑厡缂侇噮鍨跺畷褰掑礈娴g懓搴婂┑鐐村灦閻熝呭姬閳ь剟姊虹粙娆惧創濠殿喓鍊濋幆鍕敍閻愬弶鐎梺鐟板⒔缁垶寮查幖浣圭叆闁绘洖鍊圭€氾拷
MYSQL濠电姷鏁告慨鐑藉极閸涘﹥鍙忓ù鍏兼綑閸ㄥ倿鏌i幘宕囧哺闁哄鐗楃换娑㈠箣閻愨晜锛堝┑鐐叉▕娴滄繈寮查幓鎺濈唵閻犺櫣灏ㄦΛ姘舵煕閳哄啫浠辨慨濠冩そ濡啫鈽夊顒夋毇闂備胶鎳撻崲鏌ヮ敄婢跺﹦鏆︽い鏍仜瀹告繈鎮楀☉娆嬬細闁告﹩浜濈换婵嬪閿濆棛銆愰梺缁橆殔濡繂鐣峰┑鍡╂僵闁瑰吀绀佹禍楣冩⒒閸喓鈽夌紒銊ヮ煼閺岀喖宕欓妶鍡楊伓
SQL闂傚倸鍊搁崐宄懊归崶顒夋晪鐟滃秹婀侀梺缁樺灱濡嫰寮告笟鈧弻鐔兼⒒鐎靛壊妲梺绋胯閸斿酣骞夐幖浣告閻犳亽鍔嶅▓楣冩⒑濮瑰洤鐏╁鐟帮躬瀵偊宕堕浣哄幗濠殿喗顨呭Λ妤佺濠婂厾鐟扳堪閸垻鏆梺鍝勭焿缂嶄焦鎱ㄩ埀顒勬煏閸繃顥為梺娆惧弮閺岋綁濮€閳轰胶浠╅梺缁樼墪閵堢ǹ顕g拠娴嬫婵☆垶鏀遍悗璇测攽閻愬弶顥為柛鏃€娲熼、鏃堟晸閿燂拷
MYSQL闂傚倸鍊搁崐宄懊归崶顒夋晪鐟滃秹锝炲┑瀣櫇闁稿矉濡囩粙蹇旂節閵忥絾纭鹃柤娲诲灦瀵悂宕奸埗鈺佷壕妤犵偛鐏濋崝姘舵煙瀹勯偊鍎忛柕鍡樺笚缁绘繂顫濋鐘插箞闂佽绻掗崑娑欐櫠娴犲鐓″璺虹灱绾惧ジ鏌涢幘鑼槮濞寸娀浜堕弻锛勪沪閸撗勫垱婵犵绱曢崗姗€銆佸☉妯峰牚闁告侗鍠楅蹇涙⒒閸屾瑦绁版俊妞煎妿濞嗐垽濡舵径濠勵唵闂佽法鍣﹂幏锟�
闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柤鍝ユ暩娴犳氨绱撻崒娆掑厡缂侇噮鍨跺畷褰掑礈娴g懓搴婂┑鐐村灦閻熝呭姬閳ь剟姊虹粙娆惧創濠殿喓鍊濋幆鍕敍閻愬弶鐎梺鐟板⒔缁垶寮查幖浣圭叆闁绘洖鍊圭€氾拷
闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晜閽樺缃曢梻浣虹《閸撴繈鎮疯閹矂骞樼紒妯衡偓鍨箾閹寸儐浼嗛柟杈剧畱閻鐓崶銊р姇闁绘挾鍠栭弻锟犲礃閵娿儮鍋撻崫銉︽殰闁割偅娲橀埛鎺楁煕鐏炶鈧洟鎮橀敃鍌涚厸閻忕偟鍋撶粈鍐磼缂佹ḿ娲寸€规洖缍婇、娆撴偂楠烆喓鍊栫换婵堝枈濡搫鈷夐梺缁樻尨閳ь剛绻€缂傛氨鎲搁弬鍖¤€垮〒姘e亾婵﹨娅g槐鎺懳熼弴鐔风仼缂侇喖锕獮姗€顢欓懖鈺嬬幢闂備胶鎳撴晶鐣屽垝椤栫偛纾婚柛鏇ㄥ幘绾捐棄霉閿濆拋娼犳い蹇撶墱閺佸倿鏌嶆潪鎷岊唹闁衡偓娴犲鐓熼柟閭﹀墯閳绘洟鏌涢妶鍥ф瀻闁宠鍨块、娑樷槈濞嗗繐鏀俊銈囧Х閸嬫稓鎹㈠鈧顐﹀箻缂佹ɑ娅㈤梺璺ㄥ櫐閹凤拷
闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柛顐f礀閸屻劎鎲搁弮鍫澪ラ柛鎰ㄦ櫆閸庣喖鏌曡箛瀣労婵炶尙枪閳规垿鎮╃拠褍浼愰柣搴㈠嚬閸欏啫鐣烽敐鍫㈢杸婵炴垶鐟ч崢鎾绘⒑閸涘﹦绠撻悗姘煎墴閸┾偓妞ゆ巻鍋撻柟鑺ョ矊閳诲酣濮€閵堝棗鈧兘鏌i幋鐐ㄧ細闁告﹢浜跺娲濞戣鲸鈻撻梺鎼炲妽婵炲﹪骞冩ィ鍐╃劶鐎广儱妫涢崢鍛婄箾鏉堝墽鍒版繝鈧柆宥嗗剹闁圭儤顨嗛悡娑㈡倶閻愰鍤欏┑鈥炽偢閺屽秹鎸婃径妯恍﹂柧浼欑秮閺屾盯鈥﹂幋婵囩彯婵炲鍘ч崯鏉戭潖缂佹ɑ濯村瀣凹鐟曞棛绱撻崒姘毙¢柤鍐插閸掓帗绻濆顒€鍞ㄩ悷婊勭矒瀹曠敻寮撮悢缈犵盎闂佸搫鍟崐鍛婄閸撗€鍋撶憴鍕妞わ富鍨舵俊鎾箳閹搭厽鍍甸梺缁樻尭濞撮攱绂掗銏$厸鐎广儰璁查崑鎾诲棘閵夛附鏉搁梻浣虹帛閸旀洖螣婵犲洤鍚归柣鏂跨殱閺€鑺ャ亜閺嶃劎鈯曢悘蹇ラ檮椤ㄣ儵鎮欓懠顒傤啋闂佽桨鐒﹂幑鍥极閹剧粯鏅搁柨鐕傛嫹
闂傚倸鍊搁崐宄懊归崶褏鏆﹂柛顭戝亝閸欏繒鈧娲栧ú锔藉垔婵傚憡鐓涢悘鐐额嚙閸旀岸鏌i妶鍥т壕缂佺粯鐩畷鍗炍熼搹閫涙偅缂傚倷璁查崑鎾斥攽閻樻彃鏆為柛娆忕箲娣囧﹪鎮欐0婵嗘婵炲瓨绮撶粻鏍ь潖閾忚瀚氶柍銉ョ-娴犫晠姊洪崫銉ユ瀾婵炲吋鐟╅幃楣冩倻閼恒儱浜滅紒鐐妞存悂寮查姀锛勭閺夊牆澧界粔顒併亜閺囩喓澧电€规洦鍨堕崺鈧い鎺戝閳锋帡鏌涚仦鍓ф噯闁稿繐鏈妵鍕閻欏懓鍚銈冨灪瀹€绋款嚕娴犲鏁囬柣鎰暩瀹曡埖绻濆閿嬫緲閳ь剚鍔欏畷鎴﹀箻濞n兛绨婚梺瀹犳〃闂勫秹宕戦姀鈶╁亾鐟欏嫭绀€闁靛牊鎮傞獮鍐閵忊€充粧闂佹枼鏅涢崯鐗堢濞嗘挻鈷戦悹鍥ㄧ叀椤庢绱掗悩鑼х€规洘娲樺ḿ蹇涘煘閹傚濠殿喗岣块崢褔鐛Δ鍐<閻庯綆浜跺Ο鈧繝娈垮枓閸嬫捇姊虹紒妯兼喛闁稿鎹囬弻锝夊棘閹稿寒妫﹂梺璇″枦椤骞忛崨顖滈┏閻庯綆鍋嗙粔鐑芥⒑鐠囨彃顒㈤柣鏃戝墴楠炲繘鏁撻敓锟�

适用于 Java 的 AWS 开发工具包 Amazon Aurora Serverless 数据 API - java教程是冷启动和热启动的部分优化策略

首页 2024-07-10 02:15:58

介绍

关于如何在本系列之前使用它 Data API 和 AWS SDK for Java 从 Lambda 函数连接到 Amazon Aurora Serverless v2 在文章中,我们对冷启动和热启动进行了基本的测量,比较了 Data API 和 JDBC 冷启动和热启动之间的测量SnapStart 有或没有底漆都有效果。

在本系列的这一部分,我们将介绍冷启动和热启动的优化策略。

冷启动和热启动的优化策略

为了在冷启动时间和热启动时间之间找到良好的平衡,您可以尝试以下优化技术。我还没有使用它 Data API 和 Amazon Aurora Serverless v2 与 PostgreSQL 任何测量数据库,但使用 DynamoDB 类似场景的数据库。我将为我的相关文章提供参考。

  • 尝试不同的 Lambda 内存设置。到目前为止,所有的测量都被使用了。 Lambda 函数的 1024 MB 执行内存。通过不同的内存设置,您可能会以合理的价格获得更好的性能。请参阅我的文章,使用不同的文章 Lambda 使用内存设置 Java 21 测量冷启动、热启动和部署时间,以了解使用情况 DynamoDB 说明测量。
  • 尝试 Lambda 函数的不同 Java 编译选项。到目前为止,所有的测量都被使用了。 Lambda 函数编译选项“-XX: TieredCompilation -XX:TieredStopAtLevel=1”执行的。可使用名称 JAVA_TOOL_OPTIONS 环境变量方向 Lambda 函数提供了更多的其他选项,该变量具有不同的冷启动和热启动权衡。请参阅我的文章“使用” Java 21 用不同的编译选项测量冷启动和热启动,以了解使用情况 DynamoDB 说明测量。
  • 尝试不同的同步 HTTP 客户端通过 Data API 与数据库建立 HTTP 连接。到目前为止,所有测量都使用默认同步 HTTP 客户端(Apache)执行。还有其他选项,如 UrlConnection 和 AWS CRT HTTP 在客户端,它们为冷启动和热启动提供不同的性能权衡。

这是创建/构建 RdsDataClient 时使用 AWS CRT HTTP 客户端示例。 URLConection客户端可以类似设置。

RdsDataClient.builder().httpClient(AwsCrtHttpClient.create()).build()

另外,不要忘记使用正在使用的东西 HTTP 客户端的依赖项包含在客户端中 pom.xml 中,如下所示:

        <groupid>software.amazon.awssdk</groupid><artifactid>aws-crt-client</artifactid>依赖&gt;

请参考我的文章“使用不同步” HTTP 客户端从 Java 21 测量冷热启动,以获取说明、代码示例和使用 DynamoDB 进行测量。

立即学习“Java免费学习笔记(深入);

  • 探索数据 API 的异步 HTTP 客户端是否适合您的用例。默认异步 HTTP 客户端是 NettyNio。还有另一个选项 AWS CRT 异步 HTTP 客户端为冷启动和热启动提供不同的性能平衡。

它是在创建/构建 RdsDataAsyncClient 时使用异步 AWS CRT HTTP 客户端示例(我们需要使用异步 HTTP 在客户端的情况下构建)。

RdsDataAsyncClient.builder().httpClient(AwsCrtAsyncHttpClient.create()).build()

另外,不要忘记使用正在使用的东西 HTTP 客户端的依赖项包含在客户端中 pom.xml 中,如下所示:

        <groupid>software.amazon.awssdk</groupid><artifactid>aws-crt-client</artifactid>依赖&gt;

必须在这种情况下使用 Java 因此,异步编程模型(这本身就是讨论的主题) RDSDataAsyncClient 调用上述方法的每个方法都将返回 Java CompletableFuture 对象。请参阅我的文章,使用不同的异步 HTTP 客户端通过 Java 21 测量冷启动和热启动,以获得说明、代码示例和使用 DynamoDB 的测量。

对于所有潜在的优化策略,您可以 Lambda 函数上启用 SnapStart,并另外测量 DynamoDB 调用启动的影响,如本系列最后一篇文章 Data API meet SnapStart 中所述。

还要注意我在文章中描述的快照分层缓存对冷启动的影响。因为我总是部署新版本 Lambda 函数后提供 first 100 二次冷启动测量。当使用分层缓存时,我测量并描述了随着更多的后续调用,冷启动显著减少。经过一定数量的调用后,它是特定的 Lambda 保持版本不变。

结论

我们在这篇文章中使用它 Amazon Aurora Serverless v2 的数据 API 和适用于 Java 的 AWS 开发工具包提供了冷启动和热启动的优化策略,您可以探索该策略,以找出适合您使用的最佳性能。

以上是适用的 Java 的 AWS 开发工具包 Amazon Aurora Serverless 数据 API - 更多关于冷启动和热启动部分优化策略的细节,请关注其他相关文章!


p
SEO闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗ù锝堟缁€濠傗攽閻樻彃鈧绱撳杈ㄥ枑闊洦娲橀~鏇㈡煟閹邦剦鍤熺紒鈾€鍋撻梻浣规偠閸庢粓宕堕…鎺旇埞婵犵數濮烽弫鎼佸磻濞戞鐔哥節閸愵亶娲稿┑鐘诧工閻楀﹦鈧艾鎳橀弻锝夊棘閸喗鍊梺缁樻尪閸庣敻寮婚敐澶婂嵆闁绘劖绁撮崑鎾诲捶椤撴稑浜炬慨妯煎亾鐎氾拷
闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晜閽樺缃曢梻浣虹《閸撴繈鎮疯閹矂骞樼紒妯衡偓鍨箾閹寸儐浼嗛柟杈剧畱閻鐓崶銊р姇闁绘挾鍠栭弻锟犲礃閵娿儮鍋撻崫銉︽殰闁割偅娲橀埛鎺楁煕鐏炶鈧洟鎮橀敃鍌涚厸閻忕偟鍋撶粈鍐磼缂佹ḿ顬兼い锔界叀閺岋繝宕奸銏犫拫閻庤娲滄繛鈧柟顔规櫇缁辨帒螣闁垮顏瑰┑鐘垫暩閸嬬姷浜稿▎鎴濆灊妞ゆ牗绮嶉鑺ョ箾閹存瑥鐏柣鎾寸懇閺屾盯骞嬪▎蹇婂亾閺嶎偀鍋撳鐐
闂傚倸鍊搁崐椋庣矆娓氣偓楠炴牠顢曚綅閸ヮ剦鏁冮柨鏇楀亾闁汇倗鍋撶换婵囩節閸屾稑娅i梺鎼炲妽缁诲牓鐛弽顬ュ酣顢楅埀顒佷繆婵傚憡鐓熼柟鎯ь嚟缁犳捇鏌嶇憴鍕伌鐎规洘甯掗埞鍐箻閾忣偉纭€闂侀€炲苯澧柤褰掔畺钘濋梺顒€绉撮悞鍨亜閹哄棗浜剧紓浣哄Т缁夌懓鐣烽弴銏$劶鐎广儱鎳愰悿鍥煙閸忓吋鍎楅柣鎾愁槺缁辩偤寮介鐔哄帾闂佸壊鍋呯换宥呂hぐ鎺撶厽闁规儳鐡ㄧ粈瀣煛鐏炶濡奸柍瑙勫灴瀹曞崬螖娴h鍞叉繝鐢靛Х椤d粙宕滃┑瀣畺闁稿瞼鍋涢拑鐔衡偓骞垮劚閻楁粌顬婇妸鈺傗拺缂佸娉曠粻鑼磼鐎n偄鐏存繝鈧笟鈧娲箹閻愭彃濮夐梺鍝勬噺缁矂鎮鹃悜钘夌煑濠㈣泛鐬奸鏇㈡⒑缁洖澧查柨姘舵煟韫囧﹥娅婇柡宀嬬秮椤㈡﹢鎮㈤悜妯烘珣闂備礁鐤囬~澶愬垂閸фぜ鈧礁鈽夊Ο婊勬閸┾偓妞ゆ帊鑳堕々鑼磽瀹ュ洤鐦查梻鍌氬€峰ù鍥敋瑜嶉~婵嬫晝閸岋妇绋忔繝銏e煐閸旀洜绮婚弽顓熺厱妞ゆ劧绲剧粈鈧紒鐐劤濞尖€愁潖濞差亶鏁嗛柍褜鍓涚划鏃堝箻椤旇棄鍓瑰┑掳鍊曢幊蹇涙偂閵夆晜鐓熼柡鍥╁仜閳ь剙婀遍埀顒佺啲閹凤拷
濠电姷鏁告慨鐑藉极閹间礁纾婚柣鎰惈閸ㄥ倿鏌涢锝嗙缂佺姳鍗抽弻鐔虹磼閵忕姵鐏堢紒鐐劤椤兘寮婚悢鐓庣鐟滃繒鏁☉銏$厓闂佸灝顑呴悘锔剧磼缂佹ḿ娲寸€规洖宕灒闁告繂瀚闂傚倷绀侀幖顐︻敄閸℃稒鍋¢柍鍝勬噹閽冪喖鏌i弬鎸庢喐闁荤喎缍婇弻娑⑩€﹂幋婵囩亪濡炪値鍋勫ú顓㈠箖濡も偓閳绘捇宕归鐣屼簴闂備礁鎲¢弻銊︻殽閹间礁鐓″鑸靛姈閸嬨劎绱掔€n亞浠㈢紒鎰☉椤啴濡堕崱娆忣潷缂備緡鍠氭繛鈧€规洦鍨伴悾婵嬪焵椤掑倹顫曢柟鎹愵嚙绾惧吋绻涢崱妯虹劸婵″樊鍠栭—鍐Χ閸℃浠撮梺纭呮珪閿曘垽濡存笟鈧浠嬵敇閻愰潧鈧偛顪冮妶鍡楃瑨妞わ缚鍗冲鎻掆堪閸愮偓瀵岄梺闈涚墕濡绮幒妤佸€垫慨妯煎帶婢ф挳鏌熼姘冲閾绘牠鏌涘☉鍗炴灓闁告瑥妫濆铏圭磼濡崵顦ラ梺绋匡工濠€閬嶅焵椤掍胶鍟查柟鍑ゆ嫹
C闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柛顐f礀绾惧潡鏌i姀鈶跺綊鎮块悙顒傜瘈濠电姴鍊搁弳鐔割殽閻愬瓨宕岄柡灞剧椤﹁櫕銇勯妸銉﹀殗鐎规洖缍婂畷鎺楁倷閼碱剦鍟囬梺鍝勵槸閻楀棙鏅舵禒瀣畺闁稿繘妫跨换鍡樸亜閹伴潧浜滈柣蹇ョ節閺屾洟宕惰椤忣厽銇勯姀鈩冪妞ゃ垺娲熸慨鈧柨娑樺婢规洜绱撻崒姘偓椋庢媼閺屻儱纾婚柟鐐墯閻斿棝鎮规潪鎷岊劅闁稿孩鍨圭槐鎺楁偐閼姐倗鏆梺鍝勭灱閸犳牠鐛幋锕€绠涙い鎾跺Т濞懷囨⒒娓氣偓濞艰崵寰婇懖鈺佸灊婵炲棙鎸搁拑鐔兼煟閺冨倵鎷¢柡浣革功閻ヮ亪顢橀悙鍙壭╂繛鏉戝悑閸旀洟鈥旈崘顔嘉ч柛鈩冡缚閸欏棛绱撴担铏瑰笡閽冨崬菐閸パ嶈含闁诡喗绮撻幐濠冪珶閳瑰灝濮傞柡灞炬礃瀵板嫰宕煎┑鍡椥戞繝纰樻閸ㄤ粙骞忛敓锟�