Linux环境下部署NonebotQQ机器人
准备
- Linux服务器(centos7.8)
- Python 3.8(安装教程百度,此文不赘述)
- Golang(可以没有,下文会安装)
- go-cqhttp
第一步-下载并初始化go-cqhttp
连接我们的Linux服务器,到https://github.com/Mrs4s/go-cqhttp/releases找到适用于我们自己服务器的包,既64位的Linux系统对应的压缩包名为go-cqhttp_linux_amd64.tar.gz
,好,在服务器端执行如下命令
wget https://github.com/Mrs4s/go-cqhttp/releases/download/v1.0.0-beta7-fix2/go-cqhttp_linux_amd64.tar.gz
这个过程可能会很漫长,因为是请求国外下载,您也可以自己本地下载完再上传至服务器
下载完成后,可以看到根目录下有go-cqhttp_linux_amd64.tar.gz
这个我那件,接下来我们执行如下命令来解压
tar -xzvf go-cqhttp_linux_amd64.tar.gz
解压完成后,我们需要为服务器安装一下GO语言,因为go-cqhttp是基于Golang的,安装GO语言:
sudo yum install golang
安装完成后执行下面的命令验证安装是否成功
go version
提示版本号,如go version go1.15.14 linux/amd64
既安装成功。
接下来还是在 Home 目录(例如 ~/workspace)创建一个 workspace 目录并定义 GOPATH 环境变量指向该目录,这个目录将被 Go 工具用于保存和编辑二进制文件。依次执行如下命令:
mkdir ~/workspace
echo 'export GOPATH="$HOME/workspace"' >> ~/.bashrc
source ~/.bashrc
好,接下来我们初始化go-cqhttp
,在服务器执行
./go-cqhttp
提示如下内容
[root@np1NlDVbG1 ~]# ./go-cqhttp
未找到配置文件,正在为您生成配置文件中!
请选择你需要的通信方式:
> 1: HTTP通信
> 2: 正向 Websocket 通信
> 3: 反向 Websocket 通信
> 4: pprof 性能分析服务器
> 5: 云函数服务
请输入你需要的编号,可输入多个,同一编号也可输入多个(如: 233)
您的选择是:
我们选择3: 反向 Websocket 通信
,之后会提示我们默认配置文件已生成,请修改 config.yml 后重新启动!
接下来我们修改其config.yml
,执行:
[root@np1NlDVbG1 ~]# vi config.yml
# go-cqhttp 默认配置文件
account: # 账号相关
uin: 703382225 # 你自己机器人的QQ账号
password: '' # 密码为空时使用扫码登录
encrypt: false # 是否开启密码加密
status: 0 # 在线状态 请参考 https://docs.go-cqhttp.org/guide/config.html#在线状态
relogin: # 重连设置
delay: 3 # 首次重连延迟, 单位秒
interval: 3 # 重连间隔
max-times: 0 # 最大重连次数, 0为无限制
# 是否使用服务器下发的新地址进行重连
# 注意, 此设置可能导致在海外服务器上连接情况更差
use-sso-address: true
heartbeat:
# 心跳频率, 单位秒
# -1 为关闭心跳
interval: 5
message:
# 上报数据类型
# 可选: string,array
post-format: string
# 是否忽略无效的CQ码, 如果为假将原样发送
ignore-invalid-cqcode: false
# 是否强制分片发送消息
# 分片发送将会带来更快的速度
# 但是兼容性会有些问题
force-fragment: false
# 是否将url分片发送
fix-url: false
# 下载图片等请求网络代理
proxy-rewrite: ''
# 是否上报自身消息
report-self-message: false
# 移除服务端的Reply附带的At
remove-reply-at: false
# 为Reply附加更多信息
extra-reply-data: false
# 跳过 Mime 扫描, 忽略错误数据
skip-mime-scan: false
output:
# 日志等级 trace,debug,info,warn,error
log-level: warn
# 日志时效 单位天. 超过这个时间之前的日志将会被自动删除. 设置为 0 表示永久保留.
log-aging: 15
# 是否在每次启动时强制创建全新的文件储存日志. 为 false 的情况下将会在上次启动时创建的日志文件续写
log-force-new: true
# 是否启用 DEBUG
debug: false # 开启调试模式
# 默认中间件锚点
default-middlewares: &default
# 访问密钥, 强烈推荐在公网的服务器设置
access-token: ''
# 事件过滤器文件目录
filter: ''
# API限速设置
# 该设置为全局生效
# 原 cqhttp 虽然启用了 rate_limit 后缀, 但是基本没插件适配
# 目前该限速设置为令牌桶算法, 请参考:
# https://baike.baidu.com/item/%E4%BB%A4%E7%89%8C%E6%A1%B6%E7%AE%97%E6%B3%95/6597000?fr=aladdin
rate-limit:
enabled: false # 是否启用限速
frequency: 1 # 令牌回复频率, 单位秒
bucket: 1 # 令牌桶大小
database: # 数据库相关设置
leveldb:
# 是否启用内置leveldb数据库
# 启用将会增加10-20MB的内存占用和一定的磁盘空间
# 关闭将无法使用 撤回 回复 get_msg 等上下文相关功能
enable: true
# 连接服务列表
servers:
# 添加方式,同一连接方式可添加多个,具体配置说明请查看文档
#- http: # http 通信
#- ws: # 正向 Websocket
#- ws-reverse: # 反向 Websocket
#- pprof: #性能分析服务器
# 反向WS设置
- ws-reverse:
# 反向WS Universal 地址
# 注意 设置了此项地址后下面两项将会被忽略
universal: ws://127.0.0.1:8080/cqhttp/ws
# 反向WS API 地址
api: ws://127.0.0.1:8080/cqhttp/api
# 反向WS Event 地址
event: ws://127.0.0.1:8080/cqhttp/event
# 重连间隔 单位毫秒
reconnect-interval: 3000
middlewares:
<<: *default # 引用默认中间件
修改完我们保存退出,并重新运行./go-cqhttp
,等待扫码登录,出现如下提示则证明go-cqhttp
初始化已经登录成功
[2021-09-25 04:59:35] [INFO]: 扫码成功, 请在手机端确认登录.
[2021-09-25 04:59:38] [INFO]: 登录成功 欢迎使用: Luck-c
第二步-安装nonebot
进入服务器根目录,执行如下命令下载nonebot脚手架安装
mkdir /root/nonabot
cd /root/nonabot
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple nb-cli
这里可能会出现如下报错:
ModuleNotFoundError: No module named '_ctypes'
这是Python3中有个内置模块叫ctypes,它是Python3的外部函数库模块,它提供兼容C语言的数据类型,并通过它调用Linux系统下的共享库(Shared library),此模块需要使用CentOS7系统中外部函数库(Foreign function library)的开发链接库(头文件和链接库)。
由于在CentOS7系统中没有安装外部函数库(libffi)的开发链接库软件包,所以在安装pip的时候就报了ModuleNotFoundError: No module named '_ctypes'
的错误。
解决办法见https://www.freesion.com/article/33051002781/
通过脚手架创建一个机器人项目
[root@tmTeQuIuSw nonabot]# /root/python38/bin/nb create
[?] Project Name: demo-bot
[?] Where to store the plugin? 1) In a "demo_bot" folder
[?] Load NoneBot Builtin Plugin? y
[?] Which adapter(s) would you like to use? cqhttp
这样我们就创建了一个名为而demo-bot项目,下面我们来运行这个项目
[root@tmTeQuIuSw demo-bot]# /root/python38/bin/nb run
09-25 06:24:29 [SUCCESS] nonebot | NoneBot is initializing...
09-25 06:24:29 [INFO] nonebot | Current Env: dev
09-25 06:24:29 [DEBUG] nonebot | Loaded Config: {'driver': 'nonebot.drivers.fastapi', 'host': IPv4Address('127.0.0.1'), 'port': 8080, 'debug': True, 'log_level': None, 'api_root': {}, 'api_timeout': 30.0, 'access_token': None, 'secret': None, 'superusers': set(), 'nickname': set(), 'command_start': {'/'}, 'command_sep': {'.'}, 'session_expire_timeout': datetime.timedelta(seconds=120), 'environment': 'dev'}
09-25 06:24:29 [DEBUG] nonebot | Succeeded to load adapter "cqhttp"
09-25 06:24:29 [SUCCESS] nonebot | Succeeded to import "nonebot.plugins.echo"
09-25 06:24:29 [SUCCESS] nonebot | Running NoneBot...
09-25 06:24:29 [DEBUG] nonebot | Loaded adapters: cqhttp
09-25 06:24:29 [INFO] uvicorn | Uvicorn running on http://127.0.0.1:8080 (Press CTRL+C to quit)
09-25 06:24:29 [INFO] uvicorn | Started reloader process [50139] using watchgod
09-25 06:24:31 [SUCCESS] nonebot | NoneBot is initializing...
09-25 06:24:31 [INFO] nonebot | Current Env: dev
09-25 06:24:31 [DEBUG] nonebot | Loaded Config: {'driver': 'nonebot.drivers.fastapi', 'host': IPv4Address('127.0.0.1'), 'port': 8080, 'debug': True, 'log_level': None, 'api_root': {}, 'api_timeout': 30.0, 'access_token': None, 'secret': None, 'superusers': set(), 'nickname': set(), 'command_start': {'/'}, 'command_sep': {'.'}, 'session_expire_timeout': datetime.timedelta(seconds=120), 'environment': 'dev'}
09-25 06:24:31 [DEBUG] nonebot | Succeeded to load adapter "cqhttp"
09-25 06:24:31 [SUCCESS] nonebot | Succeeded to import "nonebot.plugins.echo"
09-25 06:24:31 [INFO] uvicorn | Started server process [50143]
09-25 06:24:31 [INFO] uvicorn | Waiting for application startup.
09-25 06:24:31 [INFO] uvicorn | Application startup complete.
此时nonebot项目已经启动了,我们在新建一个窗口运行go-cqhttp
[root@tmTeQuIuSw ~]# ./go-cqhttp
[2021-09-25 06:26:18] [INFO]: 当前版本:v1.0.0-beta7-fix2
[2021-09-25 06:26:18] [INFO]: 用户交流群: 721829413
[2021-09-25 06:26:18] [INFO]: 将使用 device.json 内的设备信息运行Bot.
[2021-09-25 06:26:18] [INFO]: Bot将在5秒后登录并开始信息处理, 按 Ctrl+C 取消.
[2021-09-25 06:26:23] [INFO]: 开始尝试登录并同步消息...
[2021-09-25 06:26:23] [INFO]: 使用协议: iPad
[2021-09-25 06:26:23] [INFO]: Protocol -> connect to server: 157.255.13.249:8080
[2021-09-25 06:26:25] [INFO]: 登录成功 欢迎使用: Luck-c
[2021-09-25 06:26:25] [INFO]: 开始加载好友列表...
[2021-09-25 06:26:25] [INFO]: 共加载 72 个好友.
[2021-09-25 06:26:25] [INFO]: 开始加载群列表...
[2021-09-25 06:26:26] [INFO]: 共加载 7 个群.
[2021-09-25 06:26:26] [INFO]: 信息数据库初始化完成.
[2021-09-25 06:26:26] [INFO]: 资源初始化完成, 开始处理信息.
[2021-09-25 06:26:26] [INFO]: アトリは、高性能ですから!
[2021-09-25 06:26:26] [INFO]: 正在检查更新.
[2021-09-25 06:26:26] [INFO]: 开始尝试连接到反向WebSocket Universal服务器: ws://127.0.0.1:8080/cqhttp/ws
[2021-09-25 06:26:26] [INFO]: 检查更新完成. 当前已运行最新版本.
[2021-09-25 06:26:27] [INFO]: 收到服务器地址更新通知, 将在下一次重连时应用.
好,至此我们的机器人就成功启动了,
我们打开QQ对话框来体验一下
OK,完结。
版权声明:
作者:Ne-21
链接:https://blog.gocos.cn/archives/156.html
来源:云淡风轻
文章版权归作者所有,未经允许请勿转载。

随风
Ne-21@随风