Join us Sept 17 at .local NYC! Use code WEB50 to save 50% on tickets. Learn more >
MongoDB Event
Docs Menu
Docs Home
/ / /
C 드라이버
/ / /

소스에서 C 드라이버 라이브러리 빌드

이 페이지에서는 원본 소스 코드 형식에서 libbsonlibmongoc 를 다운로드, 압축 풀기, 구성 및 빌드 하는 방법을 자세히 설명합니다.

추가 정보

드롭다운(예: 드롭다운)에는 튜토리얼을 완료하는 데 필요하지 않은 추가 정보와 설명 세부 정보가 포함되어 있지만, 호기심이 많은 독자와 특정 튜토리얼 단계의 의미에 대한 설명을 원하는 고급 사용자에게는 유용할 수 있습니다.

다음 페이지에서는 미리 결정해야 하는 몇 가지 명명된 "변수"를 사용합니다. 튜토리얼 단계에서 이러한 값이 참조되면 해당 단계에 해당 값을 대체해야 합니다.

빌드하기 전에 지원되는 플랫폼에서 실행 확인할 수 있습니다. 지원되는 플랫폼 목록은 mongo-c-driver 플랫폼 지원 페이지를 참조하세요.

시작하기 전에 mongo-c-driver 다운로드할 버전을 확인하세요. 사용 가능한 버전 목록은 GitHub 리포지토리 태그 페이지 에서 확인할 수 있습니다. (이 문서를 위해 작성된 1 현재28 버전은..0 입니다.)

이 페이지의 나머지 부분에서 $VERSION 는 이 튜토리얼을 위해 빌드할 mongo-c-driver 의 버전 번호를 나타냅니다.

mongo-c-driver 소스 코드 를 얻는 데 권장되는 프라이머리 방법에는 두 가지가 있습니다.

  1. git 을(를) 사용하여 리포지토리 를 복제합니다(권장). (아래 참조)

  2. 특정 버전의 소스 아카이브를 다운로드합니다. (아래 참조)

중요

신규 사용자는 개발 브랜치에서 빌드하는 것보다 안정적으로 릴리스된 버전의 운전자 를 사용하는 것이 좋습니다 . git clone 또는 리포지토리 의 아카이브를 다운로드 할 때 출시하다 태그를 지정하다 (예: Git의 --branch 인수 사용)를 지정해야 합니다.

Git을 사용하면 GitHub URL https://github.com/mongodb/mongo-c-driver.git 에서 C 운전자 리포지토리 복제할 수 있습니다. 릴리스된 버전의 Git 태그 이름은 해당 버전의 이름을 따서 지정됩니다(예: "..1 280"). 명령줄 사용하여 리포지토리 복제하려면 다음 명령을 사용할 수 있습니다.

$ git clone https://github.com/mongodb/mongo-c-driver.git --branch="$VERSION" "$SOURCE"

이름에도 불구하고 git-clone--branch 인수를 사용하여 리포지토리 태그 에서 복제할 수도 있습니다.

리포지토리 의 보관된 스냅샷 GitHub 릴리스 페이지 에서 얻을 수 있습니다. 모든 출시하다 mongo-c-driver-x.y.z.tar.gz 에 첨부된 아카이브에는 빌드 에 필요한 최소한의 파일 설정하다 포함되어 있습니다.

## Download using wget:
$ wget "https://github.com/mongodb/mongo-c-driver/archive/refs/tags/$VERSION.tar.gz" \
--output-document="mongo-c-driver-$VERSION.tar.gz"
## Extract using tar:
$ tar xf "mongo-c-driver-$VERSION.tar.gz"
## Using curl:
$ curl "https://github.com/mongodb/mongo-c-driver/archive/refs/tags/$VERSION.tar.gz" \
--output="mongo-c-driver-$VERSION.tar.gz"
## Extract using tar:
$ tar xf "mongo-c-driver-$VERSION.tar.gz"
## Use Invoke-WebRequest:
PS> $url = "https://github.com/mongodb/mongo-c-driver/archive/refs/tags/$VERSION.zip"
PS> $file = "mongo-c-driver-$VERSION.zip"
PS> Invoke-WebRequest -UseBasicParsing -Uri $url -OutFile $file
## Extract using Expand-Archive:
PS> Expand-Archive mongo-c-driver-$VERSION.zip

위의 명령은 tar / Expand-Archive 명령을 실행한 디렉토리 내에 mongo-c-driver-$VERSION 디렉토리를 새로 생성합니다(참고: PowerShell은 동일한 이름의 중간 하위 디렉토리를 추가로 생성합니다). 이 디렉토리는 드라이버 소스 트리(이 문서에서는 $SOURCE 이라고 함)의 루트입니다. $SOURCE 디렉토리에는 최상위 CMakeLists.txt 파일이 포함되어 있어야 합니다.

