BFF Pattern
Seu melhor amigo backend
Engenharia de Software - FIB
Desenvolvedor - Finch Soluções
Helder Traci
O que é
BFF?
O que é BFF?
- Backend For Frontend
- Pattern
- Phil Calçado
O que é BFF?
- Motivação
- Uso de API genérica
- Responsabilidades nas UIs
- Desorganização entre times
O que é BFF?
data:image/s3,"s3://crabby-images/481fb/481fba1309b27732d2cad6e09d80ed834ad88b24" alt=""
API backend genérica
API backend genérica
data:image/s3,"s3://crabby-images/49b59/49b59981d4398ce2c987923ab2e980cf40e60a2e" alt=""
API backend genérica
- Diferentes necessidades e limitações
data:image/s3,"s3://crabby-images/46c0d/46c0d2708784436022c0fdceba9e91d9f853173d" alt=""
data:image/s3,"s3://crabby-images/22202/222028e66f55e1291f819152ee7400625e8ec1ef" alt=""
API backend genérica
- Separação entre times
data:image/s3,"s3://crabby-images/49b59/49b59981d4398ce2c987923ab2e980cf40e60a2e" alt=""
Time A
Time B
Time C
API backend genérica
- Alterações centralizadas
data:image/s3,"s3://crabby-images/23cc2/23cc2c5341ce86891e2465a5ccc397f3b8c9fc88" alt=""
data:image/s3,"s3://crabby-images/f35b8/f35b8e3b41c7c090ff6e6aa729f14cab3515b90d" alt=""
X
API backend genérica
- Novas UIs
data:image/s3,"s3://crabby-images/9c444/9c4440149113d97d744642305f9b7452f9b6827a" alt=""
data:image/s3,"s3://crabby-images/c1d9c/c1d9c6649c9da5f21d2d36be6b42059e2aad2c81" alt=""
data:image/s3,"s3://crabby-images/4e2d0/4e2d09122e488ef741481ee71843ad93b17cc2a6" alt=""
data:image/s3,"s3://crabby-images/da978/da9783badb4944a246638af5e8fca344403ededd" alt=""
data:image/s3,"s3://crabby-images/568f1/568f1bbf3cae2cf7566d9930fd347e45b983eb60" alt=""
O pattern BFF
O pattern BFF
- Foco específico
data:image/s3,"s3://crabby-images/aa5cd/aa5cd52ee40e3bb6bc95e19b9737f3035c287fdc" alt=""
O pattern BFF
- Conversões
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
XML
{
"note": {
"to": "Tove",
"from": "Jani",
"heading": "Reminder",
"body": "Don't forget me this weekend!"
}
}
JSON
O pattern BFF
- Response limpo
{
"contentDetails": {
"duration": "PT4M39S",
"dimension": "2d",
"definition": "hd",
"caption": "false",
"licensedContent": true,
"projection": "rectangular"
}
}
{
"contentDetails": {
"duration": "PT4M39S"
}
}
O pattern BFF
- Response limpo
{
"thumbnails": {
"default": {
"url": "https://i.com/ok9spOX0iaE/default.jpg",
"width": 120,
"height": 90
},
"medium": { ... },
"high": { ... },
"standard": { ... },
"maxres": { ... }
}
}
{
"thumbnail": {
"url": "https://i.com/ok9spOX0iaE/sddefault.jpg",
"width": 640,
"height": 480
}
}
O pattern BFF
- Padrões
{
"url": "maxResults=12&q=bff&pageToken=CAwQAA"
}
{
"url": "size=10&search=bff&page=0"
}
O pattern BFF
- Responsabilidade
- Construção de objetos
- Unificação de requests
O pattern BFF
data:image/s3,"s3://crabby-images/3039c/3039c0e7c320d997da44ba7cb0af8bf97b4d3702" alt=""
Quantos BFFs?
Quantos BFFs?
- One UI, one BFF
data:image/s3,"s3://crabby-images/f0620/f06206e2647fdefb4bb8c2edde3c8f7d7353e939" alt=""
Quantos BFFs?
- Times completos
data:image/s3,"s3://crabby-images/f0620/f06206e2647fdefb4bb8c2edde3c8f7d7353e939" alt=""
Time A
Time B
Time C
Time D
Quantos BFFs?
- Reutilização de um BFF
data:image/s3,"s3://crabby-images/aa5cd/aa5cd52ee40e3bb6bc95e19b9737f3035c287fdc" alt=""
Quantos BFFs?
- Estrutura dos BFFs
data:image/s3,"s3://crabby-images/72738/7273842e2a9ae7fb2286cd2800bfca10a3e5daa7" alt=""
Múltiplos serviços
Múltiplos serviços
- Padrão essencial
data:image/s3,"s3://crabby-images/4cccf/4cccf6e8de698562f3d01286678e54e431451b41" alt=""
Reuso e BFF
Reuso e BFF
- Duplicidade de código
- Abordagens
- biblioteca compartilhada
- novo serviço
- unificação de serviço
- Evite generalização prematura
data:image/s3,"s3://crabby-images/55026/550260c912d62629994871fd0eb40a4ba02abf04" alt=""
Reuso e BFF
- Evolução do BFF
data:image/s3,"s3://crabby-images/7c7e8/7c7e8d47f2c3ccc75a6b14b048c00bc96f421fcc" alt=""
Sobre autonomia
Sobre autonomia
- Velocidade no desenvolvimento
- Auto-gerenciável
- Toma as próprias decisões
Quando utilizar
Quando utilizar
- Interfaces distintas (muitos dispositivos)
- Muitos serviços
- Agregação no lado do servidor
- Chamadas a serviços distintos
- API genérica complexa
Quando não utilizar
Quando não utilizar
- Times pequenos e especialistas
- Suporte para poucos dispositivos (foco específico)
- Quando não quer
E mais...
E mais...
- Trial no RADAR da ThoughtWorks (2015/2016)
- Cases
- SoundCloud
- SporTV
- Microservices.io
- Bluemix Developer Console – BFF (Backend for Frontend) Pattern
Dúvidas?
data:image/s3,"s3://crabby-images/13325/133250ca5b182fce30ea6413f209eaf7e88c9a67" alt=""
data:image/s3,"s3://crabby-images/13325/133250ca5b182fce30ea6413f209eaf7e88c9a67" alt=""
data:image/s3,"s3://crabby-images/13325/133250ca5b182fce30ea6413f209eaf7e88c9a67" alt=""
data:image/s3,"s3://crabby-images/13325/133250ca5b182fce30ea6413f209eaf7e88c9a67" alt=""
data:image/s3,"s3://crabby-images/2006d/2006d1fc718c07702d0a7d65f8e93a54626e7308" alt=""
data:image/s3,"s3://crabby-images/2006d/2006d1fc718c07702d0a7d65f8e93a54626e7308" alt=""
data:image/s3,"s3://crabby-images/2006d/2006d1fc718c07702d0a7d65f8e93a54626e7308" alt=""
data:image/s3,"s3://crabby-images/2006d/2006d1fc718c07702d0a7d65f8e93a54626e7308" alt=""
data:image/s3,"s3://crabby-images/b35d8/b35d88bc7b8a2823e3beed1596c7abe68b72e123" alt=""
data:image/s3,"s3://crabby-images/b35d8/b35d88bc7b8a2823e3beed1596c7abe68b72e123" alt=""
data:image/s3,"s3://crabby-images/b35d8/b35d88bc7b8a2823e3beed1596c7abe68b72e123" alt=""
data:image/s3,"s3://crabby-images/322d3/322d309ea775b8ead1097dde75cc762c8e514d0c" alt=""
Obrigado!
data:image/s3,"s3://crabby-images/d39c0/d39c0482827e006e293f120cffff44176442462f" alt=""
data:image/s3,"s3://crabby-images/808ca/808caebcea62770e46aa90dc4a7d4b43e4ce1845" alt=""
data:image/s3,"s3://crabby-images/451fa/451fac422c830b8fcbedc6c682709d6769823a1a" alt=""
data:image/s3,"s3://crabby-images/22dc8/22dc8749954ad09662e8a7f71facf896c283f751" alt=""
data:image/s3,"s3://crabby-images/1feb6/1feb6d512e2a0364d639d8e39a0790f5ab4f93e2" alt=""
data:image/s3,"s3://crabby-images/d0873/d0873b178086ad046c72f9b043547a431c8ff256" alt=""
https://helderdiin.github.io/
https://github.com/helderdiin
@Helderdiin