自建 Umami 网站统计分析:Docker + Nginx + Certbot
为什么自建 网站访问统计这件事,说大不大,说小不小。我之前的方案是 Google Analytics,功能确实强,但体感上越来越重——每次加载都要拖慢页面,控制台里几十个报表模板,我只是想知道昨天有多少访客、看了哪些页面而已。 后来试了 Plausible,干净利落,体验很好。但它是付费服务,按年收费。不是说付不起,而是想到这笔钱可以买一台小服务器跑点别的,就觉得自建更划算。 Umami 正是这个定位下的最佳选择。开源、轻量、免费,功能上覆盖了个人网站需要的所有统计维度:访问量、页面排名、来源渠道、访客设备、操作系统、浏览器版本等等。而且它支持多站点管理,一个实例可以同时跟踪多个网站的数据。 环境准备 部署之前,确认服务器上已经安装好以下组件: Docker 和 Docker Compose(用于启动 Umami 和 PostgreSQL) Nginx(用于反向代理) 域名(已解析到服务器 IP) 我用的是 Ubuntu 22.04 系统,如果你用的是其他 Linux 发行版,安装命令略有不同,但后面的 Docker Compose 和 Nginx 配置是通用的。 Docker Compose 部署 Umami 官方推荐用 Docker Compose 部署,这也是最省心的方式。创建一个目录来存放配置: mkdir ~/umami && cd ~/umami 然后新建 docker-compose.yml 文件,写入以下内容: services: umami: image: ghcr.io/umami-software/umami:postgresql-latest ports: - "127.0.0.1:3000:3000" environment: DATABASE_URL: postgresql://umami:umami@db:5432/umami DATABASE_TYPE: postgresql APP_SECRET: your-secret depends_on: - db restart: always db: image: postgres:15 environment: POSTGRES_DB: umami POSTGRES_USER: umami POSTGRES_PASSWORD: umami volumes: - umami-db-data:/var/lib/postgresql/data restart: always volumes: umami-db-data: 有几个配置项需要留意一下。 ...