Ben Boyter นักพัฒนาชาวออสเตรเลียผู้สร้างเว็บ SearchCode.com ประกาศย้ายฐานข้อมูลจาก MySQL และ Redis มาเป็น SQLite ในเว็บขนาดใหญ่ที่ให้บริการคนจำนวนมากเป็นผลสำเร็จ โดยฐานข้อมูลของ SearchCode มีขนาดใหญ่ถึง 6TB น่าจะเป็นฐานข้อมูล SQLite สำหรับเว็บสาธารณะที่ใหญ่ที่สุดในโลก
SearchCode เปิดบริการมากว่าสิบปีแล้ว โดยเริ่มจาก stack PHP, CodeIgnitor, MySQL, Memcached, Apache, Sphinx ภายหลังเปลี่ยนไปหลายรอบ โดยใช้ Python และช่วง Covid ก็หันมาเขียนภาษา Go แทนที่ พร้อมกับเปลี่ยนตัวค้นหาที่เขียนใหม่เอง ทำให้ stack ล่าสุดกลายเป็น Go, MySQL, Redis, และ Caddy
Boyter ระบุว่าต้องการเปลี่ยนแอปพลิเคชั่นให้เหลือไบนารีก้อนเดียวไม่มีการเชื่อมต่อใดๆ อีก การเปลี่ยนมาใช้ SQLite จึงตรงความต้องการ แม้ว่าจะเคยมอง bbolt ฐานข้อมูลแบบ key-value มาก่อนหน้า แต่ก็ยังไม่ตรงความต้องการ และแม้ฐานข้อมูลของ SearchCode จะเรียบง่ายแต่ Boyter ก็ยังต้องการใช้ SQL อยู่
ปัญหาใหญ่ที่สุดของ SQLite ที่ Boyter พบคือปัญหา database is locked
ซึ่งแก้ได้ด้วยการแยก connection ระหว่างฝั่งเขียนและอ่านออกจากกัน โดยฝั่งเขียนต้องมี connection เดียวเท่านั้น ตอนนี้เว็บเพิ่งย้ายมาเต็มรูปแบบไม่กี่วันและยังไม่พบปัญหาอะไร
ที่มา - Boyter.org
Comments
SQLite นี่แน่นอนจริงๆ
..: เรื่อยไป
SQLite กับข้อมูลใหญ่ขนาดนี้ทำยังไงถึงจะไม่ช้าครับเนี่ย
โหดจัด อยากให้แชร์จัง
Blognone = 138.1 news/w เยอะมากๆ
จำนวมาก => จำนวนมาก