【Python微信机器人】写一个监控采集公众号文章的插件

原文链接: https://mp.weixin.qq.com/s/f8zbM6wMld3koqjaFbCuxw

前言

弄了个视频号下载后,同一个问题每天都会被问,回答的有点烦了。想了想根本原因还是缺少一个交流平台,微信群的话,刚进群的看不到之前的聊天记录。想整个知识星球,发现只能弄个收费的,免费的需要激活码才能创建。

而有些人不会使用github,所以这篇文章写一下如何使用开源项目搭建一个问答平台。本来是想弄个论坛,但是在搜索的过程中发现这个问答平台更符合我的要求(支持搜索、轻量和搭建简单)。

开始搭建

我使用的系统是Ubuntu server20.04

使用的项目

MySQL安装

这个项目也可以不安装MySQL,使用sqlite3来作为数据库体验一下。不过正式环境下还是建议使用数据库

sudo apt update
sudo apt install mysql-server

安装完成后,可以使用sudo systemctl status mysql.service查看运行状态。

MySQL默认的配置文件在/etc/mysql/my.cnf,但是这里面就两行内容

!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/

看了下这些目录里的文件,mysqld的一些配置都在/etc/mysql/mysql.conf.d/mysqld.cnf

首先需要设置MySQL对docker容器开放,将bind-address改成0.0.0.0(注释掉也可以),端口不改了,因为只对内网ip开放。

然后重启MySQL: sudo systemctl restart mysql.service

先使用sudo mysql进入到SQL命令行

创建数据库

CREATE DATABASE answer;

创建用户

CREATE USER 'answer'@'%' IDENTIFIED BY '123456';

给用户赋予answer数据库的完整权限

GRANT ALL PRIVILEGES ON answer.* TO 'answer'@'%';

现在在命令行使用mysql -uanswer -Danswer -p输入密码后应该能进入到SQL命令行

放通防火墙

sudo ufw allow from 172.17.0.0/16

我查看了我的docker使用的ip段就是172.17.*.*,所以只需要放通这个ip段即可。这样容器就能访问宿主机的所有服务

安装问答平台

docker安装就不说了

docker pull apache/answer:latest

docker run -d \
    -p 19080:80 \
    -v /home/ubuntu/answer-data:/data \
    --name answer \
    apache/answer:latest

安装NGINX管理平台

docker pull docker.io/jc21/nginx-proxy-manager:latest

docker run -d \
    -p 80:80 \
    -p 18081:81 \
    -p 443:443 \
    --name nginx_proxy \
    -v /home/ubuntu/nginx-proxy/nginx-proxy-data:/data \
    -v /home/ubuntu/nginx-proxy/letsencrypt:/etc/letsencrypt \
    docker.io/jc21/nginx-proxy-manager:latest

先放通下防火墙的18081端口

然后访问http://服务器ip:18081会看到登录页面,默认用户名密码: [email protected]/changeme

登录进去要被要求设置用户名和修改密码,修改完进入到主页

点击Proxy Hosts然后点Add Proxy Host,填写如下信息(域名输完按回车,可输入多个域名)。要代理的ip就是宿主机的docker ip,也就是上面ifconfig看到的172.17.0.1,而端口是docker映射的19080。

如果需要开启https的话,如下图所示,点Save即可申请完成。我一开始容器没有映射80端口导致失败了,因为申请证书要保证80端口能被连接。

另外也可以将18081这个端口反向代理到一个域名,这样就能使用域名访问NGINX-Proxy界面。

这里就可以使用域名访问问答平台的安装界面http://answer.ikanade.cn/install,输入一些基本信息和MySQL的连接信息即可。当然你也可以防火墙放通19080,先安装完在做域名反代。

搭建的问答网站

https://answer.ikanade.cn/

以后遇到的问题我都会记录在这上面,你也可以在上面给我提问。网站名称叫每日随笔, 是因为域名备案的名称是这个。

本文由博客一文多发平台 OpenWrite 发布!

热门相关:勇闯天涯   我的女友是丧尸   带着仓库到大明   惊悚乐园   极品医圣