Vibiumとの死闘と敗北:Linux VPS環境でのブラウザ自動化の罠
最新の自動化ライブラリである「Vibium」を使い、ポイ活を自動化するツールを作成した。開発機(Windows / Node.js)では完璧に動作したが、いざ本番環境であるLinux VPS(XServer VPS / Ubuntu 24.04 / Bunでビルド)へデプロイし、実行した際に想定外の「壁」に阻まれて敗北した。
発生した問題
Section titled “発生した問題”ビルドしたバイナリをLinux環境で実行した際、まず直面したのは「エンジン自体が見つからない」という初歩的かつ高い壁だった。
これに対し、エンジンを別途インストールしてパスを通すなどの対応を行った結果、次に以下のエラーへと進展(「死闘」が本格化)した。
試行錯誤のプロセス
Section titled “試行錯誤のプロセス”1. バイナリの欠如
Section titled “1. バイナリの欠如”Vibiumのエンジン自体は実行ファイルに含まれていなかった。そのため、実行環境にVibiumエンジンをインストールし、パスを明示的に指定する必要があった。
- 対応: 以下のコマンドをVPS側で実行。エンジンをインストールし、環境変数でその場所を教えることで起動を試みた。
# エンジン(バイナリ)のインストールnpm install @vibium/linux-x64
# バイナリのパスを環境変数にセットexport VIBIUM_BIN_PATH=$(pwd)/node_modules/@vibium/linux-x64/bin/vibium2. Chromeの依存ライブラリ不足
Section titled “2. Chromeの依存ライブラリ不足”エンジンのパスを通したことで「バイナリが見つからない」エラーは消えたが、次に「Browser crashed(ブラウザがクラッシュ)」という抽象的なエラーに変化した。
この原因を特定するためには、まず「OSがChromeを動かすための最低限のパーツ(共有ライブラリ)を備えているか」を検証し、問題を切り分ける必要があった。Ubuntuの最小構成サーバでは、GUI関連のライブラリが標準で入っていないことが多いためである。
- 対応: 以下のパッケージを網羅的にインストール。これにより、OSレベルでの「欠損」を原因から除外した。
sudo apt install -y libnss3 libatk1.0-0t64 libatk-bridge2.0-0t64 \ libcups2t64 libdrm2 libxkbcommon0 libxcomposite1 \ libxdamage1 libxrandr2 libgbm1 libasound2t64 \ libpango-1.0-0 libcairo2- 結果: エラー内容は変わらず「Browser crashed」のままだった。 しかし、これにより「ライブラリ(ファイル)がないから起動できない」という線は消え、問題は「起動はしようとしているが、OSから拒否されている」という次のレイヤーへ絞り込まれた。
3. Sandboxの壁(決定打)
Section titled “3. Sandboxの壁(決定打)” ライブラリ不足を解消してもクラッシュが続く。この状況から、Linuxサーバー特有の「Sandbox(隔離機能)による実行制限」が真犯人であると推測した。root権限や限定的な環境では、--no-sandbox フラグを明示的に付けない限り、Chromeはセキュリティ保護のために即座にプロセスを終了する仕様だからである。
- ライブラリの制約:
browser.start({ args: [...] })で引数を渡しても、Vibiumエンジン側で無視される仕様。 - ラッパースクリプト戦略:
ライブラリ側が起動引数を透過させないなら、「ブラウザそのものを偽装する」というアプローチを取った。具体的には、以下の内容で
google-chromeという名前のシェルスクリプトを自作した。
#!/bin/bash # 本物のChromeバイナリを呼び出す際に、強制的にフラグを差し込む exec /usr/bin/google-chrome --no-sandbox --disable-setuid-sandbox "$@"このスクリプトに実行権限を与え、環境変数 PATH の先頭に配置することで、Vibiumに「偽のChrome」を本物だと思わせて掴ませ、無理やり設定を注入することを狙った。
- PATHの操作の結果:
シェル上で
google-chrome --versionを叩けば自作スクリプトが呼ばれ、偽装は成功している状態になったが、Vibiumからの起動では依然としてクラッシュが続いた。Vibiumのエンジンが内部でPATHを無視してバイナリを直接絶対パスで探索しているか、シンボリックリンクを解決して実体の実行ファイルを特定している可能性もあり、この「中間者攻撃」的な戦略も虚しく回避されてしまった。
4. ブラウザ専用版の導入
Section titled “4. ブラウザ専用版の導入”ラッパースクリプトすら回避される状況に、もはや現状のOS環境にあるChrome(google-chrome-stable)を使うこと自体に限界があると考えた。そこで、Vibiumエンジンそのものの能力を改めて探るため、vibium --help を実行し、利用可能なオプションを精査した。
-
新たな発見: ヘルプ画面を確認したところ、Vibium自身に
installというサブコマンドが存在し、「Chrome for Testing(自動テスト専用のブラウザ)」を独自にダウンロード・管理する機能を備えていることが判明した。「専用のブラウザをVibium自身の管理下で動かせば、権限や設定の問題を内部的に解決してくれるのではないか」という最後の望みをかけ、vibium installを実行した。 -
結果: 再実行してみたところ、今までの「即死」とは異なり、数秒間はエラーが出ずにプロセスが存続した。期待が高まったが、結局は「Browser crashed with exit code 1」に終わった。
OS標準のブラウザでも、Vibium純正(?)のブラウザでも、VPS環境(Sandbox制限)という巨大な壁の前では同様の末路を辿ることを痛感し、ここでVibiumによる解決は不可能であるとの確信に至った。
Puppeteerへの切り替え
Section titled “Puppeteerへの切り替え”Vibiumはモダンで使いやすいAPIを備えているが、「ブラウザへの起動引数を透明に透過させる」という、サーバーサイド環境において極めて重要な制御がエンジンの仕様上困難であった。
もともとPuppeteerで実装していたので、そちらに戻すことにした。Web上にはさまざまな情報が転がっているので、問題があっても対処しやすいためである。
他の記事を探す