O DevOps e o Cloud Computing revolucionaram o setor IT. O seu aparecimento conduziu a níveis sem precedentes de eficiência, agilidade e inovação.

O DevOps, que combina desenvolvimento e operações, melhora a colaboração e automatiza processos, reduzindo significativamente o time-to-market de novo software. O Cloud Computing complementa este processo, oferecendo uma infraestrutura escalável, flexível e económica, permitindo que as empresas se adaptem rapidamente às mudanças do mercado. Em conjunto, impulsionam a transformação digital, o que os torna indispensáveis no panorama IT moderno.


Antes de analisarmos as funções e carreiras relacionadas com estas áreas, vamos rever os princípios fundamentais do DevOps e de Cloud, que introduzimos na primeira parte deste artigo. Representam uma mudança de paradigma, concentrando-se não apenas em ferramentas e tecnologias, mas também em processos, cultura e mentalidade. 


Estes princípios sublinham a implementação e gestão bem-sucedidas das práticas DevOps e Cloud, garantindo eficiência, escalabilidade e melhoria contínua no desenvolvimento e implementação de software:

  • Continuous Integration e Continuous Delivery (CI/CD)
    Automatização dos processos de construção, teste e implementação de software para permitir lançamentos frequentes e fiáveis.

  • Colaboração e comunicação
    Incentivo da colaboração aberta e contínua entre desenvolvimento, operações e outras partes interessadas.

  • Infraestrutura como Código (IaC)
    Gestão e aprovisionamento da infraestrutura através de código para obter consistência e eficiência.

  • Testes automatizados
    Implementação de testes automatizados extensivos para garantir a qualidade do código e reduzir o esforço manual.

  • Monitorização e logging
    Monitorização contínua do desempenho e manutenção de logs detalhados para resolução proativa de problemas e otimização.

  • Integração de segurança (DevSecOps)
    Incorporação de práticas de segurança no processo DevOps.

  • Escalabilidade e flexibilidade
    Conceção de sistemas que possam ser escalados e adaptados rapidamente às necessidades em constante mudança, muitas vezes possibilitados por tecnologias de cloud.

  • Foco no cliente
    Fornecimento de valor ao cliente através de atualizações de software funcionais, fiáveis e rápidas.

 

 

A procura por funções Cloud/DevOps

Ao longo dos anos, a procura por profissionais de DevOps e Cloud aumentou significativamente. À medida que mais organizações adotam estas tecnologias, a necessidade de especialistas qualificados que possam navegar em ambas as áreas tornou-se crítica.


Esta tendência não é apenas temporária, mas uma mudança fundamental na forma como os serviços de IT são fornecidos e geridos. Os profissionais com competências nestas áreas são muito procurados e, por conseguinte, beneficiam de salários de topo, refletindo o seu papel fundamental para que as empresas se mantenham competitivas e inovadoras.



Agora… quais são as diferenças entre Engenheiros de Cloud, DevOps, SRE, e de Plataforma?

No cenário complexo das funções de IT modernas, os cargos de Engenheiro DevOps, Site Reliability Engineer (SRE), Engenheiro de Cloud e Engenheiro de Plataforma muitas vezes sobrepõem-se, mas também têm responsabilidades e focos distintos.

Eis uma análise comparativa que destaca as principais diferenças e semelhanças:

 

Engenheiro DevOps
  • Foco: Os Engenheiros DevOps concentram-se em melhorar a colaboração entre o desenvolvimento de software e as operações. Trabalham no sentido de automatizar o processo de implementação de software, garantindo uma entrega consistente e fiável.
  • Principais responsabilidades: Implementar pipelines de CI/CD. Automatizar o processo de criação, teste e implementação de software.  Colmatar o fosso entre as equipas de desenvolvimento e de operações.
  • Competências: Proficiência em ferramentas de automação (como Jenkins, Ansible), codificação/scripting e administração de sistemas.

Site Reliability Engineer (SRE)
  • Foco: Os SRE concentram-se na criação de sistemas de software altamente fiáveis e escaláveis. Com origem na Google, a função é uma mistura de operações com forte ênfase na codificação e automatização.
  • Principais responsabilidades: Garantir a fiabilidade, a escalabilidade e o desempenho do sistema. Implementar a automatização para monitorização e alerta do sistema. Equilibrar a fiabilidade do serviço com o ritmo de lançamento de novas funcionalidades.
  • Competências: Conhecimento profundo de codificação/scripting, administração de sistemas e uma base sólida em princípios de engenharia de software.

 

