前段时间使用E5SubBot来对365 E5进行续订,使用后发现E5SubBot项目确实有效。由于之前是使用nohup将程序放在后台运行,程序运行一段时间后会停止。为了解决这个问题,于是自己写了一个shell脚本,然后配合计划任务就解决了这个问题,事后发现自己又绕了弯路,用systemd服务不是更好吗?
不过自己写过的东西还是记录一下,直接删了又感觉没意义了,下面是我最开始写的脚本。
#!/bin/bash
pid=`ps -aux | grep E5SubBot | grep -v 'grep' | awk '{print $2}'`
if [ "$pid" != "" ];then
echo "running ..."
else
echo "$(date '+%Y/%m/%d %H:%M:%S'):no run,starting..." >> /root/e5cron.log
echo "no run"
cd /root/e5sub/ && nohup /root/e5sub/E5SubBot >> /root/e5sub/e5sub-$(date +%Y%m%d%H%M%S).log &
fi
接着配合计划任务,每两个小时执行一次自己写的shell判断是否已经停止运行,如果停止了就启动,没有停止则忽略。
* */2 * * * /root/e5bot.sh
然而上述方法并不是一个完美的方案,后来我将使用计划任务的方案改为了systemd服务的方式运行,我使用的服务器的操作系统是Centos 7,具体的过程如下。
以下是我在Centos 7操作系统中的具体安装过程。
E5SubBot项目Github地址:https://github.com/iyear/E5SubBot/releases
根据自己服务器的具体情况选择对应版本进行下载。这里我选择的是E5SubBot_Linux_64bit的版本,目前大多数服务器使用的均为此版本。
wget https://github.com/iyear/E5SubBot/releases/download/v0.2.1/E5SubBot_Linux_64bit.tar.gz
将刚下载下来的文件进行解压。
tar xvf E5SubBot_Linux_64bit.tar.gz
得到如下四个文件,而我们需要使用的是E5SubBot这个二进制文件。
LICENSE
README.md
README_zhCN.md
E5SubBot
将解压出来的文件E5SubBot移动到对应目录下。
# 创建文件夹
mkdir /opt/e5sub
# 移动文件
mv E5SubBot /opt/e5sub/E5SubBot
# 给文件添加执行权限
chmod a+x /opt/e5sub/E5SubBot
如果你已经安装了数据库,请进入下一步。这里我选择的是MYSQL5.7,如果你的服务器内存过小,可以使用MYSQL5.6或者选择使用远程MYSQL。
# 下载安装MYSQL源
wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
rpm -ivh mysql57-community-release-el7-10.noarch.rpm
# 安装数据库
yum install -y mysql-community-server
选择其他版本数据库:
# 如果不使用mysql57请在以下地址选择对应的版本的rpm
# https://repo.mysql.com/yum/
# 也可以执行下面命令查询所有可用版本
yum repolist enabled | grep mysql
# 禁用当前使用的57版本
yum-config-manager --disable mysql57-community
# 选择启用使用56版本
yum-config-manager --enable mysql56-community
# 最后在执行安装
yum install -y mysql-community-server
启动mysql数据库:
systemctl start mysqld.service
获取MYSQL的默认密码:
# 获取mysql自动生成的密码
grep password /var/log/mysqld.log
接下来你应该会看到如下的一段文本,其中t;uY?tk&S2bT
就是你的密码:
2020-12-10T06:38:17.070043Z 1 [Note] A temporary password is generated for root@localhost: t;uY?tk&S2bT
登录数据库:
mysql -uroot -p'密码'
由于MYSQL57默认密码策略,密码过于简单不能设置:
-- 使用以下SQL查询当前密码验证策略
mysql> show variables like 'validate_password%';
-- 设置MYSQL密码验证策略为low
mysql> set global validate_password_policy=0;
创建e5sub数据库:
-- 创建e5sub数据库,并设置编码
mysql> CREATE DATABASE `e5sub` CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
创建角色,分配权限:
-- 创建e5sub用户,并设置密码
mysql> CREATE USER `e5sub`@`localhost` IDENTIFIED BY 'e5sub';
-- 将e5sub数据库的所有权限授权给e5sub用户
mysql> GRANT all ON `e5sub`.* TO `e5sub`@`localhost`;
-- 刷新权限
mysql> FLUSH PRIVILEGES;
数据表不需要自己创建,E5SubBot在启动时会自动创建数据表。
在/opt/e5sub目录下创建一个config.yml文件,配置telegram bot和mysql的具体信息。如果不知道如何配置请阅读E5SubBot项目readme.md的Configuration。
vim /opt/e5sub/config.yml
配置文件内容如下:
bot_token: 你的TG机器人的TOKEN
notice: "这里可以填写机器人的通知信息"
admin: 填写你tg的id,使其作为管理员
#socks5: 127.0.0.1:1080
errlimit: 15
cron: "1 */1 * * *"
bindmax: 5
mysql:
host: localhost
port: 3306
user: e5sub
password: e5sub
database: e5sub
当然如果你使用的是境内服务器,需要指定socks5属性来使用代理服务器。以下是具体属性的说明。
属性 | 说明 |
---|---|
bot_token | tg机器人的token,可以通过@BotFather进行获取 |
socks5 | [可选]用于指定socks5代理,例如127.0.0.1:1080 |
notice | 公告,在使用/help时显示 |
admin | 管理员tgid,可以通过@userinfobot获取,用于手动执行/task任务和获取总任务执行反馈 |
errlimit | 单个帐户错误的最大数量,当单个账户执行错误到指定次数时自动解除绑定并发送通知,若设置为-1则不限制 |
bindmax | 单个账户最大绑定帐号的数量 |
cron | 调用api的频率,使用cron表达式 |
mysql | mysql数据库的连接信息 |
使用vim编辑器编辑单元文件。
vim /etc/systemd/system/e5sub.service
将以下内容复制进去。
[Unit]
Description=Telegram E5Sub Bot
[Service]
Type=simple
WorkingDirectory=/opt/e5sub
ExecStart=/opt/e5sub/E5SubBot
Restart=always
RestartSec=30
[Install]
WantedBy=multi-user.target
systemd单元文件编辑完成后需要重新载入服务配置文件。
systemctl daemon-reload
然后开启服务。
systemctl start e5sub
查看服务状态。
systemctl status e5sub
最后设置服务自启。
systemctl enable e5sub