NEWS
SOLVED [gelöst] Adapterinstallation - node gyp error
-
Guten Abend zusammen,
ich habe aktuell einige Probleme, manche Adapter zu installieren - aktuell scheitere ich sowohl über Admin als auch über die Konsole, denn iobroker.roomba Adapter zu installieren. Im Log sehe ich auch zahlreiche Probleme, kann aber keines davon identifizieren, bzw. habe keine passende Lösung gefunden.
Hier das Log:
root@HOME:/home/pi# iobroker install iobroker.roomba NPM version: 6.7.0 npm install iobroker.roomba@1.0.0 --production --save --prefix "/opt/iobroker" (System call) node-pre-gyp WARN Using request for node-pre-gyp https download node-pre-gyp WARN Tried to download(404): https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.5.0/canvas-v2.5.0-node-v67-linux-glibc-arm.tar.gz node-pre-gyp WARN Pre-built binaries not found for canvas@2.5.0 and node@11.6.0 (node-v67 ABI, glibc) (falling back to source compile with node-gyp) ../src/bmp/BMPParser.cc: In member function 'void BMPParser::Parser::parse(uint8_t*, int, uint8_t*)': ../src/bmp/BMPParser.cc:193:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data > imgdOffset, "image data overlaps with another structure"); ~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/bmp/BMPParser.cc:208:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data + imgdSize > len, "not enough image data"); ~~~~~~~~~~~~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/CanvasRenderingContext2d.cc: In static member function 'static Nan::NAN_METHOD_RETURN_TYPE Context2d::DrawImage(Nan::NAN_METHOD_ARGS_TYPE)': ../src/CanvasRenderingContext2d.cc:1291:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_x = abs(transforms[1]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/11.6.0/include/node/v8.h:21, from /home/iobroker/.node-gyp/11.6.0/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/11.6.0/include/node/v8.h:21, from /home/iobroker/.node-gyp/11.6.0/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ ../src/CanvasRenderingContext2d.cc:1292:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_y = abs(transforms[2]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/11.6.0/include/node/v8.h:21, from /home/iobroker/.node-gyp/11.6.0/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/11.6.0/include/node/v8.h:21, from /home/iobroker/.node-gyp/11.6.0/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ make: *** [Release/obj.target/canvas/src/CanvasRenderingContext2d.o] Error 1 gyp ERR! build error gyp ERR! stack Error: `make` failed with exit code: 2 gyp ERR! stack at ChildProcess.onExit (/usr/local/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23) gyp ERR! stack at ChildProcess.emit (events.js:188:13) gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:254:12) gyp ERR! System Linux 4.19.57-v7+ gyp ERR! command "/usr/local/bin/node" "/usr/local/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "build" "--fallback-to-build" "--module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node" "--module_name=canvas" "--module_path=/opt/iobroker/node_modules/canvas/build/Release" "--napi_version=3" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v67" gyp ERR! cwd /opt/iobroker/node_modules/canvas gyp ERR! node -v v11.6.0 gyp ERR! node-gyp -v v3.8.0 gyp ERR! not ok node-pre-gyp ERR! build error node-pre-gyp ERR! stack Error: Failed to execute '/usr/local/bin/node /usr/local/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js build --fallback-to-build --module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node --module_name=canvas --module_path=/opt/iobroker/node_modules/canvas/build/Release --napi_version=3 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v67' (1) node-pre-gyp ERR! stack at ChildProcess.<anonymous> (/opt/iobroker/node_modules/canvas/node_modules/node-pre-gyp/lib/util/compile.js:83:29) node-pre-gyp ERR! stack at ChildProcess.emit (events.js:188:13) node-pre-gyp ERR! stack at maybeClose (internal/child_process.js:978:16) node-pre-gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:265:5) node-pre-gyp ERR! System Linux 4.19.57-v7+ node-pre-gyp ERR! command "/usr/local/bin/node" "/opt/iobroker/node_modules/canvas/node_modules/.bin/node-pre-gyp" "install" "--fallback-to-build" node-pre-gyp ERR! cwd /opt/iobroker/node_modules/canvas node-pre-gyp ERR! node -v v11.6.0 node-pre-gyp ERR! node-pre-gyp -v v0.11.0 node-pre-gyp ERR! not ok npm WARN bl@0.7.0 requires a peer of stream-browserify@* but none is installed. You must install peer dependencies yourself. npm WARN optional SKIPPING OPTIONAL DEPENDENCY: osx-temperature-sensor@1.0.3 (node_modules/osx-temperature-sensor): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for osx-temperature-sensor@1.0.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"arm"}) npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! canvas@2.5.0 install: `node-pre-gyp install --fallback-to-build` npm ERR! Exit status 1 npm ERR! npm ERR! Failed at the canvas@2.5.0 install script. npm ERR! This is probably not a problem with npm. There is likely additional logging output above. npm ERR! A complete log of this run can be found in: npm ERR! /home/iobroker/.npm/_logs/2019-08-07T21_50_42_069Z-debug.log host.HOME Adapter directory "null" does not exists Cannot parse null/io-package.json:Error: ENOENT: no such file or directory, open 'null/io-package.json' root@HOME:/home/pi#
Ich möchte ungern rumprobieren und "verschlimmbessern" - daher hoffe ich, dass mir von euch jemand auf die Sprünge helfen kann. Hier noch die Versionen von npm und node, wenn es hilft:
root@HOME:/home/pi# node -v v11.6.0
root@HOME:/home/pi# npm -v 6.7.0
Recht herzlichen Dank vorab für jegliche Unterstützung!
Grüße
Sundance
-
Du hast eine Entwicklerversion von Node installiert. Nimm mal ne 8er oder 10er und probier dann noch mal.
Gruß dna909
-
@dna909 - da bin ich schon mit meinem Latein am Ende. Was ist der sicherste Weg, meine Node Version auf die 10 "downzugraden", ohne mir dabei irgendwas anderes zu zerschießen? Ich habe da leider kaum Erfahrung...
Danke vorab für deine Hilfe!
Beste Grüße
Sundance
-
Dazu empfehle ich Dir folgenden Thread:
https://forum.iobroker.net/topic/22867/how-to-node-js-für-iobroker-richtig-updaten
damit sollte das eigentlich funktionieren.
Gruß
dna909
-
@dna909 - danke für den Thread, bin es mal durchgegangen. Allerdings zeigt mir die Konsolo eine Meldung an, dass bereits eine neuere Version installiert ist.
Muss ich die alte Version vorher komplett löschen, wie weiter unten im Thread beschrieben, oder gibt es einen anderen bzw. besseren Weg das zu lösen?
Vielen Dank
Grüße
sundance
-
@Sundance sagte in Adapterinstallation schlägt fehl - node-gyp Fehler:
...................
node-pre-gyp WARN Pre-built binaries not found for canvas@2.5.0 and node@11.6.0 (node-v67 ABI, glibc) (falling back to source compile with node-gyp)
....
Sundance -
@Glasfaser Danke für den Hinweis, den Thread hatte ich soweit durch und auch die Libraries gemäß Angaben vorher aktualisiert.. leider bleibt das Resultat gleich. Ich denke ich werde an meiner node version schrauben müssen...
-
NPM Version 6.7.0 ... mhhh ?? ... Zeig mal : nodejs -v
sudo apt-get --purge remove node sudo apt-get --purge remove nodejs sudo apt-get autoremove sudo reboot curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash - sudo apt-get install -y build-essential libavahi-compat-libdnssd-dev libudev-dev libpam0g-dev nodejs sudo reboot cd /opt/iobroker
und dann noch
npm rebuild
und wiederreboot
.Kenn dein System nicht ... dann eventuell noch :
curl -sL https://raw.githubusercontent.com/ioBroker/ioBroker/stable-installer/fix_installation.sh | bash -
-
@Glasfaser - mein nodejs -v sagt:
pi@HOME:~ $ nodejs -v v10.16.2
Soll ich deinen Vorschlag unabhängig davon testen, oder soll ich vorher noch was eine andere NPM version installieren oder sowas?
Danke für deine Hilfe..
Beste Grüße
Sundance
-
Die Versionen passen nicht zusammen .
nimm meinen Vorschlag ...
( kann dir leider nur halb helfen da ich eine Synology habe unter Docker deshalb nimm den Thread was dir dna909 vorgeschlagen hat .) -
@Glasfaser - dein Vorschlag hat soweit erstmal super funktioniert, ich habe jetzt folgende Versionen:
Node v10.16.2
NPM 6.9.0Allerdings habe ich jetzt wieder ein anderes Problem, nämlich mit dem Zigbee Adapter:
error: Caught by controller[0]: /opt/iobroker/node_modules/bindings/bindings.js:88 error: Caught by controller[0]: throw e error: Caught by controller[0]: ^ error: Caught by controller[0]: Error: The module '/opt/iobroker/node_modules/@serialport/bindings/build/Release/bindings.node' error: Caught by controller[0]: was compiled against a different Node.js version using error: Caught by controller[0]: NODE_MODULE_VERSION 67. This version of Node.js requires error: Caught by controller[0]: NODE_MODULE_VERSION 64. Please try re-compiling or re-installing error: Caught by controller[0]: the module (for instance, using `npm rebuild` or `npm install`). error: Caught by controller[0]: at Object.Module._extensions..node (internal/modules/cjs/loader.js:807:18) error: Caught by controller[0]: at Module.load (internal/modules/cjs/loader.js:653:32) error: Caught by controller[0]: at tryModuleLoad (internal/modules/cjs/loader.js:593:12) error: Caught by controller[0]: at Function.Module._load (internal/modules/cjs/loader.js:585:3) error: Caught by controller[0]: at Module.require (internal/modules/cjs/loader.js:692:17) error: Caught by controller[0]: at require (internal/modules/cjs/helpers.js:25:18) error: Caught by controller[0]: at bindings (/opt/iobroker/node_modules/bindings/bindings.js:81:44) error: Caught by controller[0]: at Object. (/opt/iobroker/node_modules/@serialport/bindings/lib/linux.js:1:36) error: Caught by controller[0]: at Module._compile (internal/modules/cjs/loader.js:778:30) error: Caught by controller[0]: at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10) error: host.HOME instance system.adapter.zigbee.0 terminated with code 1 ()
das war eigentlich mal behoben, ist jetzt aber wieder da.. hat wohl offenbar mit dem Serialport zu tun. Hast du da zufällig auch eine Idee?
Danke und beste Grüße
Sundance
-
-
@Glasfaser - das Serialport Problem konnte ich mit deinem ersten Vorschlag jetzt lösen. Allerdings ist das ursprüngliche problem, nämlich die iobroker.roomba Adapterinstallation leider immernoch ein Problem.. ich bekomme die gleiche Fehlermeldung:
pi@HOME:~ $ iobroker install iobroker.roomba NPM version: 6.9.0 npm install iobroker.roomba@1.0.0 --production --save --prefix "/opt/iobroker" (System call) node-pre-gyp WARN Using request for node-pre-gyp https download node-pre-gyp WARN Tried to download(404): https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.5.0/canvas-v2.5.0-node-v64-linux-glibc-arm.tar.gz node-pre-gyp WARN Pre-built binaries not found for canvas@2.5.0 and node@10.16.2 (node-v64 ABI, glibc) (falling back to source compile with node-gyp) ../src/bmp/BMPParser.cc: In member function 'void BMPParser::Parser::parse(uint8_t*, int, uint8_t*)': ../src/bmp/BMPParser.cc:193:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data > imgdOffset, "image data overlaps with another structure"); ~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/bmp/BMPParser.cc:208:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data + imgdSize > len, "not enough image data"); ~~~~~~~~~~~~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/CanvasRenderingContext2d.cc: In static member function 'static Nan::NAN_METHOD_RETURN_TYPE Context2d::DrawImage(Nan::NAN_METHOD_ARGS_TYPE)': ../src/CanvasRenderingContext2d.cc:1291:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_x = abs(transforms[1]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ ../src/CanvasRenderingContext2d.cc:1292:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_y = abs(transforms[2]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /home/iobroker/.node-gyp/10.16.2/include/node/v8.h:21, from /home/iobroker/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ make: *** [Release/obj.target/canvas/src/CanvasRenderingContext2d.o] Error 1 gyp ERR! build error gyp ERR! stack Error: `make` failed with exit code: 2 gyp ERR! stack at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23) gyp ERR! stack at ChildProcess.emit (events.js:198:13) gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:248:12) gyp ERR! System Linux 4.19.57-v7+ gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "build" "--fallback-to-build" "--module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node" "--module_name=canvas" "--module_path=/opt/iobroker/node_modules/canvas/build/Release" "--napi_version=4" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v64" gyp ERR! cwd /opt/iobroker/node_modules/canvas gyp ERR! node -v v10.16.2 gyp ERR! node-gyp -v v3.8.0 gyp ERR! not ok node-pre-gyp ERR! build error node-pre-gyp ERR! stack Error: Failed to execute '/usr/bin/node /usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js build --fallback-to-build --module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node --module_name=canvas --module_path=/opt/iobroker/node_modules/canvas/build/Release --napi_version=4 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v64' (1) node-pre-gyp ERR! stack at ChildProcess.<anonymous> (/opt/iobroker/node_modules/canvas/node_modules/node-pre-gyp/lib/util/compile.js:83:29) node-pre-gyp ERR! stack at ChildProcess.emit (events.js:198:13) node-pre-gyp ERR! stack at maybeClose (internal/child_process.js:982:16) node-pre-gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:259:5) node-pre-gyp ERR! System Linux 4.19.57-v7+ node-pre-gyp ERR! command "/usr/bin/node" "/opt/iobroker/node_modules/canvas/node_modules/.bin/node-pre-gyp" "install" "--fallback-to-build" node-pre-gyp ERR! cwd /opt/iobroker/node_modules/canvas node-pre-gyp ERR! node -v v10.16.2 node-pre-gyp ERR! node-pre-gyp -v v0.11.0 node-pre-gyp ERR! not ok npm WARN bl@0.7.0 requires a peer of stream-browserify@* but none is installed. You must install peer dependencies yourself. npm WARN optional SKIPPING OPTIONAL DEPENDENCY: osx-temperature-sensor@1.0.3 (node_modules/osx-temperature-sensor): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for osx-temperature-sensor@1.0.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"arm"}) npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! canvas@2.5.0 install: `node-pre-gyp install --fallback-to-build` npm ERR! Exit status 1 npm ERR! npm ERR! Failed at the canvas@2.5.0 install script. npm ERR! This is probably not a problem with npm. There is likely additional logging output above. npm ERR! A complete log of this run can be found in: npm ERR! /home/iobroker/.npm/_logs/2019-08-08T10_20_42_621Z-debug.log host.HOME Adapter directory "null" does not exists Cannot parse null/io-package.json:Error: ENOENT: no such file or directory, open 'null/io-package.json'
Kann ich die canvas Installation irgendwie manuell machen, damit sich der Installer nicht daran aufhängt? Oder ist die Wurzel des Problems woanders?
Danke nochmal für deine Hilfe..
Beste Grüße
sundance
-
Welche Versin von Js-controller hast du ?
-
@Glasfaser ich habe aktuell die 1.5.14 installiert.
-
-
@Glasfaser Ja, das hatte ich schon probiert vorhin.. ironischerweise kommen bei der Canvas installation gemäß dem Befehl aus der Installationsanleitung die gleichen Fehler (zumindest auf den ersten Blick):
root@HOME:~# cd /opt/iobroker root@HOME:/opt/iobroker# sudo npm install canvas --unsafe-perm=true > canvas@2.5.0 install /opt/iobroker/node_modules/canvas > node-pre-gyp install --fallback-to-build node-pre-gyp WARN Using request for node-pre-gyp https download node-pre-gyp WARN Tried to download(404): https://github.com/node-gfx/node-canvas-prebuilt/releases/download/v2.5.0/canvas-v2.5.0-node-v64-linux-glibc-arm.tar.gz node-pre-gyp WARN Pre-built binaries not found for canvas@2.5.0 and node@10.16.2 (node-v64 ABI, glibc) (falling back to source compile with node-gyp) make: Entering directory '/opt/iobroker/node_modules/canvas/build' SOLINK_MODULE(target) Release/obj.target/canvas-postbuild.node COPY Release/canvas-postbuild.node CXX(target) Release/obj.target/canvas/src/backend/Backend.o CXX(target) Release/obj.target/canvas/src/backend/ImageBackend.o CXX(target) Release/obj.target/canvas/src/backend/PdfBackend.o CXX(target) Release/obj.target/canvas/src/backend/SvgBackend.o CXX(target) Release/obj.target/canvas/src/bmp/BMPParser.o ../src/bmp/BMPParser.cc: In member function 'void BMPParser::Parser::parse(uint8_t*, int, uint8_t*)': ../src/bmp/BMPParser.cc:193:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data > imgdOffset, "image data overlaps with another structure"); ~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ ../src/bmp/BMPParser.cc:208:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] E(ptr - data + imgdSize > len, "not enough image data"); ~~~~~~~~~~~~~~~~~~~~~~^~~ ../src/bmp/BMPParser.cc:10:25: note: in definition of macro 'E' #define E(cond, msg) if(cond) return setErr(msg) ^~~~ CXX(target) Release/obj.target/canvas/src/Backends.o CXX(target) Release/obj.target/canvas/src/Canvas.o CXX(target) Release/obj.target/canvas/src/CanvasGradient.o CXX(target) Release/obj.target/canvas/src/CanvasPattern.o CXX(target) Release/obj.target/canvas/src/CanvasRenderingContext2d.o ../src/CanvasRenderingContext2d.cc: In static member function 'static Nan::NAN_METHOD_RETURN_TYPE Context2d::DrawImage(Nan::NAN_METHOD_ARGS_TYPE)': ../src/CanvasRenderingContext2d.cc:1291:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_x = abs(transforms[1]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /root/.node-gyp/10.16.2/include/node/v8.h:21, from /root/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /root/.node-gyp/10.16.2/include/node/v8.h:21, from /root/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ ../src/CanvasRenderingContext2d.cc:1292:45: error: call of overloaded 'abs(double&)' is ambiguous double current_scale_y = abs(transforms[2]); ^ In file included from /usr/include/c++/6/cstdlib:75:0, from /usr/include/c++/6/ext/string_conversions.h:41, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /root/.node-gyp/10.16.2/include/node/v8.h:21, from /root/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/stdlib.h:735:12: note: candidate: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^~~ In file included from /usr/include/c++/6/ext/string_conversions.h:41:0, from /usr/include/c++/6/bits/basic_string.h:5417, from /usr/include/c++/6/string:52, from /usr/include/c++/6/stdexcept:39, from /usr/include/c++/6/array:39, from /usr/include/c++/6/tuple:39, from /usr/include/c++/6/functional:55, from /usr/include/c++/6/memory:79, from /root/.node-gyp/10.16.2/include/node/v8.h:21, from /root/.node-gyp/10.16.2/include/node/node.h:63, from ../../nan/nan.h:54, from ../src/backend/Backend.h:6, from ../src/Canvas.h:5, from ../src/CanvasRenderingContext2d.h:6, from ../src/CanvasRenderingContext2d.cc:3: /usr/include/c++/6/cstdlib:180:3: note: candidate: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^~~ /usr/include/c++/6/cstdlib:172:3: note: candidate: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^~~ canvas.target.mk:138: recipe for target 'Release/obj.target/canvas/src/CanvasRenderingContext2d.o' failed make: *** [Release/obj.target/canvas/src/CanvasRenderingContext2d.o] Error 1 make: Leaving directory '/opt/iobroker/node_modules/canvas/build' gyp ERR! build error gyp ERR! stack Error: `make` failed with exit code: 2 gyp ERR! stack at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23) gyp ERR! stack at ChildProcess.emit (events.js:198:13) gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:248:12) gyp ERR! System Linux 4.19.57-v7+ gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "build" "--fallback-to-build" "--module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node" "--module_name=canvas" "--module_path=/opt/iobroker/node_modules/canvas/build/Release" "--napi_version=4" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v64" gyp ERR! cwd /opt/iobroker/node_modules/canvas gyp ERR! node -v v10.16.2 gyp ERR! node-gyp -v v3.8.0 gyp ERR! not ok node-pre-gyp ERR! build error node-pre-gyp ERR! stack Error: Failed to execute '/usr/bin/node /usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js build --fallback-to-build --module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node --module_name=canvas --module_path=/opt/iobroker/node_modules/canvas/build/Release --napi_version=4 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v64' (1) node-pre-gyp ERR! stack at ChildProcess.<anonymous> (/opt/iobroker/node_modules/canvas/node_modules/node-pre-gyp/lib/util/compile.js:83:29) node-pre-gyp ERR! stack at ChildProcess.emit (events.js:198:13) node-pre-gyp ERR! stack at maybeClose (internal/child_process.js:982:16) node-pre-gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:259:5) node-pre-gyp ERR! System Linux 4.19.57-v7+ node-pre-gyp ERR! command "/usr/bin/node" "/opt/iobroker/node_modules/canvas/node_modules/.bin/node-pre-gyp" "install" "--fallback-to-build" node-pre-gyp ERR! cwd /opt/iobroker/node_modules/canvas node-pre-gyp ERR! node -v v10.16.2 node-pre-gyp ERR! node-pre-gyp -v v0.11.0 node-pre-gyp ERR! not ok Failed to execute '/usr/bin/node /usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js build --fallback-to-build --module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node --module_name=canvas --module_path=/opt/iobroker/node_modules/canvas/build/Release --napi_version=4 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v64' (1) npm WARN bl@0.7.0 requires a peer of stream-browserify@* but none is installed. You must install peer dependencies yourself. npm WARN optional SKIPPING OPTIONAL DEPENDENCY: osx-temperature-sensor@1.0.3 (node_modules/osx-temperature-sensor): npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for osx-temperature-sensor@1.0.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"arm"}) npm ERR! code ELIFECYCLE npm ERR! errno 1 npm ERR! canvas@2.5.0 install: `node-pre-gyp install --fallback-to-build` npm ERR! Exit status 1 npm ERR! npm ERR! Failed at the canvas@2.5.0 install script. npm ERR! This is probably not a problem with npm. There is likely additional logging output above. npm ERR! A complete log of this run can be found in: npm ERR! /root/.npm/_logs/2019-08-08T11_38_50_244Z-debug.log
Allerdings steht in der Anleitung auch, dass man Canvas in den iobroker.roomba Ordner erstellen soll. Der existiert aber bei mir (noch) nicht, zumindest nicht in /opt/iobroker/node_modules/ - oder muss der woanders hin? Muss ich den vorher händisch erstellen, oder bringt das nix?
Sorry, ich bin lost
Danke für deine Geduld
Beste Grüße
Florian
-
Hast Du eingentlich schon mal wieder versucht roomba über die Konsole ganz normal zu installieren !?
-
@Glasfaser Ja, habe es grade nochmal probiert.. aber die Fehler bleiben leider bestehen. Die Canvas Installation schlägt nachwievor fehl.. manuell installiert bekomme ich sie auch nicht.
Ich habe grade nochmal die Verzeichnisberechtigungen "bereinigt", aber es hat leider nicht geholfen.
Hast du noch eine Idee? In meinem letzten Installations-log Scheint es auch Probleme zu geben, einfache Ordner zu erstellen:
gyp WARN EACCES user "root" does not have permission to access the dev dir "/root/.node-gyp/10.16.2" gyp WARN EACCES attempting to reinstall using temporary dev dir "/tmp/.node-gyp" gyp ERR! configure error gyp ERR! stack Error: EACCES: permission denied, mkdir '/opt/iobroker/node_modules/canvas/build' gyp ERR! System Linux 4.19.57-v7+ gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "configure" "--fallback-to-build" "--module=/opt/iobroker/node_modules/canvas/build/Release/canvas.node" "--module_name=canvas" "--module_path=/opt/iobroker/node_modules/canvas/build/Release" "--napi_version=4" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v64"
Es hilft nicht, diese Ordner händisch zu erstellen, oder?
-
@Sundance sagte in Adapterinstallation schlägt fehl - node-gyp Fehler:
EACCES: permission denied, mkdir '/opt/iobroker/node_modules/canvas/build'
einfach mal den Installations-Fixer anwenden: curl -sL https://iobroker.net/fix.sh | bash -