summaryrefslogtreecommitdiffstats
path: root/docs/principles.rst
blob: 737c5f9422b4a205c6c553efbc6d7fa5e84d6c01 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
Design Principles
=================

Takahē is somewhat opinionated in its design goals, which are:

* Simplicity of maintenance and operation
* Multiple domain support
* Asychronous Python core
* Low-JS user interface

These are explained more below, but it's important to stress the one thing we
are not aiming for - scalability.

If we wanted to build a system that could handle hundreds of thousands of
accounts on a single server, it would be built very differently - queues
everywhere as the primary communication mechanism, most likely - but we're
not aiming for that.

Our final design goal is for around 10,000 users to work well, provided you do
some PostgreSQL optimisation. It's likely the design will work beyond that,
but we're not going to put any specific effort towards it.

After all, if you want to scale in a federated system, you can always launch
more servers. We'd rather work towards the ability to share moderation and
administration workloads across servers rather than have one giant big one.


Simplicity Of Maintenance
-------------------------

It's important that, when running a social networking server, you have as much
time to focus on moderation and looking after your users as you can, rather
than trying to be an SRE.

To this end, we use our deliberate design aim of "small to medium size" to try
and keep the infrastructure simple - one set of web servers, one set of task
runners, and a PostgreSQL database.

The task system (which we call Stator) is not based on a task queue, but on
a state machine per type of object - which have retry logic built in. The
system continually examines every object to see if it can progress its state
by performing an action, which is not quite as *efficient* as using a queue,
but recovers much more easily and doesn't get out of sync.


Multiple Domain Support
-----------------------

TODO


Asynchronous Python
-------------------

TODO


Low-JS User Interface
---------------------