django キャッシュのメモリ内データベース バックエンドとして redis を使用しています。
特に、次のように構成されたdjango-redisを使用します。
CACHES = {
'default': {
'BACKEND': 'redis_cache.cache.RedisCache',
'KEY_PREFIX': DOMAIN_NAME,
'LOCATION': 'unix:/tmp/redis_6379.sock:1',
'OPTIONS': {
'PICKLE_VERSION': -1, # default
'PARSER_CLASS': 'redis.connection.HiredisParser',
'CLIENT_CLASS': 'redis_cache.client.DefaultClient',
},
},
}
私の django キャッシュは正しく動作しているようです。
redis-cli
奇妙なことは、コマンド ラインを使用して django キャッシュ キーを確認できないことです。
[編集] 以下で、両方を試したことに注意してください
$ redis-cli
と
$ redis-cli -s /tmp/redis_6379.sock
[編集]
違いはありません。
特に、次のKEYS *
コマンドを使用します。
$ redis-cli
redis 127.0.0.1:6379> keys *
(empty list or set)
しかし
redis 127.0.0.1:6379> set stefano test
OK
redis 127.0.0.1:6379> keys *
1) "stefano"
Djangoシェルから:
In [1]: from django.core.cache import cache
In [2]: cache.keys('*')
Out[2]:
[u'django.contrib.sessions.cachebblhwb3chd6ev2bd85bawuz7g6pgaij8',
u'django.contrib.sessions.cachewpxiheosc8qv5w4v6k3ml8cslcahiwna']
CLIで使用MONITOR
している場合:
redis 127.0.0.1:6379> monitor
OK
1373372711.017761 [1 unix:/tmp/redis_6379.sock] "KEYS" "project_prefix:1:*"
django キャッシュ プレフィックスを使用して、リクエストを確認できます。これにより、redis-cli が同じサービスに接続されていることが証明されます。しかし、でそのプレフィックスを検索してもredis-cli
、(empty list or set)
何故ですか?
同じ redis インスタンスで異なるキャッシュを区分化するメカニズムは何ですか?