banner
libxcnya.so

libxcnya.so

Nothing...
telegram
twitter
github
email

Linux環境でNode.JS + Seleniumプロジェクトをデプロイする際の問題点

序文#

博主の Windows サーバーが期限切れになるため、以前 Windows マシンで実行していたものを Linux に移行する必要があります。そして、小学校 2 年生が書いたクソコードを実行しようとしたところ、実行できないことがわかりました。そして、今日のこの記事が生まれました。

インストール#

Google Chrome のインストール

wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
apt install ./google-chrome-stable_current_amd64.deb -y
rm google-chrome-stable_current_amd64.deb

(国内ではアクセスできないかもしれません)

google-chrome --version を入力してインストールが成功したか確認します。

1

バージョンが正常に表示されれば、インストールが成功しています。

NPM で npm install selenium-webdriver を実行すると、理論的には node プロジェクトで使用するための chromedriver が設定されます。先月作成した Hostloc ポイントを増やすための小さなプログラムを例に挙げましょう。その時、すべての設定が完了した後に実行するとエラーが発生しました。

2

root@NekoServer:~# node main.js

=.=

An error occurred: session not created: Chrome failed to start: exited normally.
  (session not created: DevToolsActivePort file doesn't exist)
  (The process started from chrome location /usr/bin/google-chrome is no longer running, so ChromeDriver is assuming that Chrome has crashed.)
/root/node_modules/selenium-webdriver/lib/error.js:524
    let err = new ctor(data.message)
              ^

SessionNotCreatedError: session not created: Chrome failed to start: exited normally.
  (session not created: DevToolsActivePort file doesn't exist)
  (The process started from chrome location /usr/bin/google-chrome is no longer running, so ChromeDriver is assuming that Chrome has crashed.)
    at Object.throwDecodedError (/root/node_modules/selenium-webdriver/lib/error.js:524:15)
    at parseHttpResponse (/root/node_modules/selenium-webdriver/lib/http.js:601:13)
    at Executor.execute (/root/node_modules/selenium-webdriver/lib/http.js:529:28)
    at process.processTicksAndRejections (node:internal/process/task_queues:95:5) {
  remoteStacktrace: '#0 0x5611b9842f83 <unknown>\n' +
    '#1 0x5611b94fbcf7 <unknown>\n' +
    '#2 0x5611b953360e <unknown>\n' +
    '#3 0x5611b953026e <unknown>\n' +
    '#4 0x5611b958080c <unknown>\n' +
    '#5 0x5611b9574e53 <unknown>\n' +
    '#6 0x5611b953cdd4 <unknown>\n' +
    '#7 0x5611b953e1de <unknown>\n' +
    '#8 0x5611b9807531 <unknown>\n' +
    '#9 0x5611b980b455 <unknown>\n' +
    '#10 0x5611b97f3f55 <unknown>\n' +
    '#11 0x5611b980c0ef <unknown>\n' +
    '#12 0x5611b97d799f <unknown>\n' +
    '#13 0x5611b9830008 <unknown>\n' +
    '#14 0x5611b98301d7 <unknown>\n' +
    '#15 0x5611b9842124 <unknown>\n' +
    '#16 0x7f9436572609 start_thread\n'
}

Node.js v18.17.1
root@NekoServer:~#

chromedriver の問題だと一時的に考え、手動で chromedriver をインストールしようとしました。

wget https://edgedl.me.gvt1.com/edgedl/chrome/chrome-for-testing/120.0.6099.109/linux64/chromedriver-linux64.zip
unzip chromedriver-linux64.zip
mv chromedriver-linux64/chromedriver /usr/bin/
rm -rf chromedriver-linux64
chromedriver --version

(最新の ChromeDriver はこちらで入手できます)

それからもう一度実行してみると、まだ同じ問題が発生していました。そして、私は google-chrome を実行してみました。なるほど、わかりました。

3

正常な状態では、root ユーザーでは実行できないため、--no-sandbox パラメータを追加する必要があります。

4

Options CV をプロジェクトから見つけて、--no-sandbox を追加してもう一度実行します。

5

すると、実行できるようになりました。
┐(´-`)┌

この記事はMix Spaceから xLog に同期されています。
元のリンクはhttps://blog.nekorua.com/posts/technology/103.htmlです。


読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。