2009-06-10 2 views
19

현재 컴파일 된 ASP.Net 응용 프로그램은 웹 사이트를 로컬에 게시하고 zip 파일을 시스템 관리자에게 전자 메일로 전송하여 배포 지침 세트를 제공합니다. 이는 처음으로 ASP.Net 응용 프로그램을 고객에게 배포하고 IIS 인스턴스를 테스트 할 때 동일한 것이기 때문에 동일한 시스템에 사이트를 두 번 배포 할 수 없었기 때문입니다. 이렇게하면 모든 후속 프로젝트에 배치 할 톤을 설정할 수 있습니다.ASP.Net 응용 프로그램을 야생에 배포하는 데 어떤 방법을 사용합니까?

현재 배포 방법을 평가 중이고 기본 제공되는 배포 도구를 찾고 있습니다. 특히 나는 사용자 정의 설치 작업을보고 있으며 대부분의 표준 설치 프로그램 기능 (대부분 사용자 인터페이스)을 사용할 수 있습니다.

둘째, 배포 및 자동 업데이트 병합을 고려하고 있습니다.

조직에 소프트웨어 배포 방법은 무엇입니까? 어떤 도구를 사용하며 가장 자주 발생하는 문제점은 무엇입니까? 복사 웹 도구를 사용하여

+1

원래 질문을 올린 후 WiX를 발견했습니다. 그것은 오픈 소스이며 무료입니다. 또한 Microsoft가 Office 2007의 배포 패키지를 개발할 때 사용했던 도구이기도합니다. 기본 사항을 이해하면 사용하기 쉽고 인터페이스를 통해 설치시 구성 요소를 선택하고 선택할 수 있습니다. – Hooloovoo

+0

업데이트 만; 응용 프로그램 릴리스 자동화 도구는이 목적을 위해 특별히 설계되었습니다. 비교할만한 주목할만한 도구가 있습니다. https://en.wikipedia.org/wiki/Application_release_automation –

답변

-2

배포 웹 응용 프로그램 당신이 (예를 들어, 많은 사용자에게 웹 응용 프로그램을 제공하는 경우 Microsoft 교육 키트 예약 웹 기반 개발
웹 설치 프로젝트에서
텍스트 사람들이 다운로드 할 수 있도록 유용 웹에서 응용 프로그램을 설치하고 설치). 조직의 특정 웹 사이트를 업데이트해야하는 경우 업데이트 할 때마다 웹 서버에 로그온하고 Windows Installer 패키지를 설치하는 것은 비현실적입니다. 내부 응용 프로그램의 경우 웹 서버에서 직접 웹 응용 프로그램을 편집 할 수 있습니다. 그러나 변경 사항은 프로덕션 웹 응용 프로그램에 즉시 구현되며 여기에는있을 수있는 버그가 포함됩니다. 사용자가 웹 응용 프로그램을 테스트 할 수있게하려면 컴퓨터에서 웹 응용 프로그램의 로컬 복사본을 편집하고 웹 복사 도구를 사용하여 프로덕션 웹 서버에 변경 내용을 게시 할 수 있습니다. 또한 웹 복사 도구를 사용하여 스테이징 서버에서 프로덕션 웹 서버로 또는 두 웹 서버간에 변경 사항을 게시 할 수 있습니다. 웹 복사 도구는 원본 파일이나 전체 웹 사이트를 원본 웹 사이트와 원격 웹 사이트간에 복사 할 수 있습니다. 또한 변경된 파일 만 복사하고 소스 및 원격 사이트의 동일한 파일을 개별적으로 편집 할 수있는 버전 충돌을 감지하여 파일을 동기화하도록 선택할 수 있습니다. 웹 복사 도구는 단일 파일 내에서 변경 내용을 병합 할 수 없습니다. 전체 파일 만 복사 할 수 있습니다.

1) 빌드를 컴파일하고 청소하기 위해뿐만 아니라 나눠 Web.config의 섹션 교체에 웹 배포 프로젝트를 사용하여 환경의 설정 변경의 경우 :

+0

