gpt4 book ai didi

node.js - 如何在snapcraft中正确安装Node.js?

转载 作者:行者123 更新时间:2023-12-03 12:21:18 24 4
gpt4 key购买 nike

https://ubuntu.com/tutorials/electron-kiosk#4-converting-the-electron-snap-into-a-kiosk-snap
你好 !
我已经按照本教程进行操作,但是我无法使其正常运行,我的问题是,至少在需要10.12时才安装了nodejs 8.10.0。
我尝试添加 Node 版本或 Node 引擎或其他参数,但是在安装8.10.0之后,它不会加载我想要的版本。
如果有人可以帮助我!
[编辑]
我在nodejs-version: "12.18.3"之后添加plugin: nodejs运行snapcraft时的一些日志

Launching a VM.
snap "snapd" has no updates available
Running with 'sudo' may cause permission errors and is discouraged. Use 'sudo' when cleaning.
Skipping pull desktop-gtk3 (already ran)
Skipping pull xwayland-kiosk-helper (already ran)
Hit http://archive.ubuntu.com/ubuntu bionic InRelease
Hit http://archive.ubuntu.com/ubuntu bionic-updates InRelease
Hit http://security.ubuntu.com/ubuntu bionic-security InRelease
Fetched 0 B in 0s (0 B/s)
Get:1 libxdmcp6_1.1.2-3_amd64.deb [10.7 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 gconf2-common_3.2.6-4ubuntu1_all.deb [700 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libdbus-1-3_1.12.2-1ubuntu1.2_amd64.deb [175 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libasound2-data_1.1.3-5ubuntu0.5_all.deb [38.7 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libsqlite3-0_3.22.0-1ubuntu0.4_amd64.deb [499 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libbsd0_0.8.7-1ubuntu0.1_amd64.deb [41.6 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libx11-6_1.6.4-3ubuntu0.3_amd64.deb [571 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libxau6_1.0.8-1ubuntu1_amd64.deb [7556 B]
Fetched 0 B in 0s (0 B/s)
Get:1 libxcb1_1.13-2~ubuntu18.04_amd64.deb [45.5 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libxtst6_1.2.3-1_amd64.deb [12.8 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 ucf_3.0038_all.deb [50.5 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libdbus-glib-1-2_0.110-2_amd64.deb [58.3 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libx11-data_1.6.4-3ubuntu0.3_all.deb [114 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libasound2_1.1.3-5ubuntu0.5_amd64.deb [360 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libnss3_3.35-2ubuntu2.12_amd64.deb [1220 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libffi6_3.2.1-8_amd64.deb [17.9 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 x11-common_7.7+19ubuntu7.1_all.deb [22.5 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libgconf-2-4_3.2.6-4ubuntu1_amd64.deb [84.8 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libxss1_1.2.2-1_amd64.deb [8582 B]
Fetched 0 B in 0s (0 B/s)
Get:1 libglib2.0-0_2.56.4-0ubuntu0.18.04.6_amd64.deb [1171 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libnspr4_4.18-1ubuntu1_amd64.deb [112 kB]
Fetched 0 B in 0s (0 B/s)
Get:1 libx11-xcb1_1.6.4-3ubuntu0.3_amd64.deb [9628 B]
Fetched 0 B in 0s (0 B/s)
Get:1 libxext6_1.3.3-1_amd64.deb [29.4 kB]
Fetched 0 B in 0s (0 B/s)
Cleaning later steps and re-pulling electron-helloworld ('nodejs-version' property changed)
Cloning into '/root/parts/electron-helloworld/src'...
remote: Enumerating objects: 688, done.
remote: Total 688 (delta 0), reused 0 (delta 0), pack-reused 688
Receiving objects: 100% (688/688), 445.19 KiB | 1.31 MiB/s, done.
Resolving deltas: 100% (365/365), done.
Downloading 'node-v12.18.3-linux-x64.tar.gz'[================================================================================================================================================================] 100%
Downloading 'latest.tar.gz'[=================================================================================================================================================================================] 100%
Skipping build desktop-gtk3 (already ran)
Skipping build xwayland-kiosk-helper (already ran)
Building electron-helloworld
▐ ╢░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
WARN engine electron-packager@15.1.0: wanted: {"node":">= 10.12.0"} (current: {"node":"8.10.0","npm":"3.5.2"})
loadDep:global-tunnel-ng ▀ ╢█████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
loadDep:serialize-error → ▀ ╢███████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
WARN engine semver@7.3.2: wanted: {"node":">=10"} (current: {"node":"8.10.0","npm":"3.5.2"})
WARN engine serialize-error@7.0.1: wanted: {"node":">=10"} (current: {"node":"8.10.0","npm":"3.5.2"})
loadDep:serialize-error → ▐ ╢███████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
loadDep:type-fest → reque ▀ ╢███████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
loadDep:pend → resolveWit ▀ ╢███████████████████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
WARN engine extract-zip@2.0.1: wanted: {"node":">= 10.17.0"} (current: {"node":"8.10.0","npm":"3.5.2"})
loadDep:yargs-parser → ge ▄ ╢█████████████████████████████████████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░╟
WARN engine electron-notarize@1.0.0: wanted: {"node":">= 10.0.0"} (current: {"node":"8.10.0","npm":"3.5.2"})
npm ERR! Linux 4.15.0-1072-kvm
npm ERR! argv "/usr/bin/node" "/usr/bin/npm" "install" "electron" "electron-packager"
npm ERR! node v8.10.0
npm ERR! npm v3.5.2
npm ERR! code EMISSINGARG

npm ERR! typeerror Error: Missing required argument #1
npm ERR! typeerror at andLogAndFinish (/usr/share/npm/lib/fetch-package-metadata.js:31:3)
npm ERR! typeerror at fetchPackageMetadata (/usr/share/npm/lib/fetch-package-metadata.js:51:22)
npm ERR! typeerror at resolveWithNewModule (/usr/share/npm/lib/install/deps.js:456:12)
npm ERR! typeerror at /usr/share/npm/lib/install/deps.js:457:7
npm ERR! typeerror at /usr/share/npm/node_modules/iferr/index.js:13:50
npm ERR! typeerror at /usr/share/npm/lib/fetch-package-metadata.js:37:12
npm ERR! typeerror at addRequestedAndFinish (/usr/share/npm/lib/fetch-package-metadata.js:82:5)
npm ERR! typeerror at returnAndAddMetadata (/usr/share/npm/lib/fetch-package-metadata.js:117:7)
npm ERR! typeerror at pickVersionFromRegistryDocument (/usr/share/npm/lib/fetch-package-metadata.js:134:20)
npm ERR! typeerror at /usr/share/npm/node_modules/iferr/index.js:13:50
npm ERR! typeerror This is an error with npm itself. Please report this error at:
npm ERR! typeerror <http://github.com/npm/npm/issues>

npm ERR! Please include the following file with any support request:
npm ERR! /root/parts/electron-helloworld/build/npm-debug.log
cp: cannot stat './electron-quick-start-linux-x64': No such file or directory
Failed to run 'override-build': Exit code was 1.
Run the same command again with --debug to shell into the environment if you wish to introspect this failure.

(对不起,也许英语不好)

最佳答案

没错,即使通过core18中的base: core18snapcraft.yaml用作基础,snap包中的nodejs运行时也已经过时了。
该解决方案不是使用snapcraft nodejs插件,而是直接从nodejs分发文件文件https://nodejs.org/dist/下载提供的二进制文件。
这可以通过snapcrafts dump插件非常方便地完成,该插件仅需一行代码即可支持下载和提取存档(甚至是有效的xy压缩):要获得64位(AMD)Linux的最新nodejs版本的12.18.x,可以使用parts定义来获取它抓紧时间:

parts:
node:
plugin: dump
source: https://nodejs.org/dist/v12.18.4/node-v12.18.4-linux-x64.tar.xz
然后,可在snaps bin目录中使用Node.js。然后,用于启动javascript应用程序的命令如下所示:
command: bin/node $SNAP/app/index.js

关于node.js - 如何在snapcraft中正确安装Node.js?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63848035/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com