이전 글에서 nuget 패키지를 관리하는 것에 대한 글을 작성했었는데 이번에는 nuget 패키지를 생성하는 것에 대한 글입니다.
뭐 솔직히 이전까지만해도 nuget 패키지를 설치하여 사용하는 것만 알았지, 생성하는 것에 대한 생각을 하지도 못했었습니다.
회의 시간에 *** 부장님이 BaGet이라는 nuget 서버와 nuget 패키지를 만들어 사용할때의 편리성에 대한 이야기를 했었는데,
그때는 그렇게 할수도 있구나 정도로 생각했었습니다.
어제부터 수행 프로젝트의 일부 기능으로 *.dwg 파일에서 텍스트를 읽어와 연계하는 기능을 만들고 있는데, *.dwg에서 텍스트를 읽어오는 쪽에 ODA라는 상용 라이브러리를 사용하게 되었습니다.(가격도 쎈 놈입니다.)
그런데 ODA쪽의 관련 파일 갯수가 무려 98개나 됩니다.
이걸 소스 저장소에 올리자니 아닌것 같아 nuget 패키지를 만들기로 했습니다.
일단 관련 파일들을 폴더로 정리했습니다.
Root
│ ODA.nuspec
│
└────build
│ ├─── ODA.target
│
└──lib
├───net46
│ TD_Mgd_20.5_15.dll
│ XXX.dll
│ XYX.tx
│
└───runtimes
XXX.txr
XYZ.txv
ODA.nuspec(xml 파일)이 패키지에 관한 정보를 저장하고 있습니다.
크게 metadata와 files로 구분됩니다.
<?xml version="1.0" encoding="utf-8"?>
<package xmlns="http://schemas.microsoft.com/packaging/2013/01/nuspec.xsd">
<metadata>
<id>ODA</id> <!-- 패키지 이름 -->
<version>1.0.50</version>
<title>ODA Drawings.NET Classic</title>
<authors>humkyung</authors>
<owners>humkyung</owners>
<requireLicenseAcceptance>false</requireLicenseAcceptance>
<description>ODA Drawings.NET Classic</description>
<dependencies>
<group targetFramework=".NETFramework4.6" />
</dependencies>
<references>
<group targetFramework=".NETFramework4.6">
<reference file="TD_Mgd_20.5_15.dll" /> <!-- (1) nuget 패키지 설치 후 자동으로 참조하도록 함 -->
</group>
</references>
</metadata>
<files>
<file src="build\ODA.targets" target="build\ODA.targets" /> <!-- (2) 빌드시 복사할 파일들 -->
<file src="lib\net46\TD_Mgd_20.5_15.dll" target="lib\net46\TD_Mgd_20.5_15.dll" />
....
이 파일에서 주목해야 할것은 크게 2가지입니다.
- nuget 설치 후 managed dll을 자동으로 프로젝트에 참조하기 위한 reference 파일 설정
- 프로젝트를 빌드하게 되면 참조된 dll들을 출력 폴더로 복사가 되지만 dependency를 확인하지 못한 파일들은 복사하지 못합니다.
그래서 실행시 오류가 발생하게 됩니다.
따라서 프로젝트 빌드 시 관련 파일들을 복사하기 위해 target 설정을 해줘야 합니다.
target 파일의 이름은 metadata의 id 값과 같아야 합니다.
[ODA.targets]
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Content Include="$(MSBuildThisFileDirectory)..\lib\net46\CDevGuideExamplesProject.dll"> <!-- 복사할 파일의 경로 -->
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
<Link>CDevGuideExamplesProject.dll</Link>
</Content>
이렇게 준비가 끝나면,
nuget.exe를 이용하여 nuget 패키지를 생성하여 서버에 올릴 수가 있습니다.
del .\*.nupkg
REM nuget spec 파일을 이용하여 nuget 패키지를 생성한다
nuget.exe pack ODA.nuspec -OutputDirectory .\
REM 생성한 nuget 패키지를 nuget 서버에 올린다
nuget.exe push .\*.nupkg -Source http://192.168.0.11:9099/v3/index.json
서버에 올릴때 nuget 패키지의 버전을 올려줘야 합니다. 그렇지 않으면 서버에 등록되지 않습니다.
이런 저런 시행 착오를 거치다 보니
하루에 50번 패키지를 만들어 서버에 올렸네요...
회사에서 자주 사용하는 코드들을 nuget 패키지로 만들어 놓으면 편리할것 같습니다.
등록한 NuGet 패키지를 사용하려면 우선 NuGet 패키지 관리자에서 NuGet server를 등록해야 합니다.
댓글
댓글 쓰기