
¿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 , . , , , , - , .
. , , .

:
«», .
, .
, . . , .
. prod. .
. .
- , .
, ?

.
, , , . .
, . , ? .

? , , 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.