Do not speak Portuguese? Translate this site with Google or Bing Translator
Qual é a diferença entre CI e CD?

Posted on: June 24, 2022 11:30 PM

Posted by: Renato

Views: 3064

Qual é a diferença entre CI e CD?

 

A integração contínua (CI) é uma prática que envolve desenvolvedores fazendo pequenas alterações e verificações em seu código. Devido à escala de requisitos e ao número de etapas envolvidas, esse processo é automatizado para garantir que as equipes possam criar, testar e empacotar seus aplicativos de maneira confiável e repetível. A CI ajuda a simplificar as alterações de código, aumentando assim o tempo para que os desenvolvedores façam alterações e contribuam para melhorar o software.

Continuous delivery

A entrega contínua (CD) é a entrega automatizada de código completo para ambientes como teste e desenvolvimento. O CD fornece uma maneira automatizada e consistente para que o código seja entregue a esses ambientes.

Continuous deployment 

A implantação contínua é a próxima etapa da entrega contínua. Cada mudança que passa nos testes automatizados é colocada automaticamente em produção, resultando em muitas implementações de produção.

A implantação contínua deve ser o objetivo da maioria das empresas que não são restringidas por requisitos regulatórios ou outros.

Resumindo, CI é um conjunto de práticas executadas enquanto os desenvolvedores estão escrevendo código, e CD é um conjunto de práticas executadas após a conclusão do código .

Como o CI/CD se relaciona com o DevOps?

 

 

DevOps é um conjunto de práticas e ferramentas projetadas para aumentar a capacidade de uma organização de fornecer aplicativos e serviços mais rapidamente do que os processos tradicionais de desenvolvimento de software. A maior velocidade do DevOps ajuda uma organização a atender seus clientes com mais sucesso e ser mais competitiva no mercado. Em um ambiente DevOps, as organizações bem-sucedidas “incorporam a segurança” a todas as fases do ciclo de vida do desenvolvimento, uma prática chamada DevSecOps .

A principal prática do DevSecOps é integrar a segurança em todos os fluxos de trabalho do DevOps. Ao realizar atividades de segurança com antecedência e de forma consistente ao longo do ciclo de vida de desenvolvimento de software ( SDLC ), as organizações podem garantir que detectem vulnerabilidades o mais cedo possível e sejam mais capazes de tomar decisões informadas sobre riscos e mitigação. Nas práticas de segurança mais tradicionais, a segurança não é abordada até o estágio de produção, que não é mais compatível com a abordagem DevOps mais rápida e ágil. Hoje, as ferramentas de segurança devem se encaixar perfeitamente no fluxo de trabalho do desenvolvedor e no pipeline de CI/CD para acompanhar o DevOps e não diminuir a velocidade de desenvolvimento. 

O pipeline CI/CD faz parte da estrutura DevOps/DevSecOps mais ampla. Para implementar e executar com sucesso um pipeline de CI/CD, as organizações precisam de ferramentas para evitar pontos de atrito que retardam a integração e a entrega. As equipes exigem uma cadeia de ferramentas integrada de tecnologias para facilitar os esforços de desenvolvimento colaborativos e desimpedidos.

Quais ferramentas AppSec são necessárias para pipelines de CI/CD?

 

 

Um dos maiores desafios enfrentados pelas equipes de desenvolvimento que usam um pipeline de CI/CD é abordar adequadamente a segurança. É fundamental que as equipes desenvolvam a segurança sem diminuir seus ciclos de integração e entrega. Mover os testes de segurança para o início do ciclo de vida é uma das etapas mais importantes para atingir esse objetivo. Isso é especialmente verdadeiro para organizações de DevSecOps que dependem de testes de segurança automatizados para acompanhar a velocidade de entrega. 

A implementação das ferramentas certas no momento certo reduz o atrito geral do DevSecOps, aumenta a velocidade de liberação e melhora a qualidade e a eficiência.

Gitlab

Você ainda não conhece o Gitlab? Verifique https://about.gitlab.com/.

O Gitlab é uma aplicação muito interessante, com várias ferramentas e recursos para ajudar e suportar os desenvolvedores em seu processo de DevOps.

“Desde o planejamento do projeto e gerenciamento do código-fonte ao CI/CD e monitoramento, o GitLab é um aplicativo único para o ciclo de vida completo do DevOps.” (gitlab.com)

Você pode ter sua própria instância local (on-premises) ou na nuvem pública ou até mesmo usar a oferta SaaS hospedada pelo GitLab! E acredite, ambos têm uma opção grátis! Verifique https://about.gitlab.com/pricing/.

Algumas citações acima são de https://about.gitlab.com/2016/08/05/continuous-integration-delivery-and-deployment-with-gitlab/, onde você pode encontrar mais informações sobre o que é CI/CD.

No site deles podemos ver a imagem abaixo, que mostra exatamente onde está o CI e o CD em todo o processo e o que está envolvido com cada um deles:

Esta imagem e muitas outras informações sobre o CI/CD e o Gitlab podem ser encontradas em https://docs.gitlab.com/ee/ci/.

Conclusão

CI significa integração contínua e CD pode ser entrega contínua ou deploy contínuo. A entrega contínua ainda precisa de uma interação humana mínima e o deploy contínuo é totalmente automatizado.

O Gitlab é uma das várias soluções que podem ajudar você a configurar o CI/CD.

E você pode estar pensando: é possível ter CI/CD com a linguagem ou plataforma com que eu trabalho? Provavelmente sim! Verifique https://docs.gitlab.com/ee/ci/examples/.

Espero ter te ajudado!

- Fonte:

