Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Instalación personalizada: Compilación de las librerías del driver C desde la fuente

Esta página detalla cómo descargar, descomprimir, configurar y compilar el libbson y libmongoc bibliotecas a partir 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 información de configuración, como $VERSION. Debes elegir valores para estas variables antes de comenzar el tutorial. Cuando vea una variable mencionada 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ágina de Compatibilidad.

Antes de empezar, sepa qué versión de mongo-c-driver va a descargar. Se puede encontrar una lista de versiones disponibles en la página de etiquetas del repositorio de GitHub. Este tutorial documenta la versión actual del controlador, v2.2.3.

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.

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 publicada del controlador, en lugar de compilar desde una rama de desarrollo. Cuando git clone o descargue un fichero del repositorio, asegúrese de especificar una etiqueta de lanzamiento (por ejemplo, con el argumento --branch de Git).

Puedes clonar el repositorio C driver desde GitHub usando Git. Las etiquetas de Git para las versiones lanzadas se nombran según la versión a la que corresponden (por ejemplo, “2.2.3”). Para clonar el repositorio desde la línea de comandos, utiliza 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.

Puedes obtener una snapshot archivada del repositorio del driver de C desde la página de lanzamientos del repositorio. Cada versión incluye un mongo-c-driver-x.y.z.tar.gz fichero, que contiene el conjunto mínimo de archivos que necesitarás 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 los ejecutaste, 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 CMakeLists.txt de nivel superior.

## 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 los ejecutaste, 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 CMakeLists.txt de nivel superior.

## 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.

Debes instalar CMake para configurar los proyectos libmongoc y libbson. Recomendamos encarecidamente que descargues la última versión estable de CMake disponible para tu plataforma.

Seleccione la pestaña correspondiente a su sistema operativo y siga las instrucciones para descargar CMake:

  1. Visita la página de descargas de CMake.

  2. Descargue el archivo .msi o .dmg de CMake y utilícelo para instalar CMake.

  1. Visita la página de descargas de CMake

  2. Descarga el script shell autoextraíble, que termina con .sh.

  3. Ejecute el script con la utilidad sh y pasando los argumentos adecuados para realizar la instalación. Por ejemplo, con CMake 3.27.0 en la plataforma x86_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/bin esté en tu lista de $PATH, el comando cmake para 3.27.0 estará entonces disponible.

    La opción --help se puede pasar al script de shell para obtener más información.

Esta página asume que cmake está disponible como un comando en tu variable de entorno PATH y puede ejecutarse como "cmake" desde una shell. Puedes probar esto solicitando el --version de 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 tienes la intención de compilar libbson únicamente, entonces CMake es suficiente para la compilación. Las funcionalidades adicionales del driver C pueden requerir la instalación de dependencias externas adicionales, pero aquí no nos preocuparemos por ellas.

Importante

Si está compilando con Xcode []1 o Visual Studio [],2 es posible que necesite ejecutar CMake desde un entorno especial en el que esté disponible la cadena de herramientas correspondiente.

Deja que el nombre $BUILD sea la ruta $SOURCE/_build. Este será el directorio donde CMake escribirá nuestros 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 ambos 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 obtener mensajes de error e información. Asegúrese de que la configuración se complete correctamente antes de continuar.

Tip

¿Qué significan estos argumentos de CMake?

El BUILD_VERSION configura el número de versión que se incluirá en los resultados de la compilación. Esto debe configurarse con el mismo valor que la versión del controlador de origen que fue descargada en Obtención del origen.

El argumento ENABLE_MONGOC=OFF desactivó la compilación de libmongoc. Lo construiremos 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.

Después de configurar exitosamente el Proyecto, se puede ejecutar el compilar utilizando CMake:

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

Si está debidamente configurado y todas las dependencias están satisfechas, entonces el comando anterior debería proceder a compilar y vincular los componentes configurados. Si el comando anterior falla, es probable que haya un error en su entorno o que esté utilizando una plataforma no compatible o no probada. Consulta la salida de la herramienta de compilar para obtener más información.

Tip

La opción --config

La opción --config se utiliza para definir la configuración de compilación que se va a usar en el caso de generadores Multi-Config (es decir, Visual Studio). No tiene ningún efecto sobre otros generadores, que en su lugar utilizan CMAKE_BUILD_TYPE.

Que $PREFIX sea la ruta $SOURCE/_install. Podemos usar CMake para instalar los resultados compilados:

$ 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.

Tip

Gestión de versiones de la biblioteca

Instalar el MongoDB C Driver desde el código fuente o usando un gestor de paquetes instala archivos que utilizan nombres y rutas con versiones. Para evitar la necesidad de actualizar su configuración de compilar cuando actualice el driver, puede utilizar los mecanismos estándar de detección de dependencias de su sistema de compilar, como el comando find_package() de CMake. También puedes usar las convenciones de enlaces simbólicos de la librería compartida de tu plataforma en lugar de codificar directamente los nombres completos de archivos de la librería o rutas de instalación.

Si seguiste los pasos anteriores empezando por Configurar para libbson, tu resultado final solo contendrá libbson y no la librería completa del driver de base de datos en C. La construcción de libmongoc se habilita/deshabilita usando la variable CMake ENABLE_MONGOC. Ejecuta CMake de nuevo, pero establece ENABLE_MONGOC a TRUE:

$ cmake -D ENABLE_MONGOC=ON -B $BUILD -S $SOURCE

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.

[1] Si deseas configurar y compilar el proyecto con Xcode, las herramientas de línea de comandos de Xcode deben estar instaladas y disponibles en el entorno. Desde un entorno de línea de comandos, ejecuta lo siguiente:
$ xcode-select --install
Esto asegurará que los compiladores y vinculadores estén disponibles en su $PATH.
[2] Si desea configurar y compilar el proyecto utilizando Microsoft Visual C++, es posible que sea necesario configurar las herramientas de Visual C++ y las variables de entorno 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 en sí mismo cuando se ejecute. Esta detección automática se puede controlar con las opciones de CMake -G, -T y -A. La opción -G es la más importante, ya que selecciona qué versión de Visual Studio se utilizará. Las versiones de Visual Studio admitidas dependen de la versión de CMake que tengas instalada. Aquí se puede encontrar una lista de versiones compatibles de Visual Studio.Para un mayor control y más opciones de herramientas, se recomienda ejecutar los comandos desde una PowerShell para desarrolladores de Visual Studio (preferida) o un símbolo del sistema para desarrolladores (heredado).Para obtener más información, consulta: Símbolo del sistema para desarrolladores de Visual Studio y PowerShell para desarrolladores 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.

Volver

Empezar

En esta página