页面静态化,有两点
- 什么时候去运用页面静态化:就是对于那些数据不经常更新的页面,我们可以对这些页面进行静态化处理
- 页面静态化的好处就是:减少请求次数和提高响应速度,这是执行页面静态化的两个好处。
那么在django当中,如何进行页面静态化?
1.shell方法生成静态文件
2.定时器生成静态文件
3.脚本生成静态文件
4.admin站点方式生成
以上4种方法都是直接或间接调用下面的方法去生成静态文件
def generate_static_index_html():
"""
生成静态的主页html文件
"""
print('%s: generate_static_index_html' % time.ctime())
# 商品频道及分类菜单
# 使用有序字典保存类别的顺序
# categories = {
# 1: { # 组1
# 'channels': [{'id':, 'name':, 'url':},{}, {}...],
# 'sub_cats': [{'id':, 'name':, 'sub_cats':[{},{}]}, {}, {}, ..]
# },
# 2: { # 组2
#
# }
# }
categories = OrderedDict()
channels = GoodsChannel.objects.order_by('group_id', 'sequence')
for channel in channels:
group_id = channel.group_id # 当前组
if group_id not in categories:
categories[group_id] = {'channels': [], 'sub_cats': []}
cat1 = channel.category # 当前频道的类别
# 追加当前频道
categories[group_id]['channels'].append({
'id': cat1.id,
'name': cat1.name,
'url': channel.url
})
# 构建当前类别的子类别
for cat2 in cat1.goodscategory_set.all():
cat2.sub_cats = []
for cat3 in cat2.goodscategory_set.all():
cat2.sub_cats.append(cat3)
categories[group_id]['sub_cats'].append(cat2)
# 广告内容
contents = {}
content_categories = ContentCategory.objects.all()
for cat in content_categories:
contents[cat.key] = cat.content_set.filter(status=True).order_by('sequence')
# 渲染模板
context = {
'categories': categories,
'contents': contents
}
template = loader.get_template('index.html')
html_text = template.render(context)
file_path = os.path.join(settings.GENERATED_STATIC_HTML_FILES_DIR, 'index.html')
with open(file_path, 'w', encoding='utf-8') as f:
f.write(html_text)
shell和脚本命令用得比较少,因为项目要部署到服务器,以后很少自己手动去更新静态文件。而更多是通过定时任务和admin站点的方式。
定时任务:在Django执行定时任务,可以通过django-crontab扩展来实现。
安装
pip install django-crontab
添加应用
INSTALLED_APPS = [
...
'django_crontab', # 定时任务
...
]
设置任务的定时时间
# 定时任务
CRONJOBS = [
# 每5分钟执行一次生成主页静态文件
('*/5 * * * *', 'contents.crons.generate_static_index_html', '>> /Users/delron/Desktop/meiduo_mall/logs/crontab.log')
]
* * * * * 分别代表
分 时 日 月 周
如上面*/5 意思就是每5分钟执行一次,如果在第二个*/3就代表3小时生成一次。
可以通过在配置文件中添加定时任务执行的附加命令来解决非英文字符的错误。
如:‘ascii’ code can't encode characters in psdition 263-266.
# 解决crontab中文问题
CRONTAB_COMMAND_PREFIX = 'LANG_ALL=zh_cn.UTF-8'
开启定时任务
添加定时任务到系统中
python manage.py crontab add
显示已经激活的定时任务
python manage.py crontab show
移除定时任务
python manage.py crontab remove
除了定时任务,还有通过admin站点的save和delete方法,这两种方法,当运营人员运行后台站点,触发保存按钮的时候,会调用admin站点的save方法,当触发删除按钮,会调用admin站点的delete方法,这两个方法在你需要的时候去使用;
而且这两个方法不仅是适用于我们静态化页面生成,在其它使用场景你涉及到保存和删除的情况,你都可以把它们使用起来。
对admin站点,需要管理站点管理模型类的话,需要把管理类和这个模型类进行绑定,绑定之后呢,后台管理类才能调用这个模型类去对模型去进行一系列的操作。
class SKUSpecificationAdmin(admin.ModelAdmin):
def save_model(self, request, obj, form, change):
obj.save()
from celery_tasks.html.tasks import generate_static_sku_detail_html
generate_static_sku_detail_html.delay(obj.sku.id)
def delete_model(self, request, obj):
sku_id = obj.sku.id
obj.delete()
from celery_tasks.html.tasks import generate_static_sku_detail_html
generate_static_sku_detail_html.delay(sku_id)
admin.site.register(models.SKUSpecification, SKUSpecificationAdmin)