https://gabriel-faraday.medium.com/o-que-%C3%A9-ci-cd-onde-eu-uso-isso-57e9b8ad8c73

https://www.synopsys.com/glossary/what-is-cicd.html

 


1

Share

Donate to Site


About Author

Renato

Developer

Add a Comment
Comments 0 Comments

No comments yet! Be the first to comment

Blog Search


Categories

OUTROS (16) Variados (109) PHP (133) Laravel (171) Black Hat (3) front-end (29) linux (114) postgresql (39) Docker (28) rest (5) soap (1) webservice (6) October (1) CMS (2) node (7) backend (13) ubuntu (56) devops (25) nodejs (5) npm (3) nvm (1) git (8) firefox (1) react (7) reactnative (5) collections (1) javascript (7) reactjs (8) yarn (0) adb (1) Solid (2) blade (3) models (1) controllers (0) log (1) html (2) hardware (3) aws (14) Transcribe (2) transcription (1) google (4) ibm (1) nuance (1) PHP Swoole (5) mysql (31) macox (4) flutter (1) symfony (1) cor (1) colors (2) homeOffice (2) jobs (3) imagick (2) ec2 (1) sw (1) websocket (2) markdown (1) ckeditor (1) tecnologia (14) faceapp (1) eloquent (14) query (4) sql (40) ddd (3) nginx (9) apache (4) certbot (1) lets-encrypt (3) debian (12) liquid (1) magento (2) ruby (1) LETSENCRYPT (1) Fibonacci (1) wine (1) transaction (1) pendrive (1) boot (1) usb (1) prf (1) policia (2) federal (1) lucena (1) mongodb (4) paypal (1) payment (1) zend (1) vim (4) ciencia (6) js (1) nosql (1) java (1) JasperReports (1) phpjasper (1) covid19 (1) saude (1) athena (1) cinnamon (1) phpunit (2) binaural (1) mysqli (3) database (42) windows (6) vala (1) json (2) oracle (1) mariadb (4) dev (12) webdev (24) s3 (4) storage (1) kitematic (1) gnome (2) web (2) intel (3) piada (1) cron (2) dba (18) lumen (1) ffmpeg (2) android (2) aplicativo (1) fedora (2) shell (4) bash (3) script (3) lider (1) htm (1) csv (1) dropbox (1) db (3) combustivel (2) haru (1) presenter (1) gasolina (1) MeioAmbiente (1) Grunt (1) biologia (1) programming (22) performance (3) brain (1) smartphones (1) telefonia (1) privacidade (1) opensource (3) microg (1) iode (1) ssh (3) zsh (2) terminal (3) dracula (1) spaceship (1) mac (2) idiomas (1) laptop (2) developer (37) api (5) data (1) matematica (1) seguranca (2) 100DaysOfCode (9) hotfix (1) documentation (1) laravelphp (10) RabbitMQ (3) Elasticsearch (1) redis (2) Raspberry (4) Padrao de design (4) JQuery (1) angularjs (4) Dicas (43) Kubernetes (3) vscode (2) backup (1) angular (3) servers (2) pipelines (1) AppSec (1) DevSecOps (4) rust (1) RustLang (1) Mozilla (1) algoritimo (1) sqlite (1) Passport (2) jwt (5) security (2) translate (1) kube (2) iot (1) politica (2) bolsonaro (1) flow (1) podcast (1) Brasil (1) containers (3) traefik (1) networking (1) host (1) POO (2) microservices (2) bug (1) cqrs (1) arquitetura (3) Architecture (4) sail (3) militar (1) artigo (1) economia (1) forcas armadas (1) ffaa (1) autenticacao (2) autorizacao (2) authentication (4) authorization (3) NoCookies (1) wsl (4) memcached (1) macos (2) unix (2) kali-linux (1) linux-tools (5) apple (1) noticias (2) composer (1) rancher (1) k8s (1) escopos (1) orm (1) jenkins (4) github (5) gitlab (3) queue (1) Passwordless (1) sonarqube (1) phpswoole (1) laraveloctane (1) Swoole (1) Swoole (1) octane (1) Structurizr (1) Diagramas (1) c4 (1) c4-models (1) compactar (1) compression (1) messaging (1) restfull (1) eventdrive (1) services (1) http (1) Monolith (1) microservice (1) historia (1) educacao (1) cavalotroia (1) OOD (0) odd (1) chatgpt (1) openai (3) vicuna (1) llama (1) gpt (1) transformers (1) pytorch (1) tensorflow (1) akitando (1) ia (1) nvidia (1) agi (1) guard (1) multiple_authen (2) rpi (1) auth (1) auth (1) livros (2) ElonMusk (2) Oh My Zsh (1) Manjaro (1) BigLinux (2) ArchLinux (1) Migration (1) Error (1) Monitor (1) Filament (1) LaravelFilament (1) replication (1) phpfpm (1) cache (1) vpn (1) l2tp (1) zorin-os (1) optimization (1) scheduling (1) monitoring (2) linkedin (1) community (1) inteligencia-artificial (2) wsl2 (1) maps (1) API_KEY_GOOGLE_MAPS (1) repmgr (1) altadisponibilidade (1) banco (1) modelagemdedados (1) inteligenciadedados (4) governancadedados (1) bancodedados (2) Observability (1) picpay (1) ecommerce (1) Curisidades (1) Samurai (1) KubeCon (1) GitOps (1) Axios (1) Fetch (1) Deepin (1) vue (4) nuxt (1) PKCE (1) Oauth2 (2) webhook (1) TypeScript (1) tailwind (1) gource (2)

New Articles



Get Latest Updates by Email