Como gerenciar ambientes de homologação e produção com Team Services? – c# asp.net visual-studio

Pergunta:


Estou em um projeto de ASP.Net C# que está começando agora, mas eu venho do ASP Clássico, onde as coisas são bem diferentes.

Neste novo projeto precisamos fazer a criação e gestão de ambientes de homologação e produção, onde as alterações devem ir para o ambiente de homologação, testadas por outra equipe, e após aprovadas, vão para o servidor de produção.

A forma como fazíamos isso no ASP Clássico era simplesmente ter dois domínios, com FTP distintos, e após aprovado no ambiente de homologação, nós copiávamos os arquivos de um FTP para o outro, para que fique disponível na produção.

No .Net fui introduzido ao Team Services, mas, confesso que ainda não caiu bem a ficha de como ele funciona e se ele consegue me ajudar neste problema aparentemente simples.

Minha pergunta é: Como funciona o Team Services e como ele poderia me ajudar neste controle de versões e ambientes?

Autor da pergunta Andy Schmitt

Cigano Morrison Mendez

A melhor introdução é esta aqui.

Em projetos que usam Git, uma boa prática que está se tornando comum é não realizar commits e pushes no branch master: este branch normalmente é utilizado para a integração contínua, ou seja, cada vez que código novo é mandado ou juntado (merged) em master, há um recurso que pode ser ativado para que o projeto seja testado e publicado sozinho.

Para as equipes, devem ser criados outros branches que representem ou fluxos de trabalho (dev, refactoring, layout, etc.) ou novas funcionalidades (“nome-do-recurso-novo1”, “antigo-recurso-refatorado2”, etc.). Quando as funcionalidades são concluídas, faz-se o merge para master e, dependendo da configuração, o serviço de integração continua sobe o projeto para uma instância de testes ou até mesmo a produção.

O TFS tem o mesmo recurso.

Além disso, há uma série de ferramentas oferecidas que são inerentes ao esforço de desenvolvimento de um projeto, como Backlog, ferramentas de produtividade e integração com outros serviços em nuvem.

Com isso, a ideia de usar FTP é simplesmente defasada. Por exemplo, num projeto ASP.NET MVC com Entity Framework, a atualização do banco é feita automaticamente por um processo chamado Web Deploy, que também tem a função de publicar o código no servidor de aplicação.

Completando a resposta do Cigano Morrison,

Para gerenciar e deploy de vários ambiente você pode usar o Release Management
https://www.visualstudio.com/team-services/release-management/

Aqui trabalhamos como o Cigano comentou, temos um branch master onde temos uma Build Definition com uma trigger apontando para este branch master. Todo checkin que é feito neste branch é o gatilho para enfileirar uma build. Ao concluir toda build a equipe recebe uma notificação por email.

inserir a descrição da imagem aqui

E temos também um Release Definition onde a trigger é justamente nossa Build Definition. A cada build completada com sucesso é disparada nossa release que é bem simples, apenas faz uma publicação da aplicação no servidor.

inserir a descrição da imagem aqui

Porém com o Release management você pode configurar muito mais detalhes como a publicação em diversos ambientes, que aguardam a aprovação e ao serem aprovados são publicados no próximo ambiente. Por exemplo, publicar em um ambiente de homologação, ao ser aprovado para um ambiente de pre-produção, ao ser aprovado, publicar em produção.

Pode também executar diversos processos como testes ou mesmo rodar comandos locais nos servidores para ajustes de ambiente.

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *