Home  >  Article  >  Backend Development  >  Django uses redis cache server

Django uses redis cache server

高洛峰
高洛峰Original
2016-10-17 13:51:101391browse

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.


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn