Java电商项目-6.实现门户首页数据展示_Redis数据缓存

目录

  • 项目的Github地址
  • 需求介绍
  • 搭建Redis集群环境
    • 下面先描述单机版redis的安装
    • 下面将进行Redis3主3从集群环境搭建
  • 基于SOA架构, 创建门户ashop-portal-web门户项目
  • 实现门户首页商品类目显示
  • 实现门户首页大广告轮播
  • 实现商品类目缓存
  • 实现大广告缓存, 缓存同步
    • 缓存同步

项目的Github地址

需求介绍

  • 为了缩短用户看到首页信息的时间, 我们把首页显示的类目信息, 广告等数据放到Redis缓存中, 这样就不用通过耗时的数据库操作获取数据, 而是直接从Redis缓存中获取.
  • 在开始之前先记录一个坑: 重启虚拟机后nginx服务器关闭了, 导致nginx上的图片无法访问, 当再次启动nginx的时候遇到

  • 进入nginx.conf文件把HTTPS SERVER里面的root注释掉后问题就没有了, 能正常启动.

搭建Redis集群环境

  • 实现Redis 3主3从集群搭建

  • Redis3.0 开始支持集群,在每个 Master 上存放着各不相同的数据,即分布式存储的思想。
    集群中的每个节点都需要知道集群中自己之外的其它节点。
  • Redis 集群主(Master(M1,M2,M3))从(Slave(S1,S2,S3))复制、读写分离 。Master 只负责写和
    同步数据给 Slave,Slave 负责被读的任务,可以通过 Slave 的扩容提高读的速度。

?

下面先描述单机版redis的安装

  • 首先要把redis的安装包上传到虚拟机上.

  • 安装gcc-c++编译器, 输入命令: yum install gcc-c++(我的机器已经安装过了, 第一次安装中途需要输入确定信息)

  • 解压redis安装包: tar zxvf 压缩包名...

  • 进入解压后的文件夹, 输入指令make进行编译, 结果如下

  • 接下来执行安装操作: make PREFIX=/usr/local/redis/ install(PREFIX指定了安装位置)

  • 进入bin目录后就可以登陆redis了. 但是redis有两种启动方式, 默认是前台启动: ./redis-server

  • 使用前台启动的话, 命令行就不能用来输入命令了, 可以按Ctrl + C 强行退出.
  • 然后进入到解压目录, 把解压文件中的redis.conf文件拷贝到安装目录下: cp redis.conf /usr/local/redis/bin

  • 编辑redis.conf: vi redis.conf

  • 重新启动redis: ./redis-server redis.conf(指定配置文件)
  • 查看是否启动: ps -ef | grep -i redis

  • 在防火墙中配置6379端口为打开.

  • 重启防火墙: service iptables restart
  • 测试是否能够连接上redis服务: ./redis-cli

  • 单机安装到这里便告一段落.

?

下面将进行Redis3主3从集群环境搭建

  • 安装集群需要ruby脚本, 先解压ruby脚本tar zxvf 压缩包名

  • 进入解压目录, 执行install.sh

  • 然后创建redis集群相关目录
  1. 首先在/opt目录下创建redis目录

  1. 然后进入redis目录, 在这创建3个集群相关目录: mkdir conf, mkdir logs, mkdir data

  • 其中conf目录用于存放6个redis共用的配置文件
  • 需要将原始的redis.conf配置文件, 拷贝到/opt/redis/conf中, 更名为redis-common
  • 建议如果不熟悉的话在windows下进行配置, 然后在上传到linux中. (该配置文件已经给出, 可以到素材文件夹中获取)

  • 然后进入/usr/local/redis/bin目录中, 加入各个redis的配置文件.

  • 关闭防火墙: service iptables stop
  • 然后启动redis的6个服务. (先把之前启动的单机redis进程kill掉)
  • 然后逐个启动6个服务

  • 接下来要创建集群:(按照自己的ip地址进行修改), 执行目录为redis解压目录下的src目录
  • ./redis-trib.rb create --replicas 1 192.168.117.130:6380 192.168.117.130:6381 192.168.117.130:6382 192.168.117.130:6383 192.168.117.130:6384 192.168.117.130:6385
  • 找到执行这行命令的目录, redis压缩包的解压目录/src: 复制执行上面的命令

  • 下面连接上集群进行测试, 进入/usr/local/redis/bin
  • 输入指令: ./redis-cli -c -p 6380, -c表示集群

  • 这里记录一下redis集群的重启.
  • 重启的参考连接
  • 大致步骤是要把/opt/redis/data 目录下的文件清空, 然后重新启动每个redis服务, 最后创建redis集群.

