首页 > 其他分享 >电商项目-网站首页高可用(二)

电商项目-网站首页高可用(二)

时间:2024-12-23 23:42:11浏览次数:8  
标签:index ad 可用 -- 步骤 redis lua 首页 电商

  一、LUA基本语法


  lua有交互式编程和脚本式编程。

  交互式编程就是直接输入语法,就能执行。

  脚本式编程需要编写脚本文件,然后再执行。

  一般采用脚本式编程。(例如:编写一个hello.lua的文件,输入文件内容,并执行lua hell.lua即可)

1.1.1 lua注释
  单行注释:两个减号是单行注释:

--   单行注释

 



  多行注释:

--[[
多行注释
多行注释
--]]

 

  1.1.2关键字

  关键字就好比java中的 break if else等等一样的效果。lua的关键字如下:

    
and break do else
elseif end false for
function if in local
nil not or repeat
return then true until
while      

 

  1.1.3 定义变量


全局变量,默认的情况下,定义一个变量都是全局变量,

如果要用局部变量 需要声明为local.例如:

-- 全局变量赋值
a=1
-- 局部变量赋值
local b=2 


如果变量没有初始化:则 它的值为nil 这和java中的null不同。

 

1.1.4 Lua中的数据类型


Lua 是动态类型语言,变量不要类型定义,只需要为变量赋值。 值可以存储在变量中,作为参数传递或结果返回。

Lua 中有 8 个基本类型分别为:nil、boolean、number、string、userdata、function、thread 和 table。

数据类型描述
nil 这个最简单,只有值nil属于该类,表示一个无效值(在条件表达式中相当于false)。
boolean 包含两个值:false和true。
number 表示双精度类型的实浮点数
string 字符串由一对双引号或单引号来表示
function 由 C 或 Lua 编写的函数
userdata 表示任意存储在变量中的C数据结构
thread 表示执行的独立线路,用于执行协同程序
table Lua 中的表(table)其实是一个"关联数组"(associative arrays),数组的索引可以是数字、字符串或表类型。在 Lua 里,table 的创建是通过"构造表达式"来完成,最简单构造表达式是{},用来创建一个空表。


  1.1.5 流程控制


如下:类似于if else

--[ 0 为 true ]
if(0) then
    print("0 为 true")
else
    print("0 不为true")
end

 


  1.1.6 函数
lua中也可以定义函数,类似于java中的方法。例如:

--[[ 函数返回两个值的最大值 --]]
function max(num1, num2)
​
   if (num1 > num2) then
      result = num1;
   else
      result = num2;
   end
​
   return result; 
end
-- 调用函数
print("两值比较最大值为 ",max(10,4))
print("两值比较最大值为 ",max(5,6))

 


执行之后的结果:

两值比较最大值为     10
两值比较最大值为     6

 


  1.1.7 require 函数
require 用于 引入其他的模块,类似于java中的类要引用别的类的效果。

用法:

require "<模块名>"

 


  二、nginx+Lua+redis实现广告缓存


2.1 表结构分析
操作shangcheng_business 数据库的 tb_ad (广告表)

 

字段名称字段含义字段类型字段长度备注
id ID INT    
name 广告名称 VARCHAR    
position 广告位置 VARCHAR   系统定义
start_time 开始时间 DATETIME    
end_time 到期时间 DATETIME    
status 状态 CHAR   0:无效 1:有效
image 图片地址 VARCHAR    
url URL VARCHAR    
remarks 备注 VARCHAR    
web_index_lb 首页轮播图      
web_index_amusing 有趣区      
web_index_ea_lb 家用电器楼层轮播图      
web_index_ea 家用电器楼层广告      
web_index_mobile_lb 手机通讯楼层轮播图      
web_index_mobile 手机通讯楼层广告      


  2.2 缓存预热与二级缓存查询
步骤一:编写lua脚本实现缓存预热(将mysql里的数据查询出来存入redis)

 

 