가장 자주 사용하는 환경은 5 개의 전용 웹 서버. 우리는 반복적이고 쉬운 배포 경로를 찾고 있습니다. 특히 배포 또는 프로덕션 환경 (배포 경로의 환경 4 및 5)에 액세스 할 수 없기 때문에 기본적으로 많은 사용자에게 배포하고 있습니다. :-) – Hooloovoo

+0

http://msdn.microsoft.com/en-us/library/xay0wxbf(VS.80).aspx – MarkJ

0

내가했던 몇 가지는 다음과 같습니다. 2) 건물, 보관 및 복사를 모두 반복적으로 수행하려면 NAnt를 사용하십시오.

웹 배포 프로젝트는 NAnt 대신 사용할 수있는 MSBuild 파일을 만듭니다. 그러나, 나는 자바 배경에서 왔고 Ant는 항상 사용했다. 따라서 NAnt는 나의 선호도가 .Net이다. NAnt Contrib 작업을 추가하면 파일뿐만 아니라 소스 컨트롤 (기본 작업의 일부가 아닌 경우) 및 변경 사항에 대한 SQL 스크립트 실행과 같은 항목도 처리 할 수 ​​있습니다.

현재 두 옵션을 함께 사용합니다. 내 NAnt 빌드 파일을 MSBuild를 통해 웹 배포 프로젝트에 호출합니다. 각 환경에 대한 구성 관리자 설정을 사용하면 web.config 섹션 대체를 자동으로 관리 할 수 ​​있으며 릴리스의 복사 및 아카이브에 대한 제어가 가능합니다.

희망이 도움이됩니다.

+0

현재 우리는 JetBrains의 TeamCity를 사용하고 있으며 다른 누군가가 빌드 스크립트를 설정하도록했습니다! 그것은 매우 간단하고 CI 서버에서 MSBuild를 사용합니다. 또한 사이트를 올바르게 구축하기 위해 웹 배포 프로젝트를 사용하지만 때로는 제대로 설정하기가 다소 어려울 수 있습니다. – Hooloovoo

+0

빌드 설정을 적절하게하는 관점에서 무엇을 의미하는지 알고 있습니다. 필자는 배포 된 환경마다 Configuration Manager 환경을 설정하고 웹 배포 프로젝트를 각각의 환경 (NAnt 또는 CI 서버의 빌드 파일을 사용하여 자동화 된 환경) 아래에 빌드하도록 기본 설정했습니다. 추가 청소/조작이 필요한 경우 WDproj (msbuild) 파일을 직접 편집하거나 NAnt에서 업데이트를 수행합니다. TeamCity 용 CI 빌드 파일을 작성하지 않으므로 wdproj가 최선의 방법입니다. 그 외에는 각 환경에서 고통 점이 무엇인지 살펴보고 그 점에 초점을 맞 춥니 다. – JamesEggers

0

우리는 웹 배포 프로젝트와 VS 2008 프로젝트를 사용하여 웹 배포 & 다른 프로젝트의 출력에서 ​​.msi를 만듭니다. 'setup'이라고하는 일반 Windows 응용 프로그램은 사용자 지정 단계로 설치 프로젝트를 사용자 지정하는 대신 많은 db 생성 및 예비 작업을 수행하는 데 사용됩니다. MS 코드를 사용자 정의하는 것보다 직접 수행하는 것이 훨씬 쉽습니다. 이 Windows 응용 프로그램은 사용자가 필요로하는 올바른 .msi 파일을 호출합니다.

매일 밤 팀 기반 빌드가 실행되어 솔루션을 다시 빌드하고 모든 사람을 액세스하고 최신 '릴리스'에 대한 테스트를 수행 할 수있는 '릴리스 CD'디렉터리에 모든 내용을 복사합니다. 정직한 TFS 빌드는 우리 팀과 같은 소규모 팀을 위해 조금 배외되어 있습니다.

이전 회사에서는이 http://www.finalbuilder.com/을 사용했으며 사용하기 쉽고 지원되는 소프트웨어의 양을 고려하여 권장 할 수 있습니다.

1

1)/각 웹 서버 인트라넷 사이트에 대한

