Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Como escolher uma stack para meu projeto?
Search
Vitor Mendrone
July 13, 2019
Technology
0
15
Como escolher uma stack para meu projeto?
Vitor Mendrone
July 13, 2019
Tweet
Share
More Decks by Vitor Mendrone
See All by Vitor Mendrone
Como se tornar indispensável em um mercado em crise?
mendrone
0
74
Expressões Regulares
mendrone
0
29
A arte da composição
mendrone
0
20
Future Proof CSS - 2019
mendrone
0
67
Vue.js - O Antes, o Durante e o Depois
mendrone
0
100
Future Proof CSS
mendrone
1
93
High Speed Workflow
mendrone
4
130
Usabilidade - O bom senso é o seu melhor amigo
mendrone
0
78
Um Simples Checkup Pode Salvar a Sua Loja Virtual
mendrone
0
54
Other Decks in Technology
See All in Technology
PHPカンファレンス名古屋-テックリードの経験から学んだ設計の教訓
hayatokudou
2
390
プロダクトエンジニア構想を立ち上げ、プロダクト志向な組織への成長を続けている話 / grow into a product-oriented organization
hiro_torii
1
220
Classmethod AI Talks(CATs) #17 司会進行スライド(2025.02.19) / classmethod-ai-talks-aka-cats_moderator-slides_vol17_2025-02-19
shinyaa31
0
120
PHPで印刷所に入稿できる名札データを作る / Generating Print-Ready Name Tag Data with PHP
tomzoh
0
110
地方拠点で エンジニアリングマネージャーってできるの? 〜地方という制約を楽しむオーナーシップとコミュニティ作り〜
1coin
1
230
滅・サービスクラス🔥 / Destruction Service Class
sinsoku
6
1.6k
現場の種を事業の芽にする - エンジニア主導のイノベーションを事業戦略に装着する方法 -
kzkmaeda
2
2.1k
OpenID Connect for Identity Assurance の概要と翻訳版のご紹介 / 20250219-BizDay17-OIDC4IDA-Intro
oidfj
0
280
オブザーバビリティの観点でみるAWS / AWS from observability perspective
ymotongpoo
8
1.5k
リアルタイム分析データベースで実現する SQLベースのオブザーバビリティ
mikimatsumoto
0
1.4k
次世代KYC活動報告 / 20250219-BizDay17-KYC-nextgen
oidfj
0
260
管理者しか知らないOutlookの裏側のAIを覗く#AzureTravelers
hirotomotaguchi
2
440
Featured
See All Featured
A Philosophy of Restraint
colly
203
16k
Automating Front-end Workflow
addyosmani
1368
200k
Why You Should Never Use an ORM
jnunemaker
PRO
55
9.2k
Writing Fast Ruby
sferik
628
61k
The Pragmatic Product Professional
lauravandoore
32
6.4k
Raft: Consensus for Rubyists
vanstee
137
6.8k
GraphQLとの向き合い方2022年版
quramy
44
13k
4 Signs Your Business is Dying
shpigford
182
22k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
Building Adaptive Systems
keathley
40
2.4k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
30
4.6k
Designing for humans not robots
tammielis
250
25k
Transcript
None
Vitor Mendrone Senior Developer
None
None
work.co/careers/technology
Como escolher uma stack para meu projeto?
None
DISCLAIMER
STACK Conjunto de tecnologias (linguagens, frameworks, bibliotecas) utilizadas como base
de um sistema. Ex.: Javascript, Vue, Redux, Node, Mongo
Por que falar sobre isso?
DECISÕES ERRADAS Todos os dias desenvolvedores iniciam projetos críticos com
stacks baseadas em hype, desejos pessoais e percepções incorretas da realidade.
None
Empolgação Medo Nervosismo
NOSSA CARREIRA DEPENDE DISSO. Entregar produtos no prazo, ter uma
ampla visão do negócio e entender os riscos de cada projeto.
Processo Mensurável Técnico Previsível
Eliminar Causas
Eliminar Causas Perguntas certas
MODELO MENTAL Problema Solução ?
Todos os modelos estão errados. Box, George E. P.; Norman
R. Draper (1987). Empirical Model-Building and Response Surfaces, p. 424, Wiley. ISBN 0471810339 https://en.wikipedia.org/wiki/All_models_are_wrong
None
[Estatisticamente] é impossível que modelos teóricos reproduzam com exatidão o
mundo real
Empirical Model-Building and Response Surfaces George Edward Pelham Box Norman
Richard Draper
... todos os modelos são aproximações. Essencialmente, todos os modelos
estão errados, mas alguns são uteis.* * Tradução livre
None
O que ignorar
O que ignorar O que importa
+ 40 perguntas - 20 perguntas
4 PILARES
Produto
Algumas tecnologias são mais indicadas para problemas específicos. Ex.: Python
para computações complexas ou Node para um chatbot. Qual problema você quer resolver?
Uma ferramenta interna, não crítica, utilizada por poucos usuários e
em um ambiente controlado, permite (muito) mais experimentações. Quem serão os usuários?
O espaço para riscos usualmente é proporcional ao tempo disponível.
Qual o prazo de entrega?
Garanta que a tecnologia escolhida é capaz de suportar a
carga de usuários em todas as frentes. Qual a estimativa de usuários?
Por quanto tempo esse produto permanecera no ar? É apenas
um teste de mercado? Uma campanha com data para acabar? Ou um produto com existência indefinida? Qual o ciclo de vida desse produto?
Pessoas
Será necessário recrutar mais desenvolvedores ou investe em treinamentos para
o time atualmente disponível? O time atual tem interesse na tecnologia escolhida? O time necessário para desenvolvimento está disponível?
Considere que, durante o aprendizado, o time terá 1/10 da
performance que poderia ter com uma linguagem ou paradigma já dominado por todos ou pela maioria. É necessário introduzir uma nova linguagem ou um novo paradigma?
Considere que, caso seja necessário, esse desenvolvedor terá sua performance
reduzida enquanto transfere conhecimento ao resto do time. Alguém no time já tem experiência utilizando essa stack?
Pessoas entediadas podem optar por tecnologias ultra modernas, "hipsters" e/ou
underground que tornam o recrutamento quase impossível. E entregar o projeto também. Você ou o time estão entediados?
Duas coisas que você nunca deve fazer quando está irritado:
usar !important e tomar decisões de stack. Você está irritado?
Negócios
Quanto mais importante ou crítico, menos espaço para riscos. Qual
a importância do projeto na estratégia de negócios da empresa?
Por mais semelhante que seja a proposta de produto, variações
de ambiente como time e expertise não são emuláveis. Sua decisão se baseia apenas na stack do concorrente?
É impossível garantir que as muitas variáveis envolvidas em um
projeto serão novamente as mesmas. Sua escolha se baseia apenas em sua experiência com projetos anteriores?
Tecnologia
Nosso mercado muda rapidamente. Crie produtos modulares e sempre esteja
preparado para mudanças. A stack é engessada?
De preferência para licenças permissivas, que não limitam o tipo
de produto/ projeto a ser construído. A licença é compatível com o negócio e o projeto?
Cheque a quantidade e qualidade das respostas no Stack Overflow,
issues no Github, livros, conferências, Meetups, artigos e cursos Existe uma comunidade ativa?
Documentação é mais do que uma seção com um exemplo
de uso. Procure documentações de API, guias para contribuição e faça um deep dive no código fonte. A documentação é compreensível?
Procure evidências de que a biblioteca ou linguagem evoluiu ao
longo do tempo e se possui mais de uma major version estável. Está em evolução?
None
None
10 pontos 50 pontos 20 pontos
Inspire-se!
stackshare.io Stacks dos produtos mais populares do mundo com comentários
dos membros do time. Diversos insights valiosos sobre downsides de diversas tecnologias.
builtwith.com Menos preciso porém um bom aliado para identificar algumas
das tecnologias de produtos não listados no stackshare.io
Feito é melhor do que perfeito. Escolha a stack que
te dê mais segurança de que terá sucesso em entregar o produto no prazo e com as características definidas no roadmap.
OBRIGADO!
Work & Co 231 Front St, 5th Floor, Brooklyn, NY
11201 +1 347-470-4803
[email protected]
work.co