# 优化获取device_name 性能

This commit is contained in:
xianfuxing 2020-06-02 15:48:48 +08:00
parent 39307f3fe8
commit a7da7e4b5f
2 changed files with 10 additions and 6 deletions

View File

@ -1,7 +1,5 @@
import pytz
from django.db.models import Q from django.db.models import Q
from datetime import datetime, time from django.core.cache import cache
from django.db.models import Sum
from rest_framework import serializers from rest_framework import serializers
from counter.models import DeviceCount, DeviceInfo from counter.models import DeviceCount, DeviceInfo
from mosquito.models import DeviceInfo as CelexDeviceInfo from mosquito.models import DeviceInfo as CelexDeviceInfo
@ -42,10 +40,16 @@ class DeviceCountSerializer(serializers.ModelSerializer):
return obj.data_time.strftime('%Y-%m-%d %H:%M:%S') return obj.data_time.strftime('%Y-%m-%d %H:%M:%S')
def get_device_name(self, obj): def get_device_name(self, obj):
qs = CelexDeviceInfo.objects.filter(device_id=obj.device_id) device_id = obj.device_id
cache_content = cache.get(device_id)
if cache_content:
return cache_content
qs = CelexDeviceInfo.objects.filter(device_id=device_id)
if qs.count() > 0: if qs.count() > 0:
device = qs[0] device = qs[0]
return device.device_name device_name = device.device_name
cache.set(device_id, device_name, 60 * 60 * 24)
return device_name
return None return None

View File

@ -13,7 +13,7 @@ class RoleMixin(object):
class DeviceListMixin(object): class DeviceListMixin(object):
@staticmethod @staticmethod
def get_device_list(): def get_device_list():
if cache.has_key('device_list'): if cache.get('device_list'):
device_list = cache.get('device_list') device_list = cache.get('device_list')
else: else:
device_list = DeviceInfo.objects.get_queryset().order_by('-online') device_list = DeviceInfo.objects.get_queryset().order_by('-online')