El robot de DBA Joe. Anatoly Stansler (Postgres.ai)



¿Cómo sabe un desarrollador de backend que una consulta SQL funcionará bien en producción? En empresas grandes o de rápido crecimiento, no todo el mundo tiene acceso al "producto". Y con el acceso, no todas las consultas se pueden verificar sin problemas, y crear una copia de la base de datos a menudo lleva horas. Para resolver estos problemas, creamos un DBA artificial: Joe. Ya se ha implementado con éxito en varias empresas y ha ayudado a decenas de desarrolladores.



Vídeo:







¡Hola! Mi nombre es Anatoly Stansler. Trabajo para la empresa Postgres.ai . Estamos comprometidos a acelerar el proceso de desarrollo eliminando los retrasos de Postgres de los desarrolladores, DBA y QA.



Tenemos grandes clientes, y hoy parte del informe estará dedicado a los casos que nos hemos encontrado trabajando con ellos. Te contaré cómo les ayudamos a resolver algunos problemas bastante serios.





, : « ?». 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, ?



Ahora hay un enlace a Slack, es decir, no hay otro mensajero, pero realmente quiero apoyar a otros mensajeros también. ¿Qué puedes hacer? Puede implementar DB Lab sin Joe, caminar usando la API REST o usar nuestra plataforma y crear clones y conectarse con PSQL. Pero puede hacer esto si está listo para dar acceso a los datos a sus desarrolladores, ya que ya no habrá ninguna pantalla.



No necesito esta capa, pero necesito esa oportunidad.



Entonces, sí, se puede hacer.




All Articles