Google Cloud SQL性能测试

  1. CREATE DATABASE test;  
  2. USE test;  
  3. CREATE TABLE test (id INT NOT NULL AUTO_INCREMENT,   
  4. value DOUBLEPRIMARY KEY(id)); 

然后在绑定的一个HR datastore应用上测试:

  1. from random import randomfrom time import timefrom google.appengine.api import rdbmsrand = [(random(),)   
  2. for i in xrange(500)]
  3. t = time()
  4. conn = rdbms.connect(instance='keakon:test'database='test')prin
  5. time()
  6. - tcursor = conn.cursor()
  7. t = time()
  8. cursor.executemany('INSERT INTO test (value) VALUES (%s)', rand)  
  9. print time() - t
  10. t = time()
  11. cursor.execute('SELECT count(*) FROM test')print time() - t
  12. t = time()
  13. cursor.execute('SELECT id FROM test')print time() - t
  14. t = time()
  15. cursor.execute('SELECT * 
  16. FROM test')print time()- t
  17. t = time()
  18. conn.rollback()prin
  19. time() - t
  20. t = time()
  21. cursor.close()conn.close()prin
  22. time() - t 

结果:
0.00699996948242
3.8259999752
0.00500011444092
0.235999822617
0.205000162125
0.0639998912811
0.00300002098083可见连接和关闭数据库还是很快的,但是插入和查询性能并不算好。

接着试试提交:

  1. t = time()
  2. cursor.executemany('INSERT INTO test (value)   
  3. VALUES (%s)', rand)conn.commit()print time() - t
  4. t = time()
  5. cursor.execute('DELETE FROM test')conn.commit()print time() - t 

结果:
3.3180000782
0.132999897003可能是测试的波动,插入变快了。比较让我奇怪的是删除,居然比查询还快。

再试了下清空表,即改成cursor.execute(‘TRUNCATE test’)。结果:
2.96399998665
0.128000020981这次插入更快了,不解…

值得一提的是,我在删除的时候写错了SQL语句,结果报错了。然后再次删除就一直被锁,但是查询和插入都正常,估计是那个事务一直没结束。
最后我试了下TRUNCATE,花了22秒终于成功了。之后再测试时,即使出错也没遇到被锁的情况了,非常奇怪…

然后对比测试HR datastore,使用同一个应用:
 

  1. from random import random
  2. from time import time
  3. from google.appengine.ext import db
  4. class Test(db.Model):
  5. value = db.FloatProperty()
  6. entites = [Test(value=random()) for i in xrange(500)]
  7. t = time()
  8. db.put(entites)prin
  9. time() - t
  10. t = time()Test.all().count(None)print time() - t
  11. t = time()
  12. keys = Test.all(keys_only=True).fetch(500)printime() - t
  13. t = time()
  14. Test.all().fetch(500)print time() - t
  15. t = time()
  16. db.delete(keys)print time() - t 

结果:
3.31100010872
0.0799999237061
0.208999872208
2.34000015259
0.861999988556其中count和查询慢了一个数量级,删除慢约6倍,插入和查询key则差不多。

接着又在一个MS datastore的应用上测试了下,结果是:
1.04965305328
0.109894037247
0.0680358409882
0.660396099091
0.251960992813插入快2倍,查询慢一个数量级,其他差不多。

对大多数应用来说,查询性能是最重要的,这一个数量级的提升也是很有益处的,更何况还少了很多限制。所以如果不需要ORM的话,用Google Cloud SQL取代Datastore是个不错的选择。

【编辑推荐】

  1. Oracle发布NoSQL数据库
  2. 微软进军NoSQL 发布Trinity数据库
  3. 微软研究人员:NoSQL需要标准化
  4. MySQL中的NoSQL插件
  5. SQL与NoSQL——MySQL与NoSQL的融合

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/269634.html<

(0)
运维的头像运维
上一篇2025-05-07 10:52
下一篇 2025-05-07 10:54

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注