【好玩的Docker项目】搭建一个小而美的网站流量监控——Umami
【好玩的Docker项目】搭建一个小而美的网站流量监控——Umami

【好玩的Docker项目】搭建一个小而美的网站流量监控——Umami

前言

前俩期,我们搭建了自己的网站监控——

【好玩的Docker项目】搭建一个专属自己的网站监控——Uptime Kuma,还有服务器的监控——

【好玩的Docker项目】搭建两个专属自己的服务器监控——Ward && ServerStatus,

这一期带大家来搭建一个网站流量的监控,看看自己的小破站到底有多少人看,是不是1 ip呢?

效果展示

搭建视频

YouTube:https://youtu.be/rRBMZwKiCRk

哔哩哔哩:https://player.bilibili.com/player.html?bvid=BV1eL4y1b7P6&cid=480025541&page=1

环境准备

服务器:腾讯云轻量应用服务器(购买链接)
系统:Debian 10(DD脚本)
域名一枚,并做好解析到服务器上(域名购买、域名解析 视频教程)
安装好Docker、Docker-compose(相关脚本
安装好Nginx Proxy Manager(相关教程)
宝塔用户建议使用国际版aapanel(下载链接)

开始搭建

1、安装docker、curl、git、vim、wget等必备的工具

apt update -y
apt install -y wget vim sudo curl git
wget -qO- get.docker.com | bash
docker -v
systemctl enable docker
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker-compose --version

2、然后到github上接取项目,进入目录

mkdir -p /docker/umami
cd /docker/umami

3、编辑配置文件

nano docker-compose.yml

4、写入Docker-compose代码

---
version: '3'
services:
  umami:
    image: ghcr.io/umami-software/umami:postgresql-latest
    ports:
      - "3000:3000"
    environment:
      DATABASE_URL: postgresql://umami:umami@db:5432/umami # 这里的数据库和密码要和下方你修改的相同
      DATABASE_TYPE: postgresql
      HASH_SALT: replace-me-with-a-random-string
    depends_on:
      - db
    restart: always
  db:
    image: postgres:12-alpine
    environment:
      POSTGRES_DB: umami
      POSTGRES_USER: umami # 数据库用户
      POSTGRES_PASSWORD: umami  # 数据库密码
    volumes:
      - ./sql/schema.postgresql.sql:/docker-entrypoint-initdb.d/schema.postgresql.sql:ro
      - ./umami-db-data:/var/lib/postgresql/data
    restart: always

检查完毕之后,ctrl+x退出,按y确认修改内容,enter确认

5、启动Umami

docker-compose up -d
关于Internal Server Error 问题
主要是因为数据库链接和初始化。 在docker-compose 中有个映射是 →./sql/schema.postgresql.sql:/docker-entrypoint-initdb.d/schema.postgresql.sql:ro 这个.sql 文件可以去作者的仓库里面找到:https://github.com/mikecao/umami/blob/master/sql/schema.mysql.sql 需要提前映射到安装的地方,来初始化数据库(也就是要提前建表),整了一天才发现主要问题在这……可能主要是因为这个东西可以静态部署,所以没有整合到应用里,需要手动执行?
大家可以自行测试一下!

此时,访问http://ip:3000就可以访问了,打开的是英文界面,右上方可以切换语言,默认用户名为admin,密码为umami

宝塔用户需要打开防火墙,放行3000端口,腾讯云、阿里云等用户还需要在官网后台服务器页面放行官方防火墙的3000端口。

如果要反向代理,且反向代理的服务与umami在一台服务器上,可以不用放行3000端口。

添加到站点

激活共享链接就是公开统计数据。

注意这边添加域名,不需要带https://

代码添加到博客

Halo

WordPress

将代码加在主题文件的footer.php下,添加完成之后,刷新浏览器缓存,就能统计到了。 其他的博客也是大同小异,在统计代码的地方加入这段JS代码即可。

参考文献:点击进入

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注