프로젝트를 빌드하려면 몇 가지 전제 조건을 사용할 수 있어야 합니다.

libmongoclibbson 프로젝트는 모두 빌드 구성에 CMake를 사용합니다.

참고

플랫폼에 사용할 수 있는 최신 안정적인 CMake를 다운로드하는 것이 좋습니다 ( 필수 사항은 아님).

최신 CMake 가져오기

CMake의 새로운 안정적인 출시하다 CMake 다운로드 페이지에서 다운로드할 수 있습니다.

Windows 및 macOS의 경우 CMake .msi / .dmg ( .zip / .tar.gz 아님)를 다운로드하여 CMake를 설치하기만 하면 됩니다.

Linux 에서는 자동 압축 풀림 shell 스크립트 (.sh로 끝남)를 다운로드 하고 sh 유틸리티를 사용하여 실행하고 적절한 인수를 전달하여 설치를 수행합니다. 예를 예시 x86_64 플랫폼의 CMake 3.27.0 을 사용하는 경우 cmake-3.27.0-linux-x86_64.sh 스크립트 에서 다음 명령을 사용할 수 있습니다.

$ sh cmake-3.27.0-linux-x86_64.sh --prefix="$HOME/.local" --exclude-subdir --skip-license

$HOME/.local/bin$PATH 목록에 있다고 가정하면 3.27.0 에 대한 cmake 명령을 사용할 수 있게 됩니다.

--help 옵션을 shell 스크립트에 전달하면 자세한 내용을 확인할 수 있습니다.

이 페이지의 나머지 부분에서는 cmakePATH 환경 변수에서 명령으로 사용할 수 있으며 shell 에서 "cmake" 로 실행할 수 있다고 가정합니다. 명령줄에서 CMake의 --version 를 요청하여 이를 테스트할 수 있습니다.

$ cmake --version
cmake version 3.21.4
CMake suite maintained and supported by Kitware (kitware.com/cmake).

참고

libbson 빌드하려는 경우 빌드에는 CMake로 충분합니다. 추가 C 드라이버 기능을 사용하려면 추가 외부 종속성을 설치해야 할 수 있지만 여기서는 걱정하지 않습니다.

중요

Xcode [1] 또는 Visual Studio [2] 를 사용하여 빌드하는 경우 해당 도구 체인을 사용할 수 있는 특수 환경 내에서 CMake를 실행해야 할 수 있습니다.

이름 $BUILD 을(를) 경로 $SOURCE/_build 로 설정합니다. 이 디렉토리는 CMake가 빌드한 파일을 작성할 디렉토리입니다.

mongo-c-driver 의 소스 디렉토리가 $SOURCE 이고 빌드 디렉토리가 $BUILD 인 경우, 명령줄에서 다음 명령을 실행하여 libbsonlibmongoc 를 모두 사용하여 프로젝트를 구성할 수 있습니다.

$ cmake -S $SOURCE -B $BUILD \
-D ENABLE_EXTRA_ALIGNMENT=OFF \
-D ENABLE_AUTOMATIC_INIT_AND_CLEANUP=OFF \
-D CMAKE_BUILD_TYPE=RelWithDebInfo \
-D BUILD_VERSION="$VERSION" \
-D ENABLE_MONGOC=OFF

모든 종속성이 충족되면 위 명령이 성공하고 다음으로 끝나야 합니다.

$ cmake …
## … (Lines of output) …
-- Generating done
-- Build files have been written to: $BUILD

오류로 인해 구성이 실패한 경우 오류 메시지 및 정보는 CMake 출력을 참조하세요. 계속 진행하기 전에 구성이 성공했는지 확인합니다.

이러한 CMake 인수는 무엇을 의미하나요?

BUILD_VERSION 는 빌드 결과에 포함될 버전 번호를 설정합니다. 이 값은 소스 가져오기에서 다운로드한 소스 드라이버의 버전과 동일한 값으로 설정해야 합니다 .

ENABLE_EXTRA_ALIGNMENTENABLE_AUTOMATIC_INIT_AND_CLEANUPmongo-c-driver 의 일부이며, ABI 호환성을 위해서만 기본적으로 활성화되는 더 이상 사용되지 않는 기능에 해당합니다. 가능하면 이러한 기능을 비활성화하는 것이 좋습니다.

ENABLE_MONGOC=OFF 인수가 libmongoc 건물을 비활성화했습니다. 다음 섹션에서 이를 빌드해 보겠습니다.

