记一次 wechaty running on docker 之旅

开始

当被告知要结合wechaty做一个自动发消息的微信机器人时,我真的有点懵。看了一下wechaty的文档,推荐通过docker运行。我当时的内心表情就是what? 什么鬼?前端的东西已经让我应接不暇,这些偏后台运维的就一点都不懂了。但能怎么办呢,还带着一个实习生一起做,老大安排的任务,跪着也得完成啊!
于是乎,咬着牙硬着头皮开始看各种文档,在本地把脚本运行起来,暴露http接口给我们的管理后台用。

环境

1、docker for mac

官网下载docker客户端就行下载地址
安装后,直接可以在Mac终端docker info,可以看到docker信息,就成功了。

2、npm和node

为了本地开发方便,不多说了,前端必备环境。

运行例子

1、在本地创建一个文件夹myWechaty
2、npm init创建package.json
3、npm install --save qrcode-termial
4、创建mybot.js 官方6行代码

const { Wechaty } = require('wechaty') // import { Wechaty } from 'wechaty'

Wechaty.instance() // Singleton
.on('scan', (url, code) => console.log(`Scan QR Code to login: ${code}\n${url}`))
.on('login',       user => console.log(`User ${user} logined`))
.on('message',  message => console.log(`Message: ${message}`))
.start()

5、修改一下scan事件,引入qrcode-terminal,方便直接在控制台显示二维码

const { Wechaty } = require('wechaty') // import { Wechaty } from 'wechaty'
const QrcodeTerminal = require('qrcode-terminal');

Wechaty.instance() // Singleton
.on('scan', (url, code) => {
  console.log(`Scan QR Code to login: ${code}\n${url}`)
  if (!(/201|200/).test(String(code))) {
    const loginUrl = url.replace(/\/qrcode\//, '/l/')
    QrcodeTerminal.generate(loginUrl)
  }
})
.on('login',        user => console.log(`User ${user} logined`))
.on('message',   message => console.log(`Message: ${message}`))
.start()

6、在终端进入myWechaty文件夹,并运行docker run -ti --name=mybot --rm --volume="$(pwd)":/bot zixia/wechaty mybot.js

  • 命令中的 zixia/wechaty是wechaty包装好的docker镜像,mybot.js是运行于这个镜像之上的一段脚本,这个镜像运行依赖的环境可以通过docker hub 上wechaty的dockerfile看到:
    依赖了一系列命令,有熟知bash, curl, git, sudo, vim等等,还下载了nodejs,还运行了npm install,也就是说,这个镜像依赖的环境也是我们需要的,我们无需再获取。
  • 关于docker run 命令解释:
    a、-ti 可命令交互
    b、--name=mybot 创建容器的名称是mybot
    c、--rm 退出命令后,自动删除容器
    d、--volume="$(pwd)":/bot 在镜像外层目录上挂载一个bot文件夹,里面存放的是myWechaty里的内容。
  • 新开终端,docker ps 列出当前所有容器,可以看到有我们的mybot

7、终端显示二维码,用微信扫码即可。这样,就可以在终端查看到微信消息了。
了解了以上之后,我们就可以在mybot.js中开发我们需要的功能了。

mybot.js中暴露接口

难以入手的问题
在写接口之前,我在想怎么在本地访问呢?现在的环境node已经有了,wechaty本身也有服务,我又该怎么做呢?这个问题困扰了我很久,总之,还是因为对docker环境不了解。
几番周折查找,原来就在docker run命令里面设置一个参数就能解决。
-p 8888:8888 : 将虚拟机器(即mybot容器)的地址端口映射到我们本地端口。
在myWechaty mybot.js中,引入:

const express = require('express');
const app = express();
const bodyParser = require('body-parser');

再对body解析:

app.use(bodyParser.json({limit: '20mb'}));//设置前端post提交最大内容
app.use(bodyParser.urlencoded({limit: '20mb', extended: false}));
app.use(bodyParser.text());

再添加一段监听日志代码:

app.get('/', function (req, res) {
  res.send('Hello World!');
});

app.listen(8888, () => {
  console.log('Example app listening on port 3000!');
});

终端:
1、npm install --save express body-parser
2、docker run -ti --name=mybot --rm --volume="$(pwd)":/bot -p 8888:8888 zixia/wechaty mybot.js

看到监听日志打出来了,也有微信消息。 在浏览器中访问localhost:8888, Hello World!
到这里了,暴露接口不就是顺手拈来的事情了么!

后续

到此,基本上开发就是这样了,跟平常做node开发一样。最后,就是看是否需要将开发的内容打包成镜像发布,还是直接就这样运行就行了。打包镜像的话,就是注意Dockerfile的配置,进行docker build。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,602评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,442评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,878评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,306评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,330评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,071评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,382评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,006评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,512评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,965评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,094评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,732评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,283评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,286评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,512评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,536评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,828评论 2 345

推荐阅读更多精彩内容

  • 一、Docker 简介 Docker 两个主要部件:Docker: 开源的容器虚拟化平台Docker Hub: 用...
    R_X阅读 4,379评论 0 27
  • Docker简介Docker是一个由GO语言写的程序运行的“容器”; 目前云服务的基石是操作系统级别的隔离,在同一...
    gakiww阅读 534评论 0 0
  • Docker基础资料 安装docker $ sudo apt-get install docker.io 查看本地...
    Sherry凤阅读 458评论 0 0
  • 查看系统信息 帮助: 我们可以看到运行结果如下图所示。如果之前有学习过 docker 相关知识的同学,可能会发现一...
    夸克星阅读 1,178评论 0 0
  • 月光穿过身体 在去往远方的路上 遗下一叠浩浩荡荡的影子 只有一个不低头看路的孩子 搭上了月亮的风车 星星们窥探出他...
    阿什塔尔阅读 372评论 3 4