Compare commits

..

No commits in common. "fe8a7cd754b6f8474f69603ec476dea404c02750" and "91769fa9c482f23a572cb7e9aeaab43accaeed86" have entirely different histories.

12 changed files with 779 additions and 1234 deletions

View file

@ -1,2 +1,3 @@
PUBLIC_PLAUSIBLE="false"
PUBLIC_ADDRESS="https://gay.leggy.dev"
PUBLIC_COMMENTS="false"

1676
package-lock.json generated

File diff suppressed because it is too large Load diff

View file

@ -10,12 +10,12 @@
"astro": "astro"
},
"dependencies": {
"@astrojs/check": "^0.9.4",
"@astrojs/mdx": "^3.1.9",
"astro": "4.16.10",
"typescript": "^5.6.3"
"@astrojs/check": "^0.9.3",
"@astrojs/mdx": "^3.1.5",
"astro": "^4.15.4",
"typescript": "^5.6.2"
},
"devDependencies": {
"sass": "^1.80.6"
"sass": "^1.78.0"
}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 65 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 150 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 107 KiB

View file

@ -1,250 +0,0 @@
---
draft: false
title: umami
description: Goob bye Plausible
pubDate: 2024-11-07
tags:
- alpine
- linux
- webdev
- networking
---
import Note from "../../components/Note.astro";
## Why I went with umami
Sike, before we talk about umami, lets talk about some of the other options I had, that I didn't go with
### Matomo
I've seen Matomo get suggested in a few places before I went with Plausible originally, but I never checked it out till
now. While it looked solid, it also has _too_ much stuff... I didn't need or want a heatmap of interactions throughout
my website, nor session recording, or any ecommerce stuff.
Even with all that, I didn't particularly like the design, it was cluttered and confusing to go through the demo site.
### PostHog
PostHog was the second thing I've checked out, while it looked promising, it was just too much along with not solving my
problem of _having_ to use docker.
The requirements were also a bit insane for my needs, 8GBs of ram (recommended minimum) in comparison to the 256MB the
CT running umami currently has.
### Fathom
This was the last one I checked out before going with umami, I liked the design as it was similar to Plausible, and had
the feature set that I was looking for, with no complicated dashboards.
Buuuuuut, there is no self-hostable option, [kinda](https://github.com/usefathom/fathom). The lite version is no longer
maintained. Which is a shame, as it fathom looked promising and Go is a nice language to work with...
Maybe I could pick it up in the future, and bring it back to life again
## Services feature comparison
Blank sections are due to me not being able to find information on said topic, also, features listed are things I
specifically looked for.
| | Matomo | PostHog | umami | Fathom | Plausible |
| ----------------------------- | ------ | ------- | --------------- | -------- | --------- |
| Self-Hostable | Yes | Yes | Yes | Yes [^1] | Yes |
| Hosting method | PHP | Docker | Node or Docker | Go [^2] | Docker |
| GDPR compliant | Yes | Yes | Yes | Yes [^3] | Yes |
| Email reports | Yes | Yes | | | Yes |
| Tracking events | Yes | Yes | Yes [^4] | | No |
| Simple (and pretty) dashboard | No | Mostly | Yes | Yes | Yes |
| Minimum RAM | 1GB | 8GB | 512MB [^5] | | 1GB |
| Supported Databases | MySQL | | Postgres, MySQL | SQLite | |
[^1]: An old and limited version is available, that is no longer maintained
[^2]: The self-hosted (lite) version uses Go, the paid version uses [Laravel](https://github.com/usefathom/fathom/issues/336#issuecomment-1079549690).
[^3]: Fathom is a Canadian based company, and while their servers are also in Canada, [they comply with EU regulations and laws](https://usefathom.com/features/eu-isolation).
[^4]: unami doesn't track events automatically [and needs to be setup manually across the website](https://umami.is/docs/track-events).
[^5]: unami doesn't list minimum requirements, so far from my testing, this is about what I needed for all my websites. For installs that have higher page visit counts, I imagine more would be needed.
<Note text="This ain't a scientific featurelist" />
## So what was wrong with Plausible?
Simply put, too heavy for my use-case. It was designed for websites that see thousands of people per week, maybe even a
day, but I haven't even reached a thousand views in a year! Secondly, docker, it has it's uses, but since all my
services already run in LXT/Proxmox containers, no point of putting them within another container.
All that I could've lived with fine, if not for trying to upgrade it. It broke, even in a docker container, it refused
to start after an update and wouldn't show any signs of life other that pushing my CPU usage to 100%, then freezing the
container!
Downgrading - worked. But since database migrations have been complete, a lot of the pages no longer worked, so I just
left it alone, until I was bothered with finding an alternative solution.
## umami
Finally, something I was looking for, it has all the features I need, with not too much extra stuff I'll never use. AND
it's self-hostable with a non-docker option!
Though, I did run into some issues compiling the project, specifically needing 2GBs of ram, lol
![Console, displaying an error from JS about running out of memory in the HEAP, then promptly exiting the process.](../../assets/posts/2024/11/js_oom.jpg)
And here's a dashboard comparison, before umami and Plausible
![Homepage of umami, showing a counter of how many people have visited my website, with a nearly empty graph of activity over the span of 1 day.](../../assets/posts/2024/11/umami.png)
![Dashboard of my page on Plausible, showing a line-graph of activity on my website over the past year, peaking in June of 2024 and a counter of 339 unique visitors.](../../assets/posts/2024/11/plausible.png)
## Now onto the fun stuff
Here's the steps I've taken to setup umami, it's not meant as a tutorial, but hopefully will be helpful regardless...
### Alpine
For this, I went with Alpine! It was my first time trying it, but it went great, and will probably be moving all my
services to it at some point, but that should be its own blog post. Main hurdle I had was understanding `OpenRC`, as
Alpine doesn't use `systemd`, but once I gotten used to `rc-update add <service>` and
`rc-service <service> start/stop/status` it went very smoothly.
Obviously firstly we should update all the available packages and install some useful tools
```bash
apk update
apk upgrade
apk add vim git
```
### Caddy
<Note text="3000 is the default port for yarn, but adjust for your needs" />
I didn't reaaaaaly need caddy for this, as it would mean the service would be behind two proxies, but I wanted to setup
caddy anyway. It was quite simple really
```bash
apk add caddy
rc-update add caddy
# Reboot
rc-service caddy start
# And make the required dirs and files
mkdir /var/www/html
```
Then, in `/etc/caddy`, we edit the `Caddyfile`
```bash
cd /etc/caddy
vim Caddyfile
```
And add the following
```caddyfile
:8080 {
reverse_proxy localhost:3000
}
```
And finally
```bash
# While still in /etc/caddy
caddy reload
```
### Postgres
It was slightly more manual than it is usually on ubuntu, but this is a great guide that still is relative
https://luppeng.wordpress.com/2020/02/28/install-and-start-postgresql-on-alpine-linux/
Then I just needed to make a database with a simple command.
```sql
CREATE DATABASE umami;
```
### Installing umami
The [official documentation](https://umami.is/docs/install) is the nicest, but there is some extra stuff you need todo
outside-of their tutorial
Firstly we make the required directory and clone the project
```bash
mkdir /var/www/html
```
<Note text="Before you go any further, follow the official documentation, then come back :3" />
### Setting up umami as a service
While umami has a section on turning the project into a service, I prefer using what's already on the system for this,
OpenRC!
Making a service on OpenRC is actually quite simple,
[they have a guide for making services too](https://github.com/OpenRC/openrc/blob/master/service-script-guide.md).
First, make a user for the service, such as `umami`. Then run the following command to make, and edit, a file for the
service
```bash
touch /etc/init.d/umami
vim /etc/init.d/umami
```
And enter the following
```bash
#!/sbin/openrc-run
YARN_USER="umami"
PROJECT_DIR="/var/www/html/umami"
YARN_CMD="/usr/local/bin/yarn start"
APP_NAME="umami"
command="$YARN_CMD"
command_args="start"
command_user="$YARN_USER"
pidfile="/var/run/${APP_NAME}.pid"
output_log="/var/log/${APP_NAME}.log"
error_log="/var/log/${APP_NAME}_error.log"
depend() {
need net
}
start() {
ebegin "Starting ${APP_NAME}"
start-stop-daemon --start --user "$YARN_USER" \
--make-pidfile --pidfile "$pidfile" \
--chdir "$PROJECT_DIR" \
--exec "$command" -- $command_args >> "$output_log" 2>> "$error_log" &
eend $?
}
stop() {
ebegin "Stopping ${APP_NAME}"
start-stop-daemon --stop --pidfile "$pidfile"
eend $?
}
```
and run the following - same - commands as we did earlier for caddy
```bash
rc-update add umami
# Reboot
rc-service umami start
```
And we're done! You may also now notice new text on the bottom of the page
> This website tracks anonymous analytics. To see them in action visit umami.leggy.dev!
If you really don't like the idea of your visit being counted, run
```js
localStorage.setItem("umami.disabled", 1);
```
In the browser console to remove all future visit counts.

View file

@ -1,3 +0,0 @@
---
name: Alpine
---

View file

@ -1,3 +0,0 @@
---
name: Linux/GNU
---

View file

@ -16,6 +16,7 @@ interface Props {
const { title, plugins, seo } = Astro.props;
const plausible = import.meta.env.PUBLIC_PLAUSIBLE !== "false";
const address = import.meta.env.PUBLIC_ADDRESS;
---
@ -50,17 +51,20 @@ const address = import.meta.env.PUBLIC_ADDRESS;
href="https://api.fontshare.com/v2/css?f[]=jet-brains-mono@400&f[]=general-sans@1&display=swap"
/>
<!--
If you want to disable your visits from being counted,
run "localStorage.setItem('umami.disabled', 1);"
in the JS console (without the quotation marks).
-->
<script
defer
src="https://umami.leggy.dev/script.js"
data-website-id="e8c4fb4f-6ff2-4179-8873-957d635c862c"
/>
{plausible ? (
<link
rel="preconnect"
href="https://plausible.leggy.dev"
>
<script
is:inline
defer
data-domain="gay.leggy.dev"
src="https://plausible.leggy.dev/js/script.js"
></script>
) : (
<script is:inline>console.log("Plausible Disabled");</script>
)}
{plugins?.katex && (
<link
rel="preconnect"
@ -123,10 +127,6 @@ const address = import.meta.env.PUBLIC_ADDRESS;
</div>
<main>
<slot />
<p id="anal_notice">
This website tracks anonymous analytics. To see them in action visit
<a href="https://umami.leggy.dev/share/jNKQaN97seslziXY/gay.leggy.dev" target="_blank">umami.leggy.dev</a>!
</p>
</main>
</body>
<script>
@ -160,19 +160,4 @@ const address = import.meta.env.PUBLIC_ADDRESS;
outline: 0 solid transparent;
}
}
#anal_notice {
padding-top: 16px;
margin-bottom: -16px;
color: $light;
font-size: 11px;
text-align: center;
> a {
color: $accent;
&:hover {
color: $light;
}
}
}
</style>

View file

@ -222,33 +222,40 @@ const comments = import.meta.env.PUBLIC_COMMENTS === "true";
}
table {
margin: 16px 0;
margin: 16px -16px;
width: 100%;
font-size: 13px;
border-collapse: collapse;
border-bottom: 2px solid $gray;
/*border: 2px solid $gray;*/
tr {
&:nth-child(even) td {
background-color: rgba($gray, 0.15);
}
&:last-of-type > td {
/*border-bottom: 2px solid darken($gray, 2%);*/
/*border-bottom: 2px solid $gray;*/
}
td {
padding: 8px 16px;
&:first-child {
border-bottom-left-radius: $radius;
}
&:last-child {
border-bottom-right-radius: $radius;
}
}
th {
padding: 8px 16px;
font-weight: bold;
text-align: left;
/*border-bottom: 2px solid darken($gray, 2%);*/
font-weight: 500;
border-bottom: 2px solid darken($gray, 2%);
background-color: $gray;
&:first-child {
@ -262,16 +269,16 @@ const comments = import.meta.env.PUBLIC_COMMENTS === "true";
}
img {
margin: 16px 0;
margin: 16px -16px;
max-width: 100%;
max-width: calc(100% + 32px);
height: auto;
border-radius: $radius;
}
.astro-code {
margin: 20px 0;
margin: 20px -16px;
padding: 40px 8px 8px;