>백엔드 개발 >Golang >캐시 구현 golang

캐시 구현 golang

WBOY
WBOY원래의
2023-05-21 19:58:06525검색

웹사이트나 애플리케이션을 개발하는 동안 페이지에 로드해야 하는 다양한 데이터와 리소스가 있을 수 있으며, 그 중 일부는 자주 요청됩니다. 이 경우 요청이 있을 때마다 데이터베이스를 쿼리하거나 리소스를 다시 가져오면 웹 사이트나 애플리케이션의 응답 속도가 느려질 수 있습니다. 이 문제를 해결하기 위해 캐싱 기술을 사용할 수 있습니다. 이번 글에서는 Golang에서 캐싱을 구현하는 방법을 소개하겠습니다.

Golang의 캐싱

Golang에는 "sync"라는 패키지가 있습니다. 이 패키지에는 "Map" 유형의 지도 동시성 안전 구현이 포함되어 있습니다. 이 맵을 사용하여 캐싱 기능을 구현할 수 있습니다.

다음은 Golang에서 캐싱을 구현하는 기본 단계입니다.

  1. 전역 변수 정의

캐시된 데이터를 저장하기 위해 전역 Map 변수를 정의할 수 있습니다. 이 맵에서는 문자열을 "키"로 사용할 수 있고 모든 유형의 변수를 "값"으로 사용할 수 있습니다.

var cache = struct {
    sync.RWMutex
    items map[string]interface{}
}{
    items: make(map[string]interface{}),
}

위 코드에서 sync.RWMutex 구조는 캐시 작업이 스레드로부터 안전한지 확인하는 데 사용됩니다. 동시에 make 함수를 사용하여 빈 맵을 생성합니다.

  1. 캐시에 데이터 추가
func Set(key string, value interface{}, exp time.Duration) {
    cache.Lock()
    defer cache.Unlock()
    cache.items[key] = value
    if exp > 0 {
        time.AfterFunc(exp, func() {
            expire(key)
        })
    }
}

위 코드에서는 "Lock" 메서드를 사용하여 동시에 여러 고루틴에 액세스하는 캐시로부터 안전한지 확인합니다. 그런 다음 캐시에 키-값 쌍을 추가했습니다. 여기서 "key"는 캐시된 키이고 "value"는 캐시된 값입니다. 마지막으로 "time.AfterFunc" 함수를 사용하여 캐시 시간을 설정합니다. 캐시가 만료되면 "expire" 메소드가 자동으로 호출되어 캐시를 삭제합니다.

  1. 캐시에서 데이터 읽기
func Get(key string) (interface{}, bool) {
    cache.RLock()
    defer cache.RUnlock()
    val, ok := cache.items[key]
    return val, ok
}

위 코드에서는 동시에 액세스하는 여러 고루틴이 캐시된 데이터를 자유롭게 읽을 수 있도록 "RLock" 메서드를 사용하여 캐시를 잠급니다. 그런 다음 캐시에서 해당 키-값 쌍을 검색합니다. "val"은 검색된 값이고 "ok"는 캐시가 성공적으로 검색되었는지 여부를 나타냅니다.

  1. 캐시에서 데이터 제거
func Delete(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}

위 코드에서는 "Lock" 메서드를 사용하여 동시에 액세스하는 여러 고루틴에 대해 캐시가 안전한지 확인합니다. 그런 다음 캐시에서 해당 키-값 쌍을 삭제합니다.

샘플 코드

위 단계에 따라 간단한 캐시 구현을 작성할 수 있으며 코드는 다음과 같습니다.

package main

import (
    "fmt"
    "sync"
    "time"
)

var cache = struct {
    sync.RWMutex
    items map[string]interface{}
}{
    items: make(map[string]interface{}),
}

func Set(key string, value interface{}, exp time.Duration) {
    cache.Lock()
    defer cache.Unlock()
    cache.items[key] = value
    if exp > 0 {
        time.AfterFunc(exp, func() {
            expire(key)
        })
    }
}

func Get(key string) (interface{}, bool) {
    cache.RLock()
    defer cache.RUnlock()
    val, ok := cache.items[key]
    return val, ok
}

func Delete(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}

func expire(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}

func main() {
    Set("key", "value", time.Second*10)

    val, ok := Get("key")
    if ok {
        fmt.Println(val)
    } else {
        fmt.Println("Value not found")
    }

    Delete("key")
}

위 예에서는 Set 메서드를 사용하여 캐시에 키-값 쌍을 추가하고 캐시 시간을 설정하세요. 그런 다음 Get 메서드를 사용하여 캐시에서 저장된 값을 읽습니다. 마지막으로 삭제 메서드를 사용하여 저장된 키-값 쌍을 삭제합니다.

결론

이 글에서는 Golang에서 캐싱을 구현하기 위해 Sync 패키지를 사용하는 방법을 소개했습니다. 이 방법을 사용하면 데이터 운영 효율성을 높이고 불필요한 데이터베이스 쿼리를 줄일 수 있습니다. 이 기사가 Golang에서 캐싱이 구현되는 방법을 더 잘 이해하는 데 도움이 되기를 바랍니다.

위 내용은 캐시 구현 golang의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:골랭 상속 방법다음 기사:골랭 상속 방법