搞事 | 5分钟部署一个机器人帮你告别 “信息焦虑”

  • 2019 年 11 月 12 日
  • 笔记

上次搞事用服务器搭建了一套监控系统,包含 Bug 追踪、数据监控以及可视化仪表盘等功能。

感兴趣的可以点击下面蓝字学习一波~

搞事 | 这个周末我对落灰的云服务器做了什么?

这次搞事是想部署一个 Telegram Bot ,方便订阅一些不错的网站和技术博客。

前奏

如果想跟着我做,你需要准备下面这些东西。

•类似 SSH shell / Xshell 的 ssh 工具•一台能够自由上网的手机•一台云服务器

申请 Telegram Bot

Telegram Bot 有个不错的地方是可以直接在手机上完成配置和订阅,方便快捷。

现在在 Telegram 上搜索 @BotFather,之后在根据提示,输入/star

接下来根据提示创建一个新的机器人 /newbot,根据提示给你的机器人起一个名字,我这里用的是 xianyu_tobot, 起好名字之后会返回一个 HTTP API token 这个需要记录下来,之后部署需要用到。

到这里你就拥有了属于你自己的一个 Telegram Bot 了。

Telegram Bot 的简单配置

我们可以通过 /mybot命令管理属于你的 Telegram Bot

我们需要简单设置一下 Telegram Bot ,点击 Edit BotEdit Commands 根据下面的格式输入指令

rss       - 显示当前订阅的 RSS 列表,加 raw 参数显示链接sub       - 订阅一个 RSS: /sub http://example.com/feed.xmlunsub     - 退订一个 RSS: /unsub http://example.com/feed.xmlunsubthis - 使用此命令回复想要退订的 RSS 消息即可退订, 不支持 Channel# export    - 导出为 OPML 特此提醒:这个功能在我们下面主讲的项目中支持的不是很好

部署 RssBot

现在网上比较流行的两种搭建方式分别是参考下面两个项目的:

一个是基于 Rust 构建的 rssbot

https://github.com/iovxw/rssbot

还有就是基于 Go 语言构建的 flowerss-bot

https://github.com/indes/flowerss-bot

基于方便新手的便利性,个人强烈推荐后者。不仅使用方便,而且支持 Telegram 内预览。

这时候就需要掏出刚刚买好的华为服务器,系统环境为 Centos 7。

先使用源码的方式编译部署。

使用源码部署 flowerss-bot

首先需要配置 go 语言安装环境

wget https://dl.google.com/go/go1.12.6.linux-amd64.tar.gztar -C /usr/local -xzf go1.12.6.linux-amd64.tar.gzecho 'export PATH=$PATH:/usr/local/go/bin' >>/etc/profilesource /etc/profileyum install make gcc git -y

接着拉取项目源码并编译

git clone https://github.com/indes/flowerss-botcd flowerss-botmake build# 配置项目参数vim config.yml

config.yml 中填入的内容

# 这个是之前申请的 bot token# 填入的参数是包含 冒号前面的一串数字的bot_token: XXX#多个telegraph_token可采用数组格式:# telegraph_token:#  - token_1#  - token_2  # 建议订阅人数多的 bot 一定要申请多一些!不然没多久就访问频繁了# 申请地址# curl https://api.telegra.ph/createAccount?short_name=flowerss&author_name=flowerss&author_url=https://github.com/indes/flowerss-bot# 选填项telegraph_token: xxxxpreview_text: 0socks5: 127.0.0.1:1080  # 机器配置不高的朋友这个配置项可以设置为20update_interval: 10error_threshold: 100mysql:  host: 127.0.0.1  port: 3306  user: user  password: pwd  database: flowersssqlite:  path: ./data.db

配置项说明

你以为到这里就结束了吗?

Tip

构建项目时会出现下面的提示:

package google.golang.org/grpc: unrecognized import path "google.golang.org/grpc"(https fetch: Get https://google.golang.org/grpc?go-get=1: dial tcp 216.239.37.1:443: i/o timeout)

这是因为这个代码已经转移到 github 上面了,但是代码里面的包依赖还是没有修改,还是 google.golang.org 。

所以不能使用 go get 的方式安装,我们需要使用下面这种方式:

# 按照错误提示创建响应的文件夹mkdir -p $GOPATH/src/golang.org/x/# 从 git 上将源码同步下来git clone https://github.com/golang/net.git $GOPATH/src/golang.org/x/net# 使用源码安装缺失的包go install net

上面这种方式部署繁琐不少,但是没关系,项目作者贴心的为我们准备了 Docker 部署的方式,只需 5 秒就可以一键部署了。

Docker 一键式部署

使用 Docker 一键部署的前提是先配置好 Docker 运行环境,没有玩过的盆友可以跟着咸鱼一步步往下做。

使用下面的命令在服务器上安装 Docker

# 在Linux操作系统下,可以使用如下命令快速安装Dockercurl -fsSL get.docker.com -o get-docker.shsh get-docker.sh  # 安装完成后,使用下面的命令验证是否安装成功, 安装成功输入下面的命令会输出一堆版本信息docker version

安装好 Docker 后就需要配置 DockerHub 镜像加速源地址,否则拉取 DockerHub 镜像的速度会让你怀疑人生。