DBA机器人乔。Anatoly Stansler(Postgres.ai)



后端开发人员如何知道SQL查询在生产中会表现良好?在大型或快速发展的公司中,并非每个人都可以使用“产品”。有了访问权限,就可以轻松地检查所有请求,并且创建数据库副本通常需要几个小时。为了解决这些问题,我们创建了一个人工DBA-Joe。它已在多家公司成功实施,并已帮助了数十名开发人员。



视频:







你好!我叫Anatoly Stansler。我在Postgres.ai公司工作我们致力于通过消除开发人员,DBA和QA的Postgres延迟来加快开发过程。



我们有很大的客户,今天,报告的一部分将专门讨论我们与他们合作时遇到的案例。我将告诉您我们如何帮助他们解决一些非常严重的问题。





, : « ?». review, , DBA-. – .



, , , . , . , , .





- prod - ? . , ? . , .





– prod. , , , - . prod, .





, . , .



?





staging - prod. prod, . , , staging.



- , . . prod.



?



  • , staging . , - , – , . Staging . , . . , .
  • , , , . . .




, , , - , , . - , , .



, , , - production.





, ? , , .



, ? , .



, , production, , .



, , , , , , . . .





, – . , cloud. 200 . , , . .



, prod .



? , .



.





, , . , 10 , 10 . , , . .





:



  • – 4,5 .



  • 30 .





, . . , .



. .





OpenZFS.





OpenZFS – copy-on-write , . . . .



:



  • LVM,



  • (, Pure Storage).





Database Lab, , . . OpenZFS, LVM .





? , , , , , , .



, - , : «, , - ».



. , .



. , , , , .





, :



  • – , . production. , , . WAL-E, WAL-G Barman. , - Cloud-, , RDS Cloud SQL, . - , , , production, , .



  • – , Database Lab. Cloud, On-premise. , ZFS . .





, , , - dev. dev . , 4,5 , ZFS 3,5 . . dev .



.



  • , DBA , .



  • QA- , prod. environment QA , . , , , , - , .



  • . , , .







:



  1. «», .



  2. , .



  3. , . . , .





  • . prod. .



  • . .





  1. , .


, ?





.



, , , . .



, . , ? .





? , , Slack-. .



? . . . . . , - , . .



Slack . , thread , , DBA, .





, , . , , , , .



, - .



, . . . .



production, .





Postgres . . Postgres, . . Shared Buffer Cache.



, Shared Buffer Cache Postgres , .



.





, , . - Shared Buffer Cache – 25 % , .



, , 4 instance, . . 4 . , , , .



, Buffer Cache , , . . , . , .



, prod , Postgres . , SeqScan. , ?



, Postgres Shared Buffer , effective_cache_size.





Effective_cache_size – , , . . Buffer Cache . . .



Postgres, , - , . , production.



. , , :



  • , prod.



  • .





, , , .



, , prod, , , , . , . . , , – ( ) , .



, Joe .





. – 1 . , 10 .





, . , 2,5 . , .



B Joe , .



, , . - , , .





, . , , . , 142 .





, , index scan , , ( ), .





- , .





, .





, , 2,5 156 , . 6 .





index only scan.



, - . Flame Graphs.





, . Flame Graphs : , , . . .



. , , .





, explain.depesz.com. , - , , .



, , explain.depesz.com, , .





– explain.dalibo.com. , . , , , -, .







, , Slack . , , , , thread Slack .





, . Update Database Lab, open source. Joe . . .



, - , Delphix, enterprise-. , . Postgres. open source. !



. !





! ! , , . . , .



, ? , . , 10 , , 10 . , . . , , ?



. . - , , , , fail-.



, . . . ? . ?



- ttl . , ttl.



, ?



1 , . . idle – 1 . , . , . , – .



, , , . ZFS? LVM? , c LVM . ? , , .



ZFS? , , . . instances . , . , . . LVM?



LVM meetup. – . ZFS . . . ZFS , Linux . . . . ZFS . , , . , , . . . . , . community, . ZFS – .



: ? , . , – . Pure Storage . .



, . – , , . . , .



ZFS . DelPhix, 300 . fortune 100 — 50 , . . NASA . . . open source Core. , open source. , . , . , . SELECT , . , DBA . . , . , . ZFS, . community , open source . .*



! ! . . . ? : , , - , - job . CPU , IO, ? .



. , ZFS , prod ZFS, ext4, . ?



. , . . , staging . , - , - . . prod. - , - – , , , - .



, , . , , , -, . , . , - .



. . , production , , ? - ? – - MySQL?



. , . Joe, , . ? Joe . , . , – . , .



MySQL. , state . Postgres, Postgres. . Postgres. , , . .



, MySQL. . , . .. MySQL . , ZFS.



! . , , , . , ?



, . , Postgres. ?



, , . , , , prod . - . prod, , prod , .



, , . , , .



?



, , , . . . , .



, , , , . , . . .



. cloud- , , Google, Amazon . .



. MySQL . , , , , . , , , , Postgres, , , instance.



. , . , , , . . , . 100 , . ? , , , , ?



, ZFS . , . , . , .



, , , , ?



, .



, , , ?



, .



. ?



, . - . . , . , . . data corruption . , , . . , .



, ! Joe . , . , Explain Analyze, .



. , : «SELECT FROM WHERE email = ». . . , - . . . , , , . - , .



! ! . Slack , - instances, ?



现在对Slack有一个约束,即没有其他Messenger,但我真的也想支持其他Messenger。你能做什么?您可以在没有Joe的情况下部署DB Lab,使用REST API或使用我们的平台行走,创建克隆并与PSQL连接。但是,如果准备好让开发人员访问数据,则可以执行此操作,因为将不再有任何屏幕。



我不需要这一层,但是我需要这样的机会。



然后-是的,它可以完成。




All Articles