Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
ISUCONにRustで挑戦した話 / Participating in ISUCON wi...
Search
すてにゃん
October 20, 2020
Programming
1.4k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
ISUCONにRustで挑戦した話 / Participating in ISUCON with Rust
https://forcia.connpass.com/event/187287/
に向けた発表資料です。
すてにゃん
October 20, 2020
More Decks by すてにゃん
See All by すてにゃん
GitHub Copilot CLI の Rubber Duck 機能を使ってコーディングの品質をあげよう #techbaton_findy
stefafafan
2
1.3k
サプライチェーン攻撃への備えについて考えている #湘なんか
stefafafan
3
2.6k
サービスの信頼性を高めるため、形骸化した「プロダクションミーティング」を立て直すまでの取り組み
stefafafan
1
330
「お金で解決」が全てではない!大規模WebアプリのCI高速化 #phperkaigi
stefafafan
6
2.9k
急成長を支える基盤作り〜地道な改善からコツコツと〜 #cre_meetup
stefafafan
0
4.6k
小田原でみんなで一句詠みたいな #phpcon_odawara
stefafafan
0
2k
dotfiles について話したい #湘なんか
stefafafan
2
510
意義から考えるObservability入門 #srenext
stefafafan
2
1.6k
高橋メソッド風の発表を生成するCLIツールをPHPで作った #phpcon_odawara
stefafafan
1
1.6k
Other Decks in Programming
See All in Programming
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
480
New "Type" system on PicoRuby
pocke
1
750
LLM Plugin for Node-REDの利用方法と開発について
404background
0
160
Spec-Driven Development with AI-Agents: From High-Level Requirements to Working Software
antonarhipov
2
480
AIチームを指揮するOSS「TAKT」活用術 / How to Use “TAKT,” an OSS Tool for Orchestrating AI Teams
nrslib
6
850
A2UI という光を覗いてみる
satohjohn
1
120
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
530
These Five Tricks Can Make Your Apps Greener, Cheaper, & Nicer
hollycummins
0
280
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
100
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
120
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
Featured
See All Featured
New Earth Scene 8
popppiees
3
2.3k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
Statistics for Hackers
jakevdp
799
230k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
480
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8.2k
Leading Effective Engineering Teams in the AI Era
addyosmani
9
2k
Principles of Awesome APIs and How to Build Them.
keavy
128
17k
Site-Speed That Sticks
csswizardry
13
1.2k
The Mindset for Success: Future Career Progression
greggifford
PRO
0
360
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
2.1k
Transcript
ISUCONʹRustͰઓͨ͠ RustͷLTձ Shinjuku.rs #12 @ΦϯϥΠϯ https://forcia.connpass.com/event/187287/ 2020/10/20 ͯ͢ʹΌΜ (id:stefafafan)
࣍ • ࣗݾհ • ISUCONͱʁ • ࣄલ४උௐͨRustͷCrateͷհ • ISUCON༧બ •
ֶͼɾײͳͲ 2
ࣗݾհ • ͯ͢ʹΌΜ (id:stefafafan) • גࣜձࣾͯͳͷࣾһ • WebΞϓϦέʔγϣϯΤϯδχΞ • Rustॳ৺ऀ
• ISUCON10Trust RustνʔϜͱͯ͠ࢀՃ
ISUCONͱʁ
ISUCONͱ • LINEגࣜձࣾओ࠵ʮIikanjini Speed Up ContestʯͷུশͰ͋Γɺ༩͑ ΒΕͨWebΞϓϦέʔγϣϯΛߴԽ͠ڝ͍߹͏ίϯςετ • 1ਓʙ3ਓͷνʔϜͰࢀՃ͢Δ͜ͱ͕Ͱ͖ͯɺΞϓϦέʔγϣϯίʔυ ͷΈͳΒͣྫ͑nginxMySQLͷνϡʔχϯάͳͲߦ͏͜ͱʹͳ
Δ • ༻ҙ͞ΕͨϕϯνϚʔΫΛ࣮ߦ͢Δ͜ͱʹΑͬͯʮʯ͕֬ೝͰ͖ Δ
ISUCONͱ • ࣾձਓֶੜࢀՃՄೳ • ܾউ্ҐʹೖΔͱۚ͋Δ ※ʮISUCONʯɺLINEגࣜձࣾͷඪ·ͨొඪͰ͢ɻ http://isucon.net/
༧બग़·Ͱͷ४උ
༧બग़·Ͱͷ४උ • νʔϜ࡞Γͱׂ୲ܾΊ • nginxMySQLͷϩάղੳɾνϡʔχϯά • Rustͷษڧ • WebΞϓϦέʔγϣϯͱRust
༧બग़·Ͱͷ४උ • νʔϜ࡞Γͱׂ୲ܾΊˡࠓճ͞ͳ͍ • nginxMySQLͷϩάղੳɾνϡʔχϯάˡࠓճ͞ͳ͍ • RustͷษڧˡTour of RustΓ·ͨ͠ (https://tourofrust.com/)
• WebΞϓϦέʔγϣϯͱRust
WebΞϓϦέʔγϣϯͱRust
ISUCONͷࢀߟ࣮ʹ͍ͭͯ • ISUCONͰԿछྨ͔ͷݴޠͰͷ࣮͕ఏڙ͞Ε্ͨͰڝٕ͕ߦΘΕ Δ • ॳզʑRustͷࢀߟ࣮͕ͳ͍έʔεߟྀ͠ɺ1͔ΒRustͰΞϓ ϦέʔγϣϯΛ࣮͢Δ͜ͱݕ౼ʹೖΕ͍ͯͨ • RustͰWebΞϓϦέʔγϣϯΛ࡞ΔͷʹඞཁͳϥΠϒϥϦͳͲΛ ͓ͬͯ͘ඞཁ͕͋Δ
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
actix-web use actix_web::{web, App, HttpResponse, HttpServer}; // ϢʔβҰཡΛදࣔ͢Δ async fn
show_users() -> HttpResponse { HttpResponse::Ok().body(“Show users…”) } // ΤϯυϙΠϯτ͝ͱʹͲͷؔΛݺͿ͔ͳͲ͜͜Ͱهड़͢Δ #[actix_rt::main] async fn main() -> std::io::Result<()> { HttpServer::new(|| { App::new().service( web::scope(“/users”) .route(“/show”, web::get().to(show_users)), ) }) .bind(“127.0.0.1:8088”)? .run() .await } RustͷWeb framework https://github.com/actix/ actix-web
actix-web READMEʹػೳҰཡ Example͕͍͔ͭ͘ࡌͬͯ ͍Δ
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
Tera <h2>My Programming Languages</h2> <ul> {% for language in programming_languages
%} {% if language.name == “rust” %} <li>Rust Rules!!!!</li> {% else %} <li>{{ language.name }}</li> {% endif %} {% endfor %} </ul> … Template engine inspired by Jinja2 https://github.com/Keats/ tera
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
reqwest let client = reqwest::Client::new(); // form()ͷଞʹbody()ͱ͔json()ͱ͔͑Δ let res =
client.post(“https://…”) .form(¶ms) .send() .await?; RustͷHTTPΫϥΠΞϯτ https://github.com/ seanmonstar/reqwest
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
serde use actix_web::{HttpResponse, Responder}; use serve::{Serialize, Deserialize}; #[derive(Serialize, Deserialize)] struct
User { id: i32, username: String, name: String } async fn user_detail_json() -> imp Responder { let user = User { id: 12345, username: “stefafafan”.to_string(), name: “ͯ͢ʹΌΜ”.to_string(), } // ͜Εactix_webͷ͚ؔͩͲJSONͱͯ͠ฦͤͯΔ HttpResponse::Ok().json(user) } Rust͚ʹσʔλΛSerialize/ Deserialize͢ΔϑϨʔϜϫʔΫ https://github.com/serde-rs/ serde
WebΞϓϦέʔγϣϯΛRustͰهड़͢ΔͷʹԿ ͕ඞཁͳͷ͔ • WebϑϨʔϜϫʔΫ͕΄͍͠ • ςϯϓϨʔτΤϯδϯ͕΄͍͠ • APIୟ͍ͨΓ͢ΔͳΒHTTPΫϥΠΞϯτ͕΄͍͠ • JSONฦ͢ͳΒSerialize/DeserializeͰ͖ΔΑ͏ʹ͍ͨ͠
• MySQLPostgreSQLΫϥΠΞϯτ͕΄͍͠
SQLx use sqlx::{MySqlPool}; async fn main() -> std::io::Result<()> { let
pool = MySqlPool::connect(&DATABASE_URL).await; let row = sqlx::query!(“SELECT …”) .fetch_all(&pool) .await .unwrap(); … } Rust͚SQLϥΠϒϥϦ https://github.com/ launchbadge/sqlx
ISUCON༧બ
ISUCON10 ༧બͷղઆͱߨධ http://isucon.net/archives/55025156.html
ISUCON10 ༧બ֓ཁ • Πεʹ߹͏݅Λݕࡧ͢ΔαΠτ(ISUUMO) ҎԼͷΑ͏ͳը໘͕͋Δ • Πεͷݕࡧ • ݅ͷݕࡧ •
Πεɾ݅ͷৄࡉը໘ • ϚοϓΛϚεͰͳͧͬͯൣғʹؚ·ΕΔ݅Λදࣔ
ISUCON10 ༧બ֓ཁ • MySQLͱnginx͕ΘΕ͍ͯΔ • Rust࣮͋Δ • αʔό͕3͑Δ
ISUCON༧બTrust RustνʔϜͰͬͨ͜ͱ • αʔόʹ͋ΔRustͷ࣮ΛGitཧԼʹஔ͘ • alppt-query-digestΛͬͯɺ͍ΤϯυϙΠϯτ͍ΫΤϦΛಛఆ • MySQLͷINDEXΛ͢ͳͲ • طଘͷRustίʔυΛோΊ͖ͯ͋Β͔ʹඇޮͳ͜ͱͬͯͦ͏ͳ෦Έ
͚ͭͯվળ͠Α͏ͱͨ͠ • 3αʔό͕͋ΔͷͰΞϓϦαʔό1 + DBαʔό2ߏʹ
ISUCON༧બTrust RustνʔϜͰͬͨ͜ͱ • αʔόʹ͋ΔRustͷ࣮ΛGitཧԼʹஔ͘ • alppt-query-digestΛͬͯɺ͍ΤϯυϙΠϯτ͍ΫΤϦΛಛఆ • MySQLͷINDEXΛ͢ͳͲ • طଘͷRustίʔυΛோΊ͖ͯ͋Β͔ʹඇޮͳ͜ͱͬͯͦ͏ͳ෦Έ
͚ͭͯվળ͠Α͏ͱͨ͠ • 3αʔό͕͋ΔͷͰΞϓϦαʔό1 + DBαʔό2ߏʹ
ISUCON༧બ վળྫᶃ ɾΠεͷॎԣ෯͕݅ͷυΞʹೖΔ ͔Ͳ͏͔ͷΫΤϦΛΈཱ͍ͯͯΔ Օॴͷվળ https://github.com/dekokun/ ISUCON-2020-qualify/pull/12
ISUCON༧બ վળྫᶄ ɾchairςʔϒϧͱestateςʔϒϧͰ ผʑͷMySQLPoolΛࢀর͢ΔΑ͏ ʹͯ͠ɺDBαʔόΛΘ͚ΒΕΔঢ় ଶʹ https://github.com/dekokun/ ISUCON-2020-qualify/pull/15
༧બͷ݁Ռ • զʑ༧બഊୀͨ͠ • ISUCON10 ΦϯϥΠϯ༧બͷར༻ݴޠൺ http://isucon.net/ archives/55008738.html • Goݴޠ͕1൪ਓؾͰ6ׂۙ͘ͷνʔϜ͕͍ͬͯͨ
• Rust8Ͱ͏ͪ1͕ຊઓग़ (͍͢͝)
ֶͼɾײ • RustίϯύΠϧ࣌ʹஸೡʹ৭ʑͱౖͬͯ͘ΕΔͷͰ҆৺ײ͕͋Δ • ૉૣ͘վળ͍ͯ͘͠ඞཁͷ͋ΔISUCONʹؔͯ͠ίϯύΠϧ࣌ؒίʔ υॻ࣌͘ͷखܰ͞ͱ͍͏໘ͰGo͍͍͢ͷͩΖ͏ͳͱࢥͬͨ • ࠓճͷ͏ͪͷνʔϜͷઓ͍ํΞϓϦͷίʔυΛΰϦΰϦॻ͘ͱ͍ ͏ײ͡Ͱͳ͔ͬͨͱ͍͏ͷ͋Γ·͢ •
RustΛ৮Δػձʹͳͬͨ͠ɺ༧બམͪͨͷͷͬͯΑ͔ͬͨ