Esta página detalla cómo descargar, descomprimir, configurar y compilar el libbson y libmongoc bibliotecas de su código fuente.
Tip
Información extra
Las admoniciones (como esta) contienen información extra y detalles explicativos que no son necesarios para completar el tutorial, pero pueden ser útiles para lectores curiosos y usuarios más avanzados que deseen una explicación sobre el significado de ciertos pasos del tutorial.
La siguiente página utiliza algunas variables con nombre para representar la información de configuración, como $VERSION. Debe elegir valores para estas variables antes de comenzar el tutorial. Cuando vea una variable referenciada en un paso del tutorial, sustitúyala por su valor.
Tip
Antes de compilar las bibliotecas, compruebe que se ejecutan en una plataforma compatible. Para ver la lista de plataformas compatibles, consulte Páginade compatibilidad.
Elija una versión
Antes de empezar, tenga en cuenta la versión de que mongo-c-driver descargará. Puede encontrar una lista de las versiones disponibles en la página de etiquetas del repositorio de GitHub. Este tutorial documenta la versión actual del controlador: v...222
Para el resto de esta página, $VERSION se referirá al número de versión de mongo-c-driver que construirás para este tutorial.
Obtención de la fuente
Obtenga el código fuente mongo-c-driver de una de las siguientes maneras:
Clona el repositorio usando
git(recomendado). Para más información, consulta "Descargar con Git".Descargue un archivo fuente de una versión específica. Para más información, consulte Descargar un archivo de lanzamiento.
Importante
Se recomienda encarecidamente que los nuevos usuarios utilicen una versión estable del controlador, en lugar de compilar desde una rama de desarrollo. Al git clone usar o descargar un archivo del repositorio, asegúrese de especificar una etiqueta de lanzamiento (por ejemplo, con el --branch argumento de Git).
Descargando utilizando Git
Puedes clonar el repositorio del controlador C desde GitHub usando Git. Las etiquetas de Git para las versiones publicadas se nombran según la versión a la que corresponden (p. ej., "..2 22"). Para clonar el repositorio desde la línea de comandos, usa el siguiente comando:
$ git clone https://github.com/mongodb/mongo-c-driver.git --branch="$VERSION" "$SOURCE"
Tip
A pesar de su nombre, puedes usar la opción --branch del comando git-clone para clonar desde etiquetas del repositorio.
Descargar un archivo de lanzamiento
Puede obtener una instantánea archivada del repositorio de controladores C desde la página de Versiones del repositorio. Cada versión incluye un mongo-c-driver-x.y.z.tar.gz archivo, que contiene el conjunto mínimo de archivos que necesitará para la compilación.
## 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"
Los comandos anteriores crean el directorio mongo-c-driver-$VERSION dentro del directorio donde se ejecutaron, que es la raíz del árbol de código fuente del controlador. Esta documentación se refiere a este directorio como $SOURCE. El directorio $SOURCE contiene el archivo de nivel superior CMakeLists.txt.
## 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"
Los comandos anteriores crean el directorio mongo-c-driver-$VERSION dentro del directorio donde se ejecutaron, que es la raíz del árbol de código fuente del controlador. Esta documentación se refiere a este directorio como $SOURCE. El directorio $SOURCE contiene el archivo de nivel superior CMakeLists.txt.
## 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
Los comandos anteriores crean el directorio mongo-c-driver-$VERSION dentro del directorio donde se ejecutaron. El directorio mongo-c-driver-$VERSION contiene un segundo directorio mongo-c-driver-$VERSION, que es la raíz del árbol de código fuente del controlador. Esta documentación se refiere a este directorio como $SOURCE. El directorio $SOURCE contiene el archivo de nivel superior CMakeLists.txt.
Obtención de prerrequisitos
Debe instalar CMake para configurar los libmongoc libbson proyectos y. Le recomendamos encarecidamente que descargue la última versión estable de CMake disponible para su plataforma.
Seleccione la pestaña correspondiente a su sistema operativo y siga las instrucciones para descargar CMake:
Visita la página de descargas de CMake.
Descargue el archivo CMake
.msio.dmgy utilícelo para instalar CMake.
Visita la página de descargas de CMake
Descarga el script shell autoextraíble, que termina con
.sh.Ejecute el script con la utilidad
shy pasando los argumentos adecuados para realizar la instalación. Por ejemplo, con CMake 3.27.0 en la plataformax86_64, ejecute el siguiente comando:sh cmake-3.27.0-linux-x86_64.sh --prefix="$HOME/.local" --exclude-subdir --skip-license Suponiendo que
$HOME/.local/binestá en su lista$PATH, el comandocmakepara 3.27.0 estará disponible.La opción
--helpse puede pasar al script de shell para obtener más información.
Esta página asume que cmake está disponible como comando en la variable de entorno PATH y puede ejecutarse como "cmake" desde un shell. Puede comprobarlo solicitando --version a CMake desde la línea de comandos, como se muestra en el siguiente código:
cmake --version cmake version 3.21.4 CMake suite maintained and supported by Kitware (kitware.com/cmake).
Nota
Si libbson solo pretende compilar, CMake es suficiente. Las funciones adicionales del controlador C pueden requerir la instalación de dependencias externas adicionales, pero no nos ocuparemos de ellas aquí.
Configuración para libbson
Importante
Sea $BUILD la ruta $SOURCE/_build. Este será el directorio donde CMake escribirá los archivos compilados.
Con el directorio de origen de mongo-c-driver en $SOURCE y el directorio de compilación $BUILD, se puede ejecutar el siguiente comando desde una línea de comandos para configurar el proyecto con libbson y libmongoc:
$ cmake -S $SOURCE -B $BUILD \ -D CMAKE_BUILD_TYPE=RelWithDebInfo \ -D BUILD_VERSION="$VERSION" \ -D ENABLE_MONGOC=OFF
Si se satisfacen todas las dependencias, el comando anterior debería tener éxito y finalizar con:
$ cmake … ## … (Lines of output) … -- Generating done -- Build files have been written to: $BUILD
Si la configuración falló con un error, consulte la salida de CMake para ver los mensajes de error y la información. Asegúrese de que la configuración se realice correctamente antes de continuar.
Tip
¿Qué significan estos argumentos de CMake?
El BUILD_VERSION establece el número de versión que se incluirá en los resultados de la compilación. Debe tener el mismo valor que la versión del controlador fuente descargada en la sección "Obtención del código fuente".
El argumento ENABLE_MONGOC=OFF deshabilitó la creación de libmongoc. La crearemos en la siguiente sección.
La CMAKE_BUILD_TYPE opción indica a CMake qué variante de código se generará. En el caso RelWithDebInfo de, se generarán binarios optimizados, pero se incluirá información de depuración.CMAKE_BUILD_TYPE no afecta a los generadores Multi-Config (por ejemplo, Visual Studio), que utilizan la --config opción al compilar/instalar.
Construyendo el Proyecto
Después de configurar exitosamente el proyecto, la compilación se puede ejecutar usando CMake:
$ cmake --build $BUILD --config RelWithDebInfo --parallel
Si la configuración es correcta y se cumplen todas las dependencias, el comando anterior debería compilar y vincular los componentes configurados. Si el comando falla, es probable que haya un error en su entorno o que esté utilizando una plataforma no compatible o no probada. Consulte la salida de la herramienta de compilación para obtener más información.
Tip
La opción --config
La opción --config se utiliza para establecer la configuración de compilación que se usará en el caso de generadores Multi-Config (por ejemplo, Visual Studio). No tiene efecto en otros generadores, que utilizan CMAKE_BUILD_TYPE.
Instalación de los resultados compilados
Sea $PREFIX la ruta $SOURCE/_install. Podemos usar CMake para instalar los resultados generados:
$ cmake --install "$BUILD" --prefix "$PREFIX" --config RelWithDebInfo
Este comando instalará los resultados de compilación mongo-c-driver en el directorio $PREFIX.
Tip
La opción --config
La opción --config solo se usa para generadores Multi-Config (p. ej., Visual Studio) y, de lo contrario, se ignora. El valor dado para --config debe ser el mismo que el dado para --config con cmake --build.
Configurando con libmongoc
Si siguió los pasos anteriores desde la configuración de libbson, el resultado final solo contendrá libbson y no la biblioteca completa del controlador de base de datos de C. La compilación de libmongoc se habilita o deshabilita mediante la ENABLE_MONGOC variable de CMake. Vuelva a ejecutar CMake, pero ENABLE_MONGOC configure TRUE como:
$ cmake -D ENABLE_MONGOC=ON $BUILD
Si el comando anterior funciona correctamente, el proyecto se ha reconfigurado para compilarse libmongoc con. Siga el proceso descrito libmongocen "Compilación del proyecto e instalación de los resultados de la compilación" para compilar e instalar.
Notas al pie
| [1] | Si desea configurar y compilar el proyecto con Xcode, es necesario instalar y habilitar las herramientas de línea de comandos de Xcode en el entorno. Desde un entorno de línea de comandos, ejecute:$PATH. |
| [2] | Si desea configurar y compilar el proyecto con Microsoft Visual C++, es posible que deba configurar las herramientas y variables de entorno de Visual C++ al ejecutar cualquier comando de CMake o de compilación. En muchos casos, CMake detectará una instalación de Visual Studio y cargará automáticamente el entorno al ejecutarse. Esta detección automática se puede controlar con las -G opciones, -T y -A de CMake. La -G opción es la más importante, ya que selecciona la versión de Visual Studio que se utilizará. Las versiones de Visual Studio compatibles dependen de la versión de CMake que tengainstalada. Puede encontrar una lista de las versiones compatibles de Visual Studio aquí.Para un mayor control y más opciones de herramientas, se recomienda ejecutar comandos desde Visual Studio Developer PowerShell (preferible) o Developer Command Prompt (heredado). Para obtener más información, consulte: Visual Studio Developer Command Prompt y Developer PowerShell y Usar el conjunto de herramientas de Microsoft C++ desde la línea de comandos en las páginas de documentación de Microsoft Visual Studio. |