Kratgo Save

Simple, lightweight and ultra-fast HTTP Cache to speed up your websites

Project README

Kratgo

Test status Go Report Card GitHub release Docker

Simple, lightweight and ultra-fast HTTP Cache to speed up your websites.

Requirements

  • Go >= 1.20.X
  • make
  • git

Features:

  • Cache proxy.
  • Load balancing beetwen backends.
  • Cache invalidation via API (Admin).
  • Configuration to non-cache certain requests.
  • Configuration to set or unset headers on especific requests.

General

To known if request pass across Kratgo Cache in backend servers, check the request header X-Kratgo-Cache with value true.

Install

Clone the repository:

git clone https://github.com/savsgio/kratgo.git && cd kratgo

and execute:

make
make install

The binary file will install in /usr/local/bin/kratgo and configuration file in /etc/kratgo/kratgo.conf.yml

Cache invalidation (Admin)

The cache invalidation is available via API. The API's address is configured in admin section of the configuration file.

This API only accepts POST requests with json, under the path /invalidate/.

Ex: http://localhost:6082/invalidate/

The complete json body must be as following example:

{
	"host": "www.example.com",
	"path": "/es/",
	"header": {
		"key": "Content-Type",
		"value": "text/plain; charset=utf-8"
	}
}

IMPORTANT: All fields are optional, but at least you must specify one.

All invalidations will process by workers in Kratgo. You can configure the maximum available workers in the configuration.

The workers are activated only when necessary.

Docker

The docker image is available in Docker Hub: savsgio/kratgo

Get a basic configuration from here and customize it.

Run with:

docker run --rm --name kratgo -it -v <VOLUME WITH CONFIG> -p 6081:6081 -p 6082:6082 savsgio/kratgo -config <CONFIG FILE PATH IN THE VOLUME>

Developers

Copy configuration file ./config/kratgo.conf.yml to ./config/kratgo-dev.conf.yml, and customize it.

Run with:

make run

Contributing

Feel free to contribute it or fork me... :wink:

Open Source Agenda is not affiliated with "Kratgo" Project. README Source: savsgio/kratgo
Stars
61
Open Issues
0
Last Commit
1 year ago
Repository
License

Open Source Agenda Badge

Open Source Agenda Rating