【问题标题】:How can i change node version for a systemctl service如何更改 systemctl 服务的节点版本
【发布时间】:2022-01-28 11:13:01
【问题描述】:

我创建了一个 systectl 服务来运行节点应用程序,但应用程序使用 discordJs(npm 包),它仅适用于节点 v16.* 及更高版本(我猜)。

现在的问题是,这个服务正在使用节点 v10.21.0,这就是为什么我的应用程序一启动就崩溃了!

我找不到更改此服务的节点版本的方法。


系统节点版本为v16.13.1

animeland.service 配置:

[Unit]
Description=bot for animeland server
Wants=network-online.target
After=network.target

[Service]
Type=simple
User=pi
WorkingDirectory=/home/pi/bots/chika-bot/
ExecStart=npm start

[Install]
WantedBy=multi-user.target

启动后的服务状态:

pi@rootz491:~ $ sudo systemctl start animeland.service 
pi@rootz491:~ $ sudo systemctl status animeland.service 
● animeland.service - bot for animeland server
   Loaded: loaded (/etc/systemd/system/animeland.service; disabled; vendor preset: enabled)
   Active: failed (Result: exit-code) since Fri 2022-01-28 16:44:42 IST; 5s ago
  Process: 2195 ExecStart=/usr/bin/npm start (code=exited, status=1/FAILURE)
 Main PID: 2195 (code=exited, status=1/FAILURE)

Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! errno 1
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! chika@1.0.0 start: `node index.js`
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! Exit status 1
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR!
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! Failed at the chika@1.0.0 start script.
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! This is probably not a problem with npm. There is likely additional l
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR! A complete log of this run can be found in:
Jan 28 16:44:42 rootz491 npm[2195]: npm ERR!     /home/pi/.npm/_logs/2022-01-28T11_14_42_719Z-debug.log
Jan 28 16:44:42 rootz491 systemd[1]: animeland.service: Main process exited, code=exited, status=1/FAILURE
Jan 28 16:44:42 rootz491 systemd[1]: animeland.service: Failed with result 'exit-code'.

结论:

如果你们知道如何更改 systemctl 服务的节点版本,请知道这将是一个很大的帮助!

谢谢

【问题讨论】:

标签: node.js linux service automation systemd


【解决方案1】:

所以我得到了我自己问题的答案?

阅读这个 github 问题线程: https://github.com/nodenv/nodenv/issues/117

然后来到这里: https://github.com/nodenv/nodenv/wiki/Use-with-systemd


如果你还没有弄清楚,

获取节点的位置(您要使用的)

pi@rootz491:~ $ whereis node
node: /usr/bin/node /usr/local/bin/node /home/pi/.nvm/versions/node/v16.13.1/bin/node /usr/share/man/man1/node.1.gz

所以我要使用的节点位于/home/pi/.nvm/versions/node/v16.13.1/bin/node

然后我将此添加到节点应用程序的 package.json 中:

  ...,
  "main": "index.js",
  "scripts": {
    "systemd": "/home/pi/.nvm/versions/node/v16.13.1/bin/node index.js",
    "start": "node index.js",
    "dev": "nodemon index.js",
  },
  "keywords": [],
  ...

现在终于更新服务配置:

[Unit]
Description=bots for animeland server
Wants=network-online.target
After=network.target

[Service]
Type=simple
User=pi
WorkingDirectory=/home/pi/bots/chika-bot/
ExecStart=npm run systemd

[Install]
WantedBy=multi-user.target

这里npm run systemd 将使用我想要的特定节点版本(v16.13.1)运行应用程序?

【讨论】:

    猜你喜欢
    • 2018-06-22
    • 1970-01-01
    • 2023-03-09
    • 2019-05-16
    • 1970-01-01
    • 2021-02-28
    • 1970-01-01
    • 2020-08-12
    • 2022-06-15
    相关资源
    最近更新 更多