Dengan perkembangan Internet, caching pelayan web telah menjadi salah satu cara penting untuk meningkatkan prestasi aplikasi web. Dalam pembangunan sebelum ini, kami terutamanya menggunakan beberapa perisian tengah caching khusus seperti Memcached dan Redis Walau bagaimanapun, kini kami boleh menggunakan perpustakaan konkurensi Golang sendiri untuk melaksanakan caching pelayan web untuk menyelesaikan masalah prestasi beberapa aplikasi berskala kecil. Artikel ini akan memberi tumpuan kepada cara menggunakan Golang untuk melaksanakan caching pelayan web.
Golang mempunyai banyak perpustakaan concurrency, termasuk penyegerakan, saluran, konteks dan perpustakaan lain yang biasa digunakan. Antaranya, yang paling biasa digunakan ialah Mutex dan RWMutex yang disediakan dalam perpustakaan penyegerakan. Mutex ialah jenis kunci yang paling asas, yang hanya boleh dipegang oleh satu goroutine pada masa yang sama Menggunakannya boleh memastikan keselamatan berbilang goroutine secara serentak mengakses sumber yang dikongsi. RWMutex ialah kunci baca-tulis berdasarkan Mutex, yang boleh mengehadkan bilangan gorout yang membaca sumber pada masa yang sama dan meningkatkan kecekapan membaca serentak.
Seterusnya, kami akan mengikuti langkah berikut untuk melaksanakan cache pelayan web:
2.1 Buat struktur cache Badan
Kami boleh menggunakan RWMutex dalam pustaka penyegerakan untuk melaksanakan struktur cache selamat serentak, di mana peta digunakan sebagai struktur storan cache. Pelaksanaan khusus adalah seperti berikut:
type Cache struct { cache map[string]interface{} rw sync.RWMutex } func NewCache() *Cache { return &Cache{ cache: make(map[string]interface{}), } }
2.2 Pelaksanaan fungsi operasi cache
Laksanakan fungsi operasi asas cache, seperti Dapatkan, Tetapkan, Padam, dsb. Antaranya, kami menggunakan RWMutex untuk memastikan keselamatan capaian serentak cache.
func (c *Cache) Get(key string) (interface{}, bool) { c.rw.RLock() defer c.rw.RUnlock() item, ok := c.cache[key] return item, ok } func (c *Cache) Set(key string, value interface{}) { c.rw.Lock() defer c.rw.Unlock() c.cache[key] = value } func (c *Cache) Delete(key string) { c.rw.Lock() defer c.rw.Unlock() delete(c.cache, key) }
2.3 Pemprosesan Tamat Tempoh Cache
Data dalam cache wujud untuk tempoh masa yang berbeza Kami boleh menetapkan masa cache untuk memastikan kesegaran data cache dengan memadamnya secara kerap. Untuk melakukan ini, kita perlu menggunakan goroutine untuk memadam data cache yang telah tamat tempoh secara berkala.
func (c *Cache) deleteExpired() { for { time.Sleep(time.Second * 30) c.rw.Lock() for key, value := range c.cache { item, ok := value.(*item) if ok && item.expired.Before(time.Now()) { delete(c.cache, key) } } c.rw.Unlock() } } type item struct { data interface{} expired time.Time } func (c *Cache) SetWithExpiration(key string, value interface{}, expiration time.Duration) { item := &item{ data: value, expired: time.Now().Add(expiration), } c.rw.Lock() defer c.rw.Unlock() c.cache[key] = item } func NewCache() *Cache { c := &Cache{ cache: make(map[string]interface{}), } go c.deleteExpired() return c }
Artikel ini memperkenalkan cara menggunakan perpustakaan konkurensi Golang sendiri untuk melaksanakan caching pelayan web. Dengan melaksanakan fungsi operasi asas cache dan goroutine yang memadamkan data cache yang telah tamat tempoh secara berkala, kami boleh membina cache pelayan web yang ringan sendiri untuk menyelesaikan masalah prestasi aplikasi berskala kecil. Pada masa yang sama, kami juga boleh mempelajari kaedah asas menggunakan perpustakaan serentak Golang, yang akan membantu kami memanfaatkan kelebihan prestasi serentak Golang dengan lebih baik dalam pembangunan masa hadapan.
Atas ialah kandungan terperinci Cara menggunakan Golang untuk melaksanakan caching pelayan web. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!