Django uses redis cache server
Redis I believe everyone is familiar with it. Like memcached, it is a high-performance key-value database. As for what a cache server is, Du Niang has a very clear introduction, so I will not introduce it one by one here.
So under what circumstances do we usually use cache servers? It is not necessary in all situations. Generally speaking, it is only when a field needs to be read frequently that it is necessary to put this field on the cache server. And since key-value databases generally only store very simple data, So be careful when selecting objects to save.
Now I will introduce how to configure and use the redis database in Django. First, install redis. Execute the following command in Ubuntu:
#Install Redis server
sudo apt-get install redis-server
Then in order to be able to To use redis in Django, you also need to install the redis for Django plug-in:
pip install django-redis
This is an open source project, the github address is https://github.com/niwibe/django-redis, thank you to the author.
Then it is now configured in Django settings.
CACHES = { 'default': { 'BACKEND': 'redis_cache.cache.RedisCache', 'LOCATION': '127.0.0.1:6379', "OPTIONS": { "CLIENT_CLASS": "redis_cache.client.DefaultClient", }, }, } REDIS_TIMEOUT=7*24*60*60 CUBES_REDIS_TIMEOUT=60*60 NEVER_REDIS_TIMEOUT=365*24*60*60
In fact, you only need those items in CACHES. The following three sentences are not needed, but they are needed in my later examples, so I configured them here.
Okay, now that the connection and configuration have been completed, how to use it in the project? Let’s look at the following example.
from django.conf import settings from django.core.cache import cache #read cache user id def read_from_cache(self, user_name): key = 'user_id_of_'+user_name value = cache.get(key) if value == None: data = None else: data = json.loads(value) return data #write cache user id def write_to_cache(self, user_name): key = 'user_id_of_'+user_name cache.set(key, json.dumps(user_name), settings.NEVER_REDIS_TIMEOUT)
Through the above two methods, you can realize the reading operation of redis. You only need to pass the required fields as parameters into the method.
So what about memcached mentioned before? In fact, it is the same configuration:
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', } }
Of course, the usage is the same as my example above. In fact, for cache servers like redis, the configuration is very simple, and the specific use is not difficult. There are many simple and clear examples on the official website for our reference. There is only one thing to pay attention to, that is, what to use Saving this kind of information to redis is what we really need to care about.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Solution to permission issues when viewing Python version in Linux terminal When you try to view Python version in Linux terminal, enter python...

How to avoid being detected when using FiddlerEverywhere for man-in-the-middle readings When you use FiddlerEverywhere...

How to teach computer novice programming basics within 10 hours? If you only have 10 hours to teach computer novice some programming knowledge, what would you choose to teach...

When using Python's pandas library, how to copy whole columns between two DataFrames with different structures is a common problem. Suppose we have two Dats...

How does Uvicorn continuously listen for HTTP requests? Uvicorn is a lightweight web server based on ASGI. One of its core functions is to listen for HTTP requests and proceed...

Fastapi ...

Using python in Linux terminal...

Understanding the anti-crawling strategy of Investing.com Many people often try to crawl news data from Investing.com (https://cn.investing.com/news/latest-news)...
