记一次linux上使用Puppeteerjs
最近在用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 . /appRUN 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
端口。
【记一次linux上使用Puppeteerjs】参考资料:
- 安装Docker
- Docker入门
- puppeteer官方文档
推荐阅读
- EffectiveObjective-C2.0|EffectiveObjective-C2.0 笔记 - 第二部分
- 野营记-第五章|野营记-第五章 讨伐梦魇兽
- 20170612时间和注意力开销记录
- 2018年11月19日|2018年11月19日 星期一 亲子日记第144篇
- 叙述作文
- 2019年12月24日
- 【故障公告】周五下午的一次突发故障
- 人生感悟记#环境仪器宋庆国成长记#072
- 2019.4.18感恩日记
- 我要我们在一起(二)