?

基于SOA架构, 创建门户ashop-portal-web门户项目

  • 在ashop项目下创建war类型子模块ashop-portal-web

  • 接着配置好pom.xml, src/main/resource下的配置文件和web.xml. 这些文件的配置可在源码中获得.
  • 然后把静态资源复制到项目中
  • 接着创建PageController

  • 打包部署项目, 显示出网站首页本阶段完成.

?

实现门户首页商品类目显示

  • 创建远程服务方法:

  • 然后封装回显数据的实体类对象
  • 在ashop-common模块下的beans包中创建CatResult

  • 创建CatNode实体类.

  • 编写web模块的service接口和实现类, 里面涉及到json字符串的封装

  • 编写controller, 这次响应回去的类型是text/html

  • 最后实现这样的效果

?

实现门户首页大广告轮播

  • 远程服务提供者实现

  • 编写封装响应信息的实体类.

  • 编写web模块的service接口及实现类
  • 编写controller

  • 最后打包部署, 能在商品的大广告位看到图片

?

实现商品类目缓存

  • 考虑到商城首页的并发量很大, 如果每个用户的请求都从数据库中查询商品类目效率将会很低. 我们将会用redis把商品类目缓存到内存中, 加快响应速度.
  • 整个逻辑是很好理解的:
  • 如果redis缓存中没有商品类目数据, 就通过调用ashop-rpc远程服务获得数据, 通过处理后保存到redis中, 再返回给用户进行展示.
  • 如果redis缓存中已经缓存了商品类目数据, 就直接返回给客户, 不需要调用ashop-rpc.

?

  • 首先在pom文件中添加依赖

  • 创建applicationContext-redis.xml

  • 在src下创建文件cache.properties, 记录redis中保存商品类目的键, 注意要在上面的spring配置文件中添加context头

  • 接下来修改service实现类中的逻辑

?

实现大广告缓存, 缓存同步

  • 缓存的逻辑和上面商品类目的缓存一样.

缓存同步

  • 使用缓存就肯定要考虑缓存更新的问题. 如果后台更新了数据, 而redis缓存中的数据没有更新, 用户就会获取到非最新数据, 出现脏读.
  • 关于实现缓存与数据库之间的同步, 以下提供两种思路:
  1. 设置key的生命周期, 定期同步数据库.
  2. 当调用远程服务操作数据库后, 同时清空缓存中的内容, 这样当客户访问时服务器将重新到数据库读取数据.

原文地址:https://www.cnblogs.com/tanshaoshenghao/p/10884625.html

时间: 2024-11-07 21:46:36

Java电商项目-6.实现门户首页数据展示_Redis数据缓存的相关文章

Java电商项目面试题(六)

插入商品的话,要求级联插入几张表,你们当时是怎么实现的?通过Redis生成商品编号(ID)保存商品表再保存Sku表(此表中外键,是商品表的ID)在青岛做了两年开发,大大小小参与过三个项目的开发,一个是某公司内部的人员管理系统,一个是物流项目,最近做的是一个电商项目.在整个项目中,我们采用的是nginx+tomcat来部署的(面试官会可能问nginx是谁来部署的?如何部署的?Nginx的执行流程,优点),nginx一方面做加载静态资源的服务器,另一方面来做反向代理和负载均衡.因为该项目需要在多个环

Java电商项目面试题(四)

