简介
这是Hubot,由Github开发、开源的聊天机器人,湾区很多创业公司也陆续用Hubot来做运维自动化(比如部署代码、重启机器)、以及各种有用的没用的自动化(比如问今天公司的晚餐吃啥)。
类似Github内部严重依赖 Hubot,Slack 公司内的员工也依赖 Slack 做各种自动化;同样的,Atlassian 内部也严重依赖他们自己的聊天产品 hipchat(比如部署代码)。同一个聊天界面,既能与真人(同事)对话,也能当命令行窗口与机器对话。
聊天软件的 UI 很适合做 bot,很自然,你有时候分不清到底聊天窗口背后的是真人、还是机器人。似乎有种趋势,西方很多新闻媒体的内部员工,都是 Slack 重度用户,都做了很多内部的Slack Bot帮助运营 -- 比如New York Times、Quartz、Vox、Fusion、路透社、以及湾区日报(真不要脸~)。
湾区日报的运营也极大受益于 Slack 上的机器人:湾区日报的第一个“员工”:Slack/Hubot
有人说 There's an app for everything;其实,慢慢地,There's a slack bot for everything.
使用案例(均引自湾区日报)
Slack/Hubot 在湾区日报运营中起到的作用。
注意,这篇文章只讲 Slack/Hubot 的(简单)应用。具体怎么搭起来的,Google、StackOverflow以及Github
1. 发布新文章
问题
湾区日报分享的每篇文章都是有一定结构的:标题、简评、详细简评、原URL、文章图片、标签、归属于哪一期、适合移动设备的原文排版、slug等。完全可以手工录入,但很浪费时间,很容易厌倦。厌倦了后,我怎么会有动力继续把湾区日报一期一期地做下去呢?
解决方案
跟机器人对话:wq post $URL
然后 Slack 连上 Hubot;Hubot 里我自定义的脚本(CoffeeScript写的)跟我后台的 API(Python/Django写的)通信,把每篇文章大部分结构化的数据录入数据库中。
机器人帮我做了大部分文章录入的工作后,我再手动地拟个中文标题、写几句话的简评。
Slack 的 iOS App 做得不错,有时候整期的湾区日报其实是我从手机发出来的:比如老婆开车、我坐在副驾驶的时候,比如在餐厅吃饭等上菜的时候。
2. 部署网站代码
问题
如何快速迭代、快速地部署代码到服务器上?尽管湾区日报是小本经营,只是一个“个人博客”性质的 side project,我也希望有一定规范:用git版本控制、自己进行code review (有点左右互搏的意思)、可重复地快速地部署代码 、一键瞬间回退到前一个版本(如果上线后发现有严重bug)、简单的监控系统、收集重要指标等 ,都没什么技术含量,就是一个套路而已。
解决方案
跟机器人对话:wq deploy
然后 Slack 连上 Hubot;Hubot 执行我写的脚本 git clone 一份最新代码、安装各种 dependency、升级数据库的 schema (如果有的话)、重启服务器等。
由于部署代码是很轻松愉快的、可重复性极高的过程,所以我可以利用零散时间随便改点代码(改个文字描述、加个按钮、改个颜色)、立刻上线。
4. 查看各项指标
有一些我比较关心的指标,比如有多少iOS App用户打开了 push notification。那我就问机器人“wq metrics”,然后 Slack 给我返回一些数字:
5. 通知我湾区日报 iOS App 有用户了
前面几个用途都是 “pull” 的模式,我得问,它才回答。接下来几个功能是 “push” 的模式,有新事件,就通知我。
推送的功能我就没用Hubot了,直接在后台代码连Slack 的 API。基本套路就是,一有什么重要事件发生,就 publish 一个celerytask 连上 Slack API,然后 Slack 机器人就发消息给我。比如一有湾区日报 iOS App的用户允许使用推送功能,Slack 就发个消息给我:
其中,“930 push users (vs 928)” 的意思是,目前累计共有930个用户打开了Push Notification,对比昨天的928个用户(增长了 930–928=2 个)。我发现 Apple Watch 的主要用途就是看这种通知。。
等等...
安装
著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:陈湛翀
链接:http://www.zhihu.com/question/20077206/answer/13902587
来源:知乎
一般在自己的Mac 下用shell 测试,在线上的Linux 连接Campfire 。Hubot 由node.js 的CoffeeScript 写的,所以要装node.js & CoffeeScript 。
获取源码方式一样,去https://github.com/github/hubot下载源码包,或者clone readonly 的,再或者fork 一份。我建议fork 。
Mac 下,我用的是homebrew 作为包管理系统
1)安装node.js
brew install node.js
2)安装npm — node package manager
curlhttp://npmjs.org/install.sh| sh
3)进入hubot ,用npm 安装相关依赖
npm install
4)shell 测试一下
export PATH=”node_modules/.bin:$PATH”
./bin/hubot
在这个命令行提示符下
Hubot>
输入 hubot pug me 看看效果,如果返回一个包含图片url 的json 就成功了
我的Linux 是Debian
1)安装相关依赖包
# apt-get install build-essential libssl-dev git-core redis-server libexpat1-dev
2)安装node.js
# wgethttp://nodejs.org/dist/v0.6.9/node-v0.6.9.tar.gz
# tar xf node-v0.6.9.tar.gz -C /usr/local/src && cd /usr/local/src/node-v0.6.9
# ./configure && make && make install
3)进入hubot ,用npm 安装相关依赖
npm install
4)编写用于Campfire 的启动脚本
# vim run
--------------------------
#!/bin/bash
##
## Wrapper for Hubot startup
##
HUBOT="/opt/hubot/bin/hubot"
NAME="marvin"
ADAPTER="campfire"
HUBOT_CAMPFIRE_TOKEN="marvin's api token" HUBOT_CAMPFIRE_ACCOUNT="subdomain"
HUBOT_CAMPFIRE_ROOMS="roomid1, roomid2"
OPTS="--name ${NAME} --adapter ${ADAPTER}"
export HUBOT_CAMPFIRE_TOKEN
export HUBOT_CAMPFIRE_ACCOUNT
export HUBOT_CAMPFIRE_ROOMS
until ${HUBOT} ${OPTS};
do echo "Hubot crashed with exit code $?. Restarting." >&2
sleep 5
done
---------------------------
这里说明一下,申请一个Campfire 账号给hubot 使用,需要它的API token ,和它需要进入的room 的id。
NAME 是机器人的名字
HUBOT_CAMPFIRE_TOKEN 是申请的那个账号的api token
HUBOT_CAMPFIRE_ACCOUNT 这里是你的http://xxx.campfirenow.com的xxx ,而不是hubot 的账号
HUBOT_CAMPFIRE_ROOM 聊天室的id ,用逗号分隔
chmod +x run
5)连接Campfire 测试
在screen 或者 tmux 中挂着 ./run
如果一切都正确,你会见到hubot 已经登陆到那些 HUBOT_CAMPFIRE_ROOM 了
输入命令
hubot pug me
测试一下,正常的话,hubot 会发一张很可爱的狗狗的图片
作者:fohnwind
但是自己在安装的时候发现./bin/hubot一直无法执行,后来发现需要redis支持,采取官网yo hubot的安装方法,开启redis服务,然后执行就可以了
网友评论