linux 下 使用 puppeteer

未结帖
0 687
ajian admin_jim 2021-12-23
悬赏:5飞吻

记一次linux上使用Puppeteerjs

赫鲁晓夫的玉米棒子

字数 436阅读 433

最近在用Puppeteerjs时,在Linux下运行遇到不少麻烦,找了不少资料后,已经解决,现在记录一下。

解决方法:使用Doker!——因为我也不是第一个遇到这个问题的,已经有人搭建好了一个可以运行puppeteer的环境。

举个🌰

如果没有Doker,先安装Docker。

在一个合适的地方,创建项目。

mkdir puppeteer-demo
cd puppeteer-demo

创建package.json,里肯定得有puppeteer

{
  "name": "puppeteer-demo",
  "version": "1.0.0",
  "main": "index.js",
  "dependencies": {
    "puppeteer": "^5.4.0",
  }}

再创建一个index.js,使用一下官方的例子。

const puppeteer = require('puppeteer');(async () => {
 // linux环境必须要有下面俩个参数 noSandbox 、disableSetuidSandbox 
  const browser = await puppeteer.launch({
      args: [
          '--no-sandbox',
          '--disable-setuid-sandbox',
      ]
  });
  const page = await browser.newPage();
  await page.goto('https://www.baidu.com');
  await page.screenshot({path: 'example.png'});

  await browser.close();})();

创建Dockerfile文件,注意没有后缀的。

# 这个就是别人搭好的环境
FROM buildkite/puppeteer
WORKDIR /app
COPY . /app

RUN npm install -g yarn
RUN yarn install

创建Doker镜像

# 这个puppeteer-demo按你自己名字来
docker build --tag=puppeteer-demo .

启动一个实例

docker run -it puppeteer-demo bash

# 然后你会发现你到了一个新的命令行里
node index.js

# 等待一会儿
ls

# 发现多了一个 example.png的文件

到此为止,就已经完美运行了一次puppeteerjs访问百度并接了个图保存了下来。


因为在实际项目中,考虑到经常更新和需要访问项目提供的接口,所以在启动实例的时候,加了额外参数。
docker run -it -v /opt/puppeteer/xx-puppeteer:/app -p 3013:3012 xx-ptr /bin/bash

  • -v 是挂载,宿主机目录:镜像内目标路径,当我更新/opt/puppeteer/xx-puppeteer目录下的文件时,镜像内的/app目录下也会同步更新。

  • -p是端口映射,本机端口:容器端口,当我访问我 服务器ip:3013的时候,就会访问到容器里的3012端口。

Docker新手,如有错误,还请指出,欢迎批评。



热忱回答0


最近热帖

近期热议

  1. javascript——prototype与__proto 9
  2. Mysql 中出现的Data truncated for column 3
  3. 在nginx中使用x-sendfile的解决方案 3
  4. 高版本jQuery面插件实现Ajax上传图片 1
  5. Thinkphp Socket.class.php 类的使用 1
  6. 使用ionic3创建第一个App 0
  7. ios-oc html5 0
  8. nginx.conf 0
  9. 基于ionic3.4.0的项目搭建 0
  10. php 缩略图 0