+0

이 문제는 우리가 제 3 환경을 지나서 접근 할 수 없으므로 가능한 한 자동화해야한다는 것입니다. 기업 브랜딩의 관점에서 볼 때, 이것은 엄청나게 강하지 않습니다. 지난 몇 년 동안 우리가 해왔 던 일이 꽤 많이 있었다고 말했죠! – Hooloovoo

0

에 직접 붙여 넣기 생산 환경

3) 복사에 MSBUILD와

2) FTP 파일을 프로젝트를 빌드, 우리는 SVN와 함께 CruiseControl를 사용 사이트를 자동으로 재구성 할 수 있습니다.

이론적으로 클라이언트의 인트라넷에 드라이브를 원격으로 매핑 할 수있는 경우 VPN을 통해이 모델을 확장 할 수 있습니다. 또는 더 빠르고 더러운 솔루션은 SyncBack과 같은 도구를 사용하여 사이트의 컴파일 된 DLL이 포함 된 원격 폴더를 동기화하는 것일 수 있습니다.

3

우리는 DEV, TEST, STAGE 및 PRODUCTION 전용 서버를 보유하고 있습니다.

또한 크루즈 컨트롤을 실행하는 전용 빌드 머신이 있습니다.

Cruise Control은 코드가 체크인 된 후 실행되는 연속 통합 빌드를 위해 구성되며 별도의 개발, QA, 스테이지 및 프로덕션 작업을 위해 구성됩니다.

코드를 먼저 SVN에서 검색하여 빌드 한 다음 "미리 컴파일 된 웹"폴더를 개발 웹 사이트에 복사하고 웹 서비스 프로젝트를 개발 응용 프로그램 서버에 복사합니다. Cruise Control은 빌드가 시작되기 전에 소스 코드에 "태그를 추가"하도록 구성되어 나중에 빌드를 재현하거나 핫 픽스를 수행해야하는 경우 태그에서 분기 할 수 있습니다.

QA에 배포하려면 파일이 개발 컴퓨터에서 QA 컴퓨터로 복사됩니다.

마찬가지로 스테이지에 배포하기 위해 파일이 QA 시스템에서 스테이지 시스템으로 복사됩니다.

마지막으로 프로덕션에 배포하기 위해 파일이 스테이지 시스템에서 프로덕션 시스템으로 다시 복사됩니다.

각 환경을 구성하려면 연결 문자열 "debug = true | false", "customErrors = Off | RemoteOnly"및 기타 환경 별 설정을 수정하는 각 환경의 Cruise Control 작업의 일부인 사용자 지정 도구가 있습니다. .

각 환경을 Cruise Control 대시 보드에서 버튼을 눌러 배치 할 수 있습니다.

크루즈 컨트롤 설정 파일에 프로덕션 데이터베이스 비밀번호가 설정되어 있다는 경고가 있습니다. 다른 곳으로 옮길 수 있습니다.

마지막으로 우리의 프로덕션 시스템이 전용 호스팅 시설에 있어도 Cruise Control 컴퓨터에서 서버에 액세스 할 수 있으므로 프로덕션 배포를 매우 쉽게 할 수 있습니다. 유일한 수동 단계는 web.config 파일을 암호화하고 Cruise Control이 설정하는 "AppOffline.html"파일을 제거하는 것입니다.

도움이되는지 또는 궁금한 점이 있으면 알려주십시오.

감사합니다.

+0

CC 시스템에서 호스팅 설비의 프로덕션 시스템에서 어떻게 액세스합니까? (UNC, FTP 등)? – RyanW

+0

어쨌든, 생산 기계는 특정 기계 (Cruise Control 기계가 그 중 하나임)에서만 로컬 네트워크에서 사용할 수있었습니다. 나는 더 이상 그 회사에 가지 않기 때문에 더 이상 sysadmin에게 직접 물어볼 수있는 권한이 없습니다. 그래서 배포는 파일을 네트워크의 다른 컴퓨터로 복사하는 것처럼 동작합니다. 나는 UNC 경로가 사용되었다고 생각한다. –

관련 문제