CMAKE_BUILD_TYPE 설정은 생성될 코드 변형을 CMake에 알려줍니다. 의 경우 RelWithDebInfo 최적화된 바이너리가 생성되지만 여전히 디버그 정보가 포함됩니다.CMAKE_BUILD_TYPE은 다중 구성 생성기(예: Visual Studio)에는 영향을 주지 않으며 대신 --config 빌드/설치 시 옵션을 사용합니다.

프로젝트를 성공적으로 구성한 후 CMake를 사용하여 빌드를 실행할 수 있습니다.

$ cmake --build $BUILD --config RelWithDebInfo --parallel

올바르게 구성되고 모든 종속성이 충족되면 위 명령을 계속 실행하여 구성된 구성 요소를 컴파일하고 연결해야 합니다. 위의 명령이 실패하면 환경에 오류가 있거나 지원되지 않거나 테스트되지 않은 플랫폼을 사용하고 있을 수 있습니다. 자세한 내용은 빌드 도구 출력을 참조하세요.

--config 옵션

--config 옵션은 다중 구성 생성기의 경우 사용할 빌드 구성을 설정하는 데 사용됩니다(예: Visual Studio). 다른 생성기에는 영향을 주지 않으며 대신 CMAKE_BUILD_TYPE 을(를) 사용합니다.

$PREFIX$SOURCE/_install 경로로 설정합니다. CMake를 사용하여 빌드된 결과를 설치할 수 있습니다.

$ cmake --install "$BUILD" --prefix "$PREFIX" --config RelWithDebInfo

이 명령은 mongo-c-driver 빌드 결과를 $PREFIX 디렉토리 에 설치합니다.

--config 옵션

--config 옵션은 다중 구성 생성기에만 사용됩니다(예: Visual Studio)이며 그렇지 않은 경우 무시됩니다. --config 에 지정된 값은 cmake --build--config 에 지정된 값과 동일해야 합니다.

위의 스니펫은 단순히 소스 디렉토리 자체의 하위 디렉토리에 mongo-c-driver 를 설치하지만 이는 일반적인 워크플로가 아닙니다. mongo-c-driver 구성 및 빌드가 마음에 들면 방법: 소스에서 libbson/libmongoc 설치 페이지에서 소스 설치 옵션에 대해 자세히 설명합니다.

libbson 구성 부터 시작하여 위의 단계를 수행한 경우 최종 결과에는 전체 C 데이터베이스 드라이버 라이브러리가 아닌 libbson 만 포함됩니다. libmongoc 빌드는 ENABLE_MONGOC CMake 변수를 사용하여 활성화/비활성화합니다. CMake를 다시 실행하되 ENABLE_MONGOCTRUE 로 설정합니다.

$ cmake -D ENABLE_MONGOC=ON $BUILD

위의 명령이 성공하면 프로젝트가 libmongoc 으로 빌드되도록 재구성된 것입니다. 프로젝트 빌드하기 및 빌드 된 결과 설치하기 의 프로세스에 따라 libmongoc 을 빌드하고 설치합니다.

[1] Xcode를 사용하여 프로젝트 를 구성하고 빌드 하려면 환경에서 Xcode 명령줄 도구를 설치하고 사용할 수 있도록 설정해야 합니다. 명령줄 환경에서 다음을 실행.
$ xcode-select --install
이렇게 하면 $PATH 에서 컴파일러와 링커를 사용할 수 있습니다.
[2] Microsoft Visual C++ 사용하여 프로젝트 구성하고 빌드 하려면 CMake 또는 빌드 명령을 실행 때 Visual C++ 도구 및 환경 변수를 설정하다 해야 할 수 있습니다. 대부분의 경우 CMake는 Visual Studio 설치를 감지하고 자동으로 로드합니다. 실행될 때 환경 자체입니다. 이 자동 감지는 CMake의,-G -T-A 옵션으로 제어할 수 -G 있습니다. 옵션은 사용할 Visual Studio 버전을 선택하므로 가장 중요합니다. 지원되는 Visual Studio 버전은 설치한 CMake 버전에 따라 다릅니다. 지원되는Visual Studio 버전 목록은 여기에서 확인할 수 있습니다. 더 효과적으로 제어하고 더 많은 도구 옵션을 사용하려면 VisualStudio 개발자 PowerShell(권장) 또는 개발자 명령 프롬프트(레거시)에서 명령을 실행 것이 좋습니다. 자세한 내용은Visual Studio 개발자 명령 프롬프트 및 개발자 PowerShell을 참조하세요. Microsoft Visual Studio 설명서 페이지의 명령줄 에서 Microsoft C++ 도구 세트를 선택합니다.

돌아가기

C 드라이버 라이브러리

이 페이지의 내용