Node.js NativeAddon 构建工具:node-gyp 安装与配置完全指南

news/2025/1/21 20:50:07/

Node.js NativeAddon 构建工具:node-gyp 安装与配置完全指南

node-gyp Node.js native addon build tool [这里是图片001] 项目地址: https://gitcode.com/gh_mirrors/no/node-gyp

项目基础介绍及主要编程语言

Node.js NativeAddon 构建工具(node-gyp) 是一个基于 Node.js 的跨平台命令行工具,专用于编译 Node.js 的原生插件模块。它内部封装了源自Chromium团队使用的 gyp-next 项目,并针对 Node.js 模块开发进行了扩展。值得注意的是,node-gyp 不用来构建 Node.js 自身,而是专注于让开发者能够轻松地在不同的操作系统上编译原生模块。这个工具支持多种版本的 Node.js,并自动匹配对应版本的开发文件。

主要编程语言: JavaScript 和 C/C++

关键技术和框架

  • GYP (Generate Your Projects):由Google开发,用于生成构建文件,如Makefiles或Visual Studio解决方案。
  • Node.js API:利用Node.js的进程环境来配置构建过程。
  • Python (>= v3.12 for node-gyp >= v10):作为辅助工具,在编译过程中用于执行部分脚本。
  • Make (Unix/Linux)Visual Studio 工具链 (Windows):实际执行编译任务的系统工具。

安装与配置详细步骤

准备工作
系统需求

确保你的系统中已安装以下组件:

  • Node.js: 最新或目标版本的Node.js。
  • Python: 对于node-gyp >= v10,推荐安装Python 3.12及以上版本。
  • 开发工具包:
    • Unix/Linux: Python, make工具,以及GCC/G++编译器。
    • macOS: Python, Xcode Command Line Tools(包含clang等)。
    • Windows: Python, Visual Studio Build Tools含C++工具集或Visual Studio 2019/2022(带有桌面开发C++的工作负载)。
全球安装node-gyp

通过npm全局安装node-gyp,确保你的Node.js已正确设置PATH环境变量。

npm install -g node-gyp
配置Python路径

如果你有多个Python版本,需指定node-gyp应使用的版本:

  • Linux/macOS:

    export npm_config_python=“/path/to/python”

  • Windows CMD:

    set npm_config_python=C:path opython.exe

  • Windows PowerShell:

    $Env:npm_config_python=“C:path opython.exe”

或者,直接在命令行调用时指定--python参数。

在特定平台上完成配置
Unix/Linux

确保Python和make工具已就位,还需安装gcc/g++。

macOS

安装Xcode Command Line Tools或单独安装如果已经拥有Xcode。

xcode-select --install
Windows

使用Chocolatey或手动下载安装Python和Visual Studio Build Tools(选择Desktop development with C++ workload)。

  • Chocolatey方式:

    choco install python visualstudio2022-workload-vctools -y

手动配置可能涉及更多的环境变量设置和组件选择。

使用node-gyp编译模块

假设你已经有了一个包含binding.gyp的原生模块项目,基本流程如下:

  1. 进入模块目录:

    cd your-native-module
    
  2. 配置项目(通常不需要额外参数,除非特别指定Python版本或其他编译选项):

    node-gyp configure
    

    对于特定编译环境(如Visual C++ Build Tools 2015),可能需要指定--msvs_version=2015

  3. 编译模块:

    node-gyp build
    

若要创建调试版本,添加--debug-d标志。

至此,你就成功完成了node-gyp的安装与配置,可以在Node.js应用中通过require()调用编译后的原生模块了。


此指南提供了清晰的步骤以帮助新手快速入门node-gyp,但具体细节可能随Node.js版本或系统更新而变化,请参考官方文档获取最新信息。

node-gyp Node.js native addon build tool [这里是图片002] 项目地址: https://gitcode.com/gh_mirrors/no/node-gyp


http://www.ppmy.cn/news/1565037.html

相关文章

Learning Prompt

说明:这是我的学习笔记,很多内容转自网络,请查阅文章末尾的参考资料。 目录 基本要求(C.R.E.A.T.E)总结文章(Summarise)改写文章(Rewrite)根据参考资料回答问题(Question & Answer)参考资料 基本要求(C.R.E.A.T.E) Character This is th…

[实战]Ubuntu使用工具和命令无法ssh,但使用另一台Ubuntu机器可以用命令ssh,非root用户。

现象 新安装一台Ubuntu 22.04服务器,各种远程工具都无法SSH,但使用公司的另一台Ubuntu 22.04的机器可以正常SSH。并且我使用的是非root用户。 百度、谷哥上能试的方案全试了一遍,使用命令ssh仍然提示 permission denied please try again。…

vue3 跨级传递数据

假设我们我们有3层组件 顶层,中间层,底层 如果我们的顶层想给底层传递数据 常规的我们可以用父传子的方式props,顶层传递给中间层,中间层再传给底层,如果中间有很多层,那不炸杠了吗 所以接下来要用vue3推…

中等难度——python实现电子宠物和截图工具

import io # 文件处理 import nt # windows nt 库直接获取对应的磁盘空间 import time # 时间 import zlib # 加解密 import ctypes # 调用 import struct # 处理字节二进制 import base64 # 编解码 import threading # 线程 import tkinter as tk # tk from datetime…

Kotlin基础知识学习(三)

函数使用 基本用法 函数声明变化 如果函数是公开的,则public关键字可以省略。用fun关键字表示函数的定义。如果函数没有返回值可以不用声明。如果函数表示重载,直接在fun同一行用override修饰。函数参数格式是变量名:变量类型。函数参数允…

类和对象(3)——继承:extends关键字、super关键字、protected关键字、final关键字

目录 1. 继承 1.1 继承的概念 1.2 extends关键字 1.3 继承方式 2.继承类的成员访问 2.1 成员变量 2.2 成员方法 3. super关键字 4. super、this 与 构造方法 4.1 子类中的super()调用 4.1.1 父类只有无参构造方法 4.1.2 父类有带参构造方法时 4.2 super 与 this 的…

Dart语言的网络编程

Dart语言的网络编程 引言 在现代软件开发中,网络编程无处不在。无论是移动应用、桌面应用,还是Web应用,网络通信都是实现各种功能的核心。在这个领域,Dart语言因其简洁的语法和与Flutter框架的紧密结合而备受关注。本文将深入探…

2024人工智能AI+制造业应用落地研究报告汇总PDF洞察(附原数据表)

原文链接: https://tecdat.cn/?p39068 本报告合集洞察深入剖析当前技术应用的现状,关键技术 创新方向,以及行业应用的具体情况,通过制造业具体场景的典型 案例揭示人工智能如何助力制造业研发设计、生产制造、运营管理 和产品服…