步骤二:编写lua脚本实现二级缓存读取

 

 

  2.3.1 缓存预热


  实现步骤:

定义请求:用于查询数据库中的数据更新到redis中。

(1)连接mysql ,按照广告分类ID读取广告列表,转换为json字符串。

(2)连接redis,将广告列表json字符串存入redis 。

定义请求:

请求:
    /ad_update
参数:
    position  --指定广告位置
返回值:
    json

 


  步骤一:在/root/lua目录下创建ad_load.lua ,实现连接mysql 查询数据 并存储到redis中。

  步骤二:修改/usr/local/openresty/nginx/conf/nginx.conf文件:

代码如下:

 

#user  nobody;
user root root;
worker_processes  1;
​
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
​
#pid        logs/nginx.pid;
​
events {
    worker_connections  1024;
}
​
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    #tcp_nopush     on;
​
    #keepalive_timeout  0;
    keepalive_timeout  65;
​
    #gzip  on;
​
    server {
        listen       80;
        server_name  localhost;
        charset utf-8;
        #access_log  logs/host.access.log  main;
        # 添加
        location /ad_update {
            content_by_lua_file /root/lua/ad_update.lua;
        }
        
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }        
    }
}

 

 

步骤三:测试

重新启动nginx

测试:http://192.168.200.128/ad_update?position=web_index_lb

查看redis客户端

 

  2.3.2 广告缓存读取
实现步骤:

通过lua脚本直接从redis中获取数据即可。

定义请求:

请求:/ad_read
参数:position
返回值:json

 


步骤一:在/root/lua目录下创建ad_read.lua

步骤二:在/usr/local/openresty/nginx/conf/nginx.conf中server下添加配置

location /ad_read {
  content_by_lua_file /root/lua/ad_read.lua;
}

 


步骤三:测试

测试 http://192.168.200.128/ad_read?position=web_index_lb 输出:

[{"url":"img\/banner1.jpg","image":"img\/banner1.jpg"},
{"url":"img\/banner2.jpg","image":"img\/banner2.jpg"}]

 


  2.4 二级缓存(openresty本地缓存)


  如上的方式没有问题,但是如果请求都到redis,redis压力也很大,所以我们一般采用多级缓存的方式来减少下游系统的服务压力。

  先查询openresty本地缓存 如果没有再查询redis中的数据

  步骤一:修改/root/lua目录下ad_read文件, 内容如下:

  步骤二:修改nginx配置文件vi /usr/local/openresty/nginx/conf/nginx.conf ,http节点下添加配置:

#包含redis初始化模块
lua_shared_dict dis_cache 5m;  #共享内存开启

 


  2.5前端页面实现


步骤一:修改index.html,编写脚本

<script>
       new Vue({
        el: '#app',
        data: {
            ad: {
                web_index_lb:[]
            }
        },
        methods: {
            adRead: function(position) {
                axios.get('ad_read?position='+position).then(response =>{
                    this.ad[position]=response.data                 
                })
            }
        },
        created(){
            this.adRead('web_index_lb')
        }
      })
</script>

 

 

步骤二:修改index.html,渲染广告轮播图

<div id="myCarousel" data-ride="carousel" data-interval="4000" class="sui-carousel slide">
    <ol class="carousel-indicators">
        <li data-target="#myCarousel" data-slide-to="0" class="active" v-for="item in ad.web_index_lb"></li>
    </ol>
    <div class="carousel-inner" id="lbt">
        <div class="item" v-for="item in contentList">
            <a :href="item.url">
            <img :src="item.pic"  />
          </a>
        </div>      
    </div>
    <a href="#myCarousel" data-slide="prev" class="carousel-control left">‹</a>
    <a href="#myCarousel" data-slide="next" class="carousel-control right">›</a>
</div>

 


步骤三:上传至服务器并测试

更改配置:

# 加载首页
        location / {
            root   html;
            index  index.html index.htm;
        }

 

