在阿里函数计算中,我在nodejs16环境中添加了一个自定义层,层里面的内容是chrome,当我尝试运行该chrome是,提示没有权限执行 Failed to launch the browser process! spawn /opt/chrome-linux-118_0_5993_70/chrome EACCES,我应该如何添加权限呢?
在阿里函数计算中,我在nodejs16环境中添加了一个自定义层,层里面的内容是chrome之后咋搞?[阿里云Serverless]
「点点赞赏,手留余香」
还没有人赞赏,快来当第一个赞赏的人吧!
代码写个 hello world 然后登录到实例里面 cd 到 /opt 目录下直接起一下试试 看看报什么错。1. 用容器镜像来写业务。
在阿里函数计算中,您可以尝试以下方法来添加权限:
chmod
命令来更改文件权限,例如:/usr/local/bin
:然后,您需要确保在您的自定义层中引用的是这个新的可执行文件路径。例如,如果您在
package.json
文件中指定了chrome
作为启动命令,您需要将其更改为:--no-sandbox
选项,以允许Chrome在无沙箱模式下运行。例如:请注意,这些方法可能需要根据您的具体环境和需求进行调整。希望这对您有所帮助!
由于安全性考虑,自定义层默认不允许直接执行,以避免恶意攻击。要使用 Chrome,可以采取以下措施:
在阿里云函数计算中,当你在Node.js 16环境中添加了一个自定义层并试图运行Chrome时,出现”Failed to launch the browser process! spawn /opt/chrome-linux-118_0_5993_70/chrome EACCES”的错误,这是因为Chrome的二进制文件没有执行权限。
你可以使用以下命令来为Chrome的二进制文件添加执行权限:
这条命令会为"/opt/chrome-linux-118_0_5993_70/chrome"这个文件添加执行权限。
但是,这种方法只能解决一次的问题。每次重启函数实例后,Chrome的二进制文件的执行权限都会丢失,因为函数计算会在每次重启函数实例时重新下载并解压Chrome的二进制文件。
为了解决这个问题,你可以使用阿里云函数计算的"持久化存储"功能。你可以将Chrome的二进制文件保存在持久化存储中,然后在每次函数实例启动时,从持久化存储中读取并运行Chrome的二进制文件。这样可以确保Chrome的二进制文件始终保持执行权限。
在Linux环境中运行Chrome需要具有一定的权限。为了使Chrome可以在自定义层中运行,需要赋予它足够的权限。为此,可以通过以下步骤来增加自定义层中Chrome的权限: