#1 2020-06-20 20:11:24

mpv
Member
From: Ukraine
Registered: 2012-03-24
Posts: 1,571
Website

Build a "SaaS" solution using mORMot

In pull #324 I add a systemd socket activation / journal logging support for mORMot.
This allow to build a SaaS solutions with process-per-customer ideology (for many tasks multitenancy is not the thing customer expect, for example finance or personal information)

Or simply create a service what starts on demand, for example because most of the time it's idle (some statistic services etc.)

See systemd integration section in samples 36 for details

Feedbacks is wellcome

Offline

#2 2020-06-21 08:57:54

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 14,673
Website

Re: Build a "SaaS" solution using mORMot

This sounds just great.

Do you use it on production?

Offline

#3 2020-06-21 09:22:41

mpv
Member
From: Ukraine
Registered: 2012-03-24
Posts: 1,571
Website

Re: Build a "SaaS" solution using mORMot

For a while it used only for testing (intensive).  mORMot part is ready for production, but In my case creating a new environment for a customer is a complex task (in opposite to a classic mORMot), so I still wrote a scripts for CD (our product use many services: nginx, Postgres, Redis for cache, RabbitMQ for message queues, nodejs for websockets, camunda for BPM, tesseract for document recognition, OnlyOffice to document edit and collaboration, certification authority for user certificates management and so on). Also several days ago I found a brilliant cockpit project what simplify administration UI a lot and allow to very easy wrote a plugins what we need.
I hope in 1-2 week we finish CD.

P.S.
@ab - please, look at libc problem (fcntl64). Current trunk is not usable - I temporary replace a sqlite3.o from a old (w/o new build) mORMot version for testing purpose (i don't use an encryption on SQLite3 level, but use encrypted FS instead)

Offline

#4 2020-06-21 12:11:32

pvn0
Member
From: Slovenia
Registered: 2018-02-12
Posts: 211

Re: Build a "SaaS" solution using mORMot

that's really cool, now that you've mentioned cockpit, does everyone use this gimacky php web UI to admin their servers? I used Proxmox for a while and after a few months I wasn't confident it would hold up when shit hits the fan. Like, I have 0 faith in this and I absolutely don't want to deal with another layer of abstraction just so I can look at some graphs or start a VM faster. Where is the value?

Offline

#5 2020-06-21 12:56:42

mpv
Member
From: Ukraine
Registered: 2012-03-24
Posts: 1,571
Website

Re: Build a "SaaS" solution using mORMot

The main purpose of Proxmox is to manage VM. This is how we currently works - one VM for one customer. Proxmox to manage VMs.Very resources unfriendly...

The idea under systemd activation is to go away from VM, activate app in  Control Groups (Cgroups) environment with limited resources (build-in feature in systemd) on the bare metal. In case of socket activation we can actually run an app "on demand" and shut it down after some period of inactivity.

I mentioned a cockpit project (it's written using C, not PHP) because it's main purpose is to manage a host from browser (including docker/podman containers). It's just a VERY thin layer between browser and host. But the main thing what important for me in cockpit is how simple is create a plugin.

Offline

#6 2020-06-21 15:48:35

pvn0
Member
From: Slovenia
Registered: 2018-02-12
Posts: 211

Re: Build a "SaaS" solution using mORMot

Thanks for explaining, I had no idea systemd can do that, looks very promising! I use LXC containers instead of VMs but this systemd socket activation could be very useful.

Offline

#7 2020-06-21 18:14:09

mpv
Member
From: Ukraine
Registered: 2012-03-24
Posts: 1,571
Website

Re: Build a "SaaS" solution using mORMot

Systemd can also manage a LXC containers (machinectl) - see chapter 21 here. With optional socket activation. And thanks to SynLog journald integration - with centralized logging

Last edited by mpv (2020-06-21 18:14:31)

Offline

#8 2020-06-22 06:47:26

pvn0
Member
From: Slovenia
Registered: 2018-02-12
Posts: 211

Re: Build a "SaaS" solution using mORMot

Amazing, thank you! I've been using LXD container manager but machinectl looks amazing. Exactly what I need and now I can run stock debian without any external snap packages. Still blows my mind I missed this systemd functionality.
Thanks again very much.

Offline

#9 2020-06-22 13:40:17

edwinsn
Member
Registered: 2010-07-02
Posts: 1,218

Re: Build a "SaaS" solution using mORMot

This thread is a good read, thank you guys! The systemd socket activation is really interesting, the start-on-demand nature is similar to that of the 'serverless' (eg, AWS lambda) hype.

Not sure if Window server has the similar feature?


Delphi XE4 Pro on Windows 7 64bit.
Lazarus trunk built with fpcupdelux on Windows with cross-compile for Linux 64bit.

Offline

#10 2020-08-07 13:09:28

mpv
Member
From: Ukraine
Registered: 2012-03-24
Posts: 1,571
Website

Re: Build a "SaaS" solution using mORMot

Important fix is added for journald logging - because sd_journal_print args strings processed using C printf semantic, % is a printf placeholder and should be either escaped using %% or all formatting args must be passed.

So better to use sd_journal_sendv for logging. See https://github.com/synopse/mORMot/pull/340

Last edited by mpv (2020-08-07 13:10:12)

Offline

#11 2020-08-07 13:54:58

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 14,673
Website

Re: Build a "SaaS" solution using mORMot

Merged.

Thanks!

Offline

Board footer

Powered by FluxBB