dubbo服务开发流程,运行流程?zookeeper注册中心的作用?使用流程:第一步:要在系统中使用dubbo应该先搭建一个注册中心,一般推荐使用zookeeper.第二步:有了注册中心然后是发布服务,发布服务需要使用spring容器和dubbo标签来发布服务.并且发布服务时需要指定注册中心的位置.第三步:服务发布之后就是调用服务.一般调用服务也是使用spring容器和dubbo标签来引用服务,这样就可以在客户端的容器中生成一个服务的代理对象,在action或者Controller中直接调用se

Java电商项目面试题(三)

什么是数据库分片简单来说,就是指通过某种特定的条件,将我们存放在同一个数据库中的数据分散存放到多个数据库上面,以达到分散单台设备负载的效果.数据的切分(Sharding)根据其切分规则的类型,可以分为两种切分模式.1.一种是按照不同的表来切分到不同的数据库(主机)之上,这种切可以称之为数据的垂直切分2.另外一种则是根据表中的数据的逻辑关系,将同一个表中的数据按照某种条件拆分到多台数据库上面,这种切分称之为数据的水平切分.如何实现数据库分片当数据库分片后,数据由一个数据库分散到多个数据库中.此时系

java电商项目常见异常

1. java.lang.nullpointerexception 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等.对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,即把数组的初始化和数组元素的初始化混淆起来了.数组的初始化是对数组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,

[18]Java实战项目教程 Java电商项目 服务端实战 基于最新SSM框架 视频源码全[15G]

视频试看链接:https://pan.baidu.com/s/1qY3bQMg 淘宝链接:https://item.taobao.com/item.htm?spm=0.7095261.0.0.534444d0f5tDSg&id=562016685477 总目录: 子文件目录1: 子文件目录2: 视频:

Java电商项目面试题(二)

什么是SolrCloudSolrCloud是Solr提供的分布式搜索方案,当你需要大规模,容错,分布式索引和检索能力时使用SolrCloud.当一个系统的索引数据量少的时候是不需要使用SolrCloud的,当索引量很大,搜索请求并发很高,这时需要使用SolrCloud来满足这些需求.SolrCloud是基于Solr和Zookeeper的分布式搜索方案,它的主要思想是使用Zookeeper作为集群的配置信息中心.它有几个特色功能:1)集中式的配置信息2)自动容错3)近实时搜索4)查询时自动负载均衡

Java企业级电商项目实战 Tomcat集群与Redis分布式

本套课程包含:java电商项目实战课程 Tomcat集群视频教程 Redis项目实战课程课程目录1-1 课程导学1-2 大型Java项目架构演进解析1-3 一期课程与问答服务回顾1-4 一期项目结构和代码回顾1-5 课程使用系统及技术版本介绍(一期+二期)1-6 二期项目初始化第2章 Lombok框架集成及原理解析本章会对Lombok框架进行介绍,同时会讲解Lombok的原理.并手把手领着小伙伴们实战,引入Lombok以及IDE安装Lombok插件.然后会带着大家实战Coding,讲解@Data

java架构师课程、性能调优、高并发、tomcat负载均衡、大型电商项目实战、高可用、高可扩展、数据库架构设计、Solr集群与应用、分布式实战、主从复制、高可用集群、大数据

15套Java架构师详情 * { font-family: "Microsoft YaHei" !important } h1 { background-color: #006; color: #FF0 } 15套java架构师.集群.高可用.高可扩展.高性能.高并发.性能优化.Spring boot.Redis.ActiveMQ.Nginx.Mycat.Netty.Jvm大型分布式项目实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  clo

16套java架构师,高并发,高可用,高性能,集群,大型分布式电商项目实战视频教程

16套Java架构师,集群,高可用,高可扩展,高性能,高并发,性能优化,设计模式,数据结构,虚拟机,微服务架构,日志分析,工作流,Jvm,Dubbo ,Spring boot,Spring cloud, Redis,ActiveMQ,Nginx,Mycat,Netty,Jvm,Mecached,Nosql,Spring,大型分布式项目实战视频教程 视频课程包含: 高级Java架构师包含:架构师,高并发,分布式,集群,高可用,高可扩展,高性能,设计模式,数据结构算法,虚拟机,微服务架构,日志分析,