标签:index,ad,可用,--,步骤,redis,lua,首页,电商
From: https://www.cnblogs.com/kongsq/p/18625302

相关文章

  • 电商项目-网站首页高可用(一)
    一、Nginx简介Nginx是一个高性能的http服务器。一个单机的tomcat,理论上最多只能承载500个并发,对于首页来说用户的访问频率高,因此并发量大,一个单机tomcat无法承受网站首页的并发访问量,最终导致当前服务的崩溃。对于一个tomcat集群来说,集群内部最多只能有5台tomc......
  • 【电商搜索】CRM: 具有可控条件的检索模型
    【电商搜索】CRM:具有可控条件的检索模型目录文章目录【电商搜索】CRM:具有可控条件的检索模型目录文章信息摘要研究背景问题与挑战如何解决核心创新点算法模型实验效果(包含重要数据与结论)相关工作后续优化方向后记https://arxiv.org/pdf/2412.13844文章信息......
  • 【电商搜索】文档的信息论生成聚类
    【电商搜索】文档的信息论生成聚类目录文章目录【电商搜索】文档的信息论生成聚类目录文章信息概览研究背景技术挑战如何破局技术应用主要相关工作与参考文献后续优化方向后记文章信息https://arxiv.org/pdf/2412.13534概览本文提出了一种基于信息论的生成......
  • 电商项目-数据同步解决方案(一)
    一、canal简介canal是阿里旗下的开源项目,其内部是基于java开发。主要作用是用于监控数据库内部数据的改变。从而获得新增数据,或者修改的数据。canal主要支持mysql数据库。canal是应对阿里巴巴存在杭州和美国的双机房部署,存在跨机房同步的业务需求......
  • node.js基于协同过滤算法的居民健康生活引导系统的设计与实现程序+论文 可用于毕业设
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容一、选题背景关于居民健康生活引导的研究,现有研究主要以健康生活方式的推广、健康意识的提升等宏观层面为主。在健康引导的技术实现方面,多集中于简单的信息推送系统,......
  • keepalived的高可用集群
    keepalived的概念keepalived的工作原理基于vrrp实现的调度器高可用方案keepalived的配置实验先在调度服务器上安装keepalived和ipvsadmapt-yinstallkeepalivedipvsadm复制keepalived的配置文件到/etc/keepalived/目录下cp/usr/share/doc/keepalived/samples......
  • 从复盘到优化,电商团队如何破局?
    敏捷的复盘文化是现代电商团队提升竞争力的关键。无论是小型活动还是全年大促,复盘不仅是发现问题的工具,更是团队内部持续进化的核心能力。在线文档编辑与协同工具的应用,为电商团队在这一过程中提供了新的解决方案。电商复盘文化为何重要?1.数据驱动决策:活动过程中会产生大量数据......
  • Redis高可用部署
    Redis常见架构Redis实现高可用有三种部署模式:主从模式,哨兵模式,集群模式。主从模式主从模式中,Redis部署了多台机器,主节点负责读写操作,从节点只负责读操作。从节点的数据来自主节点,实现原理就是主从复制机制。主从复制包括全量复制,增量复制两种。一般当slave第一次启动连接ma......
  • 数据到行动:电商复盘文化的深度剖析
    电商团队如何用协同工具优化活动复盘效率在电商行业中,团队复盘是每次活动后提升战斗力的重要环节。但由于活动节奏快、涉及面广,传统的复盘流程往往效率低下。近年来,越来越多的电商团队开始依赖在线文档编辑与协同工具,极大地提升了复盘的效率和质量。高效复盘的痛点:1.信息分散:......
  • 轻松解决首页白屏问题
    解决首页白屏问题:基于Nuxt2和无界微前端的优化方案前言在当今的Web开发中,首页的加载速度是影响用户体验的一个关键因素。用户在访问网站时,通常期望能在几秒钟内看到可交互的页面内容,而如果页面的加载时间过长,特别是出现白屏的现象,可能会导致用户流失,严重影响转化率。为......