Engenheiro de Cloud
  • Foco: Os Engenheiros de Cloud são especializados em soluções de computação baseadas na cloud, incluindo infraestruturas, plataformas e software como serviços.
  • Principais responsabilidades: Conceber e gerir infraestruturas e serviços de Cloud Computing. Implementar e gerir medidas de segurança na cloud. Otimizar os recursos da cloud para obter eficiência e rentabilidade.
  • Competências: Experiência em plataformas de cloud (como AWS, Azure, Google Cloud Platform), arquitetura de cloud e gestão de redes/segurança na cloud.

 

Engenheiro de Plataforma
  • Foco: Os Engenheiros de Plataforma trabalham no desenvolvimento e manutenção das plataformas de software que suportam a implementação e as operações de software.
  • Principais responsabilidades: Construir e manter ferramentas e plataformas internas. Garantir a escalabilidade e a eficiência das plataformas. Integrar vários componentes do pipeline de entrega de software.
  • Competências: Conhecimento de tecnologias específicas de plataforma, orquestração de containers (como Kubernetes) e integração de sistemas.

 

Apesar das suas diferenças, estas funções partilham vários aspetos comuns:

  • Automatização: Todas as funções dão ênfase à automatização para melhorar a eficiência e a consistência.
  • Colaboração: Cada função envolve um certo grau de colaboração com outras equipas de IT e de desenvolvimento.
  • Melhoria contínua: É predominante em todas estas funções uma filosofia partilhada de melhoria e otimização contínuas.
  • Competência técnica: É crucial ter uma base sólida em codificação, administração de sistemas e compreensão das infraestruturas modernas de IT.

 

 

O roadmap

Agora que os principais conceitos, a história e os papéis do DevOps estão fora do caminho, vamos olhar para as etapas necessárias para atingir esses objetivos.


Quer venhas da área de Operações ou de Desenvolvimento de Software, as três coisas fundamentais de que precisas são…

 

…Linux, Bash e Containers

Porquê? Bem, o Linux é um sistema operativo gratuito, de código aberto e o número um para o desenvolvimento de software. Neste setor, o código aberto é dominante, o que significa que o Linux tem um enorme impacto e um papel preponderante.


Quanto ao Bash, na minha experiência, nenhuma outra ferramenta tem sido mais versátil para mim do que o script bash, que é uma forma rápida e fiável de automatizar as tarefas diárias. O Bash é a ferramenta que definitivamente precisas de dominar se quiseres tornar-te Engenheiro de DevOps, SRE, Cloud ou Plataforma.


No que diz respeito aos Containers, estes tornaram-se uma tecnologia fundamental para a implementação, gestão e escalamento de aplicações de forma eficiente e fiável, de modo a obter eficiência de recursos, isolamento e ambientes seguros. É a peça central da arquitetura de microsserviços, tem uma integração fácil e, principalmente, nativa com práticas e ferramentas modernas de DevOps, com uma grande comunidade e ecossistema.


Portanto, esses são os principais tópicos que precisarás de conhecer se quiseres ir mais longe. É suficiente? Não, mas com certeza é um ponto de partida e é uma boa maneira de conseguires um emprego como Engenheiro DevOps, SRE, Cloud ou Platforma.


Todos os dias surgem novas tecnologias, pelo que é possível encontrar roadmaps maiores, mas não é necessário ficar sobrecarregado. Uma coisa que tenho aprendido na minha carreira é seguir a regra 80/20, o que significa que se começarmos por procurar 80% do conhecimento, estamos num bom caminho. Na minha experiência, é suficiente ter um conhecimento macro de cada tecnologia e partir daí.


Abaixo encontrarás um roadmap personalizado para quem está a iniciar uma carreira em DevOps. Inspirando-me no roadmap abrangente disponível aqui, simplifiquei o conteúdo para me concentrar nos conceitos, tecnologias, protocolos e ferramentas essenciais necessários no setor, atualmente.


Esta versão condensada foi concebida para fornecer um guia claro e atualizado, ajudando-te a compreender rapidamente os fundamentos e a começar a desenvolver os teus conhecimentos em DevOps.

 

DevOps Roadmap 1

DevOps Roadmap 2

DevOps Roadmap 3

 

Conclusão

As funções de Engenheiro DevOps, Cloud, SRE e Platforma requerem o conhecimento de muitas ferramentas, conceitos e tecnologias, mas eu diria que todos devem começar pelo início – e as três palavras-chave para isso são Linux, Bash e Containers. Depois, o resto das tecnologias pode ser aprendido à medida das necessidades.


Por exemplo, podes aprender todas as funcionalidades e características de um fornecedor de Cloud, como a Amazon Web Services (AWS), mas no final vais precisar de utilizar o Linux. Talvez também precises de automatizar tarefas e, com os conhecimentos básicos que tens de Containers, podes aprender uma ferramenta de orquestração de Containers, como o Kubernetes, que te dará mais oportunidades para criar, testar e implementar aplicações em diferentes ecossistemas.


O meu último conselho é que continues sempre a aprender.

Partilha este artigo