O DevOps tem uma filosofia e estrutura em evolução que encorajam o desenvolvimento rápido e aprimorado de aplicativos, além de acelerar o lançamento de recursos de software novos e avançados para os clientes.
A prática de DevOps impulsiona a comunicação mais otimizada e contínua, a colaboração, a integração, a visibilidade e a transparência entre as equipes de desenvolvimento de aplicativos ("Dev") e as de operações de TI ("Ops").
Essa relação de maior proximidade entre as duas equipes está presente em cada fase do ciclo de vida do DevOps: o planejamento do software inicial, as fases de codificação, compilação, teste e lançamento, além da implantação, operações e monitoramento contínuo. Isso incentiva a criação de um loop de feedback contínuo dos clientes, o que impulsiona mais melhorias, desenvolvimento, testes e implantações. Como resultado desses esforços, é possível aplicar aos recursos as mudanças ou os complementos necessários de um jeito mais rápido e contínuo.
Algumas pessoas agrupam metas de DevOps em quatro categorias: Cultura, automação, medição e compartilhamento (CAMS) e ferramentas de DevOps podem ajudar nessas áreas. Essas ferramentas podem tornar os fluxos de trabalho de desenvolvimento e operações mais simplificados e colaborativos, automatizando tarefas que antes consomem tempo, manuais ou estáticas envolvidas na integração, desenvolvimento, teste, implantação ou monitoramento.
Além de seus esforços para quebrar as barreiras à comunicação e colaboração entre as equipes de operações de desenvolvimento e TI, um valor central do DevOps é a satisfação do cliente e a entrega de valor mais rápida. O DevOps também foi desenvolvido para impulsionar a inovação dos negócios e a motivação para a melhoria contínua dos processos.
A prática do DevOps incentiva a entrega mais rápida, melhor e mais segura de valor de negócios aos clientes finais de uma organização. Esse valor pode assumir a forma de lançamentos de produtos, recursos ou atualizações mais frequentes. Isso pode envolver a rapidez com que um lançamento de produto ou um novo recurso entra nas mãos dos clientes, tudo com os níveis adequados de qualidade e segurança. Ou, ele pode se concentrar em quão rapidamente um problema ou bug é identificado, e então resolvido e relançado.
A infraestrutura subjacente também dá suporte ao DevOps com performance, disponibilidade e confiabilidade aprimoradas do software conforme ele é desenvolvido e testado e lançado em produção.
Existem alguns métodos de DevOps comuns que as organizações podem usar para acelerar e melhorar o desenvolvimento e as versões de produtos. Eles assumem a forma de metodologias e práticas de desenvolvimento de software. Entre os mais populares estão Scrum, Kanban e Agile:
Seguidores das práticas de DevOps costumam usar certas ferramentas amigáveis ao DevOps como parte da "cadeia de ferramentas" do DevOps. O objetivo dessas ferramentas é otimizar, encurtar e automatizar ainda mais as várias etapas do fluxo de trabalho de entrega de software (ou "pipeline"). Muitas dessas ferramentas também promovem os princípios básicos de DevOps de automação, colaboração e integração entre as equipes de desenvolvimento e operações. Veja a seguir um exemplo de ferramentas usadas em várias etapas do ciclo de vida do DevOps.
As práticas de DevOps refletem a ideia de melhoria e automação contínuas. Muitas práticas se concentram em uma ou mais fases do ciclo de desenvolvimento. Essas práticas incluem:
Os proponentes do DevOps descrevem vários benefícios técnicos e de negócios, muitos dos quais podem resultar em clientes mais felizes. Alguns benefícios do DevOps incluem:
Muitos métodos de DevOps para otimizar o desenvolvimento e a implantação de software têm uma base inicial no desenvolvimento de software ágil e na programação enxuta. Mas o DevOps originalmente evoluiu de vários movimentos de base para harmonizar as atividades dos desenvolvedores e de suas contrapartes da equipe de operações.
O início dos anos 2000s viu a necessidade de manter a disponibilidade de sites populares, como o Google e o Flickr contra grandes sucessos. Essa necessidade levou ao uso de engenheiros de confiabilidade de software (SREs) – operações que trabalham em estreita colaboração com desenvolvedores para garantir que os sites continuassem funcionando depois que o código fosse lançado em produção.
Em 2009, os engenheiros do Flickr John Allspaw e Paul Hammond apresentaram sua própria metodologia semelhante a DevOps em uma conferência. Sua apresentação foi intitulada "mais de 10 imples por dia: Cooperação de Desenvolvimento e operações no Flickr". No mesmo ano, Patrick Debois organizou o primeiro "dia do DevOps" na Bélgica. Uma hashtag no DevOps também foi incorporada e ganhou impulso à medida que mais dias de DevOps foram realizados em todo o mundo.
Nos próximos anos, ferramentas e frameworks do setor e de código aberto foram desenvolvidos e propostos para alcançar as metas do DevOps.
Com as soluções de DevOps da NetApp, as equipes de operações viabilizam uma infraestrutura automatizada com menos engenharia, e os desenvolvedores trabalham em ambientes confiáveis e previsíveis com mais simplicidade. Ajudamos você a oferecer com confiança os serviços e as funcionalidades de que sua organização precisa para maximizar a produtividade dos desenvolvedores em ambientes no local e na nuvem.
Com o NetApp, os desenvolvedores, os testes, a garantia de qualidade e as equipes de operações têm mais facilidade para consumir recursos de infraestrutura (como volumes de storage persistentes) como código. Tudo isso com ferramentas já conhecidas no pipeline de DevOps. Os exemplos incluem APIs de storage do NetApp e integrações de IAC com ferramentas como Puppet, Ansible, Docker, Kubernetes e OpenShift.
No entanto, o NetApp não apenas facilita para os desenvolvedores o consumo de storage como código. A tecnologia NetApp também permite que as operações provisionem e forneçam recursos com confiança à equipe de desenvolvimento e teste. Desenvolvedores e testadores podem acelerar os ciclos de codificação e teste com o provisionamento automático de recursos de storage rápidos e que economizam tempo, como snapshots ou clones. Com esses recursos, cópias de dados de produção em tempo real ou conjuntos de código podem ser provisionadas como código em poucos segundos ou minutos para acelerar o desenvolvimento e o fluxo de trabalho de QA. Saiba mais sobre por que o NetApp é feito para DevOps.
Por que o NetApp é feito para DevOps
O compromisso da NetApp com a comunidade se estende aothePub. Essa comunidade de desenvolvedores incentiva a colaboração, compartilha dicas e truques e debate ideias sobre as práticas e protocolos mais recentes do DevOps.
A cultura DevOps se concentra em pequenas equipes interdisciplinares que podem trabalhar de forma independente e são conjuntamente responsáveis pela experiência do usuário fornecida por um produto de software.