2025-01-06 12:17:29 +03:00
# :candy: Candy Cache :candy:
2025-01-06 00:44:03 +03:00
2025-01-06 01:57:18 +03:00
**CandyCache** — это простой и эффективный кэш на языке Go, который позволяет хранить данные с ограниченным временем жизни (**TTL**).
2025-01-06 01:00:23 +03:00
2025-01-06 01:24:59 +03:00
# Установка
2025-01-06 01:00:23 +03:00
2025-01-06 01:57:18 +03:00
Для использования CandyCache в вашем проекте, установите е г о , используя ```go get git.hikan.ru/serr/candycache```, далее просто добавьте ```git.hikan.ru/serr/candycache``` в блок импорта.
2025-01-06 01:00:23 +03:00
2025-01-06 01:24:59 +03:00
# Основные возможности
2025-01-06 01:00:23 +03:00
2025-01-06 12:18:20 +03:00
- Автоматическая очистка устаревших элементов и возможность е е отключения.
2025-01-06 12:19:06 +03:00
- Кэшем можно управлять вручную.
2025-01-06 12:18:20 +03:00
- Конкурентный доступ к данным возможен благодаря мьютексам.
- Кэш может хранить данные любых типов.
2025-01-06 14:48:47 +03:00
- Можно создавать и загружать дампы.
2025-01-06 01:13:25 +03:00
2025-01-06 01:24:59 +03:00
# Использование
2025-01-06 01:13:25 +03:00
2025-01-06 01:24:59 +03:00
## Создание кэша
2025-01-06 01:13:25 +03:00
2025-01-06 01:26:40 +03:00
### С автоматической очисткой
2025-01-06 01:18:35 +03:00
Для создания нового экземпляра кэша используйте функцию **Cacher** , передавая интервал очистки в наносекундах.
2025-01-06 01:19:02 +03:00
2025-01-06 01:24:25 +03:00
Если требуется указать интервал в секундах/минутах/часах и т.д. - используйте множители из пакета **time** :
2025-01-06 01:17:53 +03:00
```go
cache := candycache.Cacher(10 * time.Minute) // Очистка каждые 10 минут
```
2025-01-06 01:13:25 +03:00
2025-01-06 01:26:40 +03:00
### Без автоматической очистки
2025-01-06 01:24:25 +03:00
Если автоматичская очистка не нужна - просто передайте параметром любое отрицательное число:
```go
cache := candycache.Cacher(-1) // Кэш не будет очищаться автоматически
```
2025-01-06 01:24:59 +03:00
## Добавление элемента
2025-01-06 01:13:25 +03:00
2025-01-06 12:27:28 +03:00
Для добавления элемента в кэш используйте метод **Set** :
2025-01-06 01:17:53 +03:00
```go
2025-01-06 12:27:28 +03:00
cache.Set("key", "value", 5 * time.Minute) // Элемент будет считаться устаревшим через 5 минут
2025-01-06 01:17:53 +03:00
```
2025-01-06 01:13:25 +03:00
В случае, если по указанном ключу уже что-то хранится, оно будет заменено на новый элемент.
2025-01-06 01:24:59 +03:00
## Получение элемента
2025-01-06 01:13:25 +03:00
Для получения элемента из кэша используйте метод **Get** :
2025-01-06 01:17:53 +03:00
```go
2025-01-06 13:13:18 +03:00
value, err := cache.Get("key") // Получение значения по ключу "key"
2025-01-06 01:17:53 +03:00
```
2025-01-06 13:13:18 +03:00
Если элемент найден, то в переменную **value** будет записано значение, а в **err** - **nil** . Если элемент не найден, то в **err** будет записано **key not found** , а значением вернется **nil** .
2025-01-06 01:29:44 +03:00
## Удаление элемента
Для удаления элемента по ключу используйте метод **Delete** :
```go
err := cache.Delete("key1")
if err != nil {
fmt.Println("Ошибка:", err) // Н е найдено записи по ключу
}
```
2025-01-06 01:36:39 +03:00
Элемент будет удален, не смотря на то, устаревший он или нет.
## Массовое удаление элементов
### Удаление устаревших элементов
Для удаления устаревших элементов используйте метод **Cleanup** :
```go
cache.Cleanup() // Перебирает все элементы кэша, удаляет устаревшие
```
2025-01-06 12:20:31 +03:00
### Удаление всех элементов кэша
2025-01-06 01:36:39 +03:00
Для полной очистки кэша используйте метод **Flush** :
```go
cache.Flush() // Удаляет все элементы кэша, не смотря на то, устаревшие они или нет
2025-01-06 01:40:45 +03:00
```
2025-01-06 01:50:45 +03:00
## Получение информации о кэше
### Получение списка элементов
2025-01-06 01:40:45 +03:00
Для получения списка всех элементов в кэше используйте метод **List** :
```go
2025-01-06 01:54:18 +03:00
items := cache.List() // Список всех элементов кэша
2025-01-06 01:41:01 +03:00
for _, item := range items {
fmt.Printf("Ключ: %s, Значение: %v, Момент устаревания: %d\n", item.Key, item.Item.Data(), item.Item.DestroyTimestamp())
}
2025-01-06 01:50:45 +03:00
```
2025-01-06 14:52:30 +03:00
Получить список устаревших элементов можно так
2025-01-06 14:51:57 +03:00
```go
2025-01-06 14:52:30 +03:00
items := ExpiredList()
2025-01-06 14:51:57 +03:00
```
2025-01-06 01:50:45 +03:00
### Получение количества элементов
Для получения количества элементов в кэше используйте метод **Count** :
```go
2025-01-06 01:54:18 +03:00
count := cache.Count() // Количество элементов в кэше
2025-01-06 01:50:45 +03:00
```
### Получение размера кэша
Для получения размера всего кэша в байтах используйте метод **Size** :
```go
2025-01-06 01:54:18 +03:00
size := cache.Size() // Размер кэша в байтах
2025-01-06 01:50:45 +03:00
```
Данный метод возвращает корректное значение, если в кэше элементы представлены этими типами данных:
```go
bool
int, int8, int16, int32, int64
uint, uint8, uint16, uint32, uint64, uintptr
float32, float64
complex64, complex128
array, slice, string
map, struct, func
```
2025-01-06 01:56:04 +03:00
**И композициями этих типов**.
2025-01-06 01:56:17 +03:00
2025-01-06 14:35:53 +03:00
В противном случае значение может быть не точным.
2025-01-06 14:54:10 +03:00
## Работа с дампами
### Сохранение дампа в файл + восстановление
2025-01-06 14:35:53 +03:00
```go
2025-01-06 14:39:05 +03:00
cache := candycache.Cacher(10 * time.Minute) // Создаем кэш с интервалом очистки 10 минут
cache.Set("key1", "string", 5*time.Minute)
cache.Set("key2", 2, 10*time.Minute)
cache.Set("key7", -2.1231, 10*time.Minute)
cache.Set("key3", []string{"string1", "string2"}, 10*time.Minute)
cache.Set("key4", map[string]int{"a": 1, "b": 2}, 10*time.Minute)
cache.Set("key5", Person{Name: "Alice", Age: 30, Hobbies: []string{"reading", "swimming"}}, 10*time.Minute)
cache.Set("key6", []Person{
{Name: "Bob", Age: 25, Hobbies: []string{"coding", "gaming"}},
{Name: "Charlie", Age: 35, Hobbies: []string{"hiking", "photography"}},
}, 10*time.Minute)
file, err := os.Create("cache_dump.json")
if err != nil {
log.Fatal("error creating file: ", err)
}
if err := cache.Save(file); err != nil { // Сохранение кэша в файл
log.Fatal("error saving cache: ", err)
}
file.Close()
cache.Flush() // Удаление всех элементов из кэша
file, err = os.Open("cache_dump.json")
if err != nil {
log.Fatal("error opening file: ", err)
2025-01-06 14:35:53 +03:00
}
2025-01-06 14:39:05 +03:00
if err := cache.Load(file); err != nil { // Загрузка кэша из файла
fmt.Println("error load cache:", err)
}
list := cache.List() // Получаю список элементов кэша
2025-01-06 14:44:22 +03:00
for _, i := range list {
fmt.Println(i.Key, i.Item.Data(), i.Item.DestroyTimestamp())
}
```
2025-01-06 14:54:10 +03:00
### Сохранение дампа в буффер + восстановление
2025-01-06 14:44:22 +03:00
```go
cache := candycache.Cacher(10 * time.Minute) // Создаем кэш с интервалом очистки 10 минут
cache.Set("key1", "string", 5*time.Minute)
cache.Set("key2", 2, 10*time.Minute)
cache.Set("key7", -2.1231, 10*time.Minute)
cache.Set("key3", []string{"string1", "string2"}, 10*time.Minute)
cache.Set("key4", map[string]int{"a": 1, "b": 2}, 10*time.Minute)
cache.Set("key5", Person{Name: "Alice", Age: 30, Hobbies: []string{"reading", "swimming"}}, 10*time.Minute)
cache.Set("key6", []Person{
{Name: "Bob", Age: 25, Hobbies: []string{"coding", "gaming"}},
{Name: "Charlie", Age: 35, Hobbies: []string{"hiking", "photography"}},
}, 10*time.Minute)
var buffer bytes.Buffer
if err := cache.Save(&buffer); err != nil { // Сохранение бэкапа
log.Fatal("error saving cache: ", err)
}
cache.Set("key1", "lost", 10*time.Minute)
cache.Set("key2", "lost", 10*time.Minute)
cache.Set("key3", "lost", 10*time.Minute)
cache.Set("key4", "lost", 10*time.Minute)
cache.Set("key5", "lost", 10*time.Minute)
cache.Set("key6", "lost", 10*time.Minute)
cache.Set("key7", "lost", 10*time.Minute)
if err := cache.Load(&buffer); err != nil { // Восстановление бэкапа
log.Fatal("error loading cache: ", err)
}
list := cache.List() // Получаю список элементов кэша
2025-01-06 14:39:05 +03:00
for _, i := range list {
fmt.Println(i.Key, i.Item.Data(), i.Item.DestroyTimestamp())
2025-01-06 14:35:53 +03:00
}
```