带你逐步深刻了解SSM框架——淘淘商城项目之项目总结


1.  项目总结

总结淘淘商城中用到的技术点:前端

1.1. 项目工程搭建。

一、使用maven构建工程。Maven的继承、聚合、依赖管理。java

二、Svn的使用,svn上传下载代码。linux

1.2. ssm框架整合。

一、mybatis逆向工程。nginx

二、后台管理系统搭建,前台技术使用EasyUI框架。了解easyUI的dategrid的使用方法。面试

1.3. 实现商品添加。

一、商品类目选择。EasyUI的异步tree的使用方法。ajax

二、图片服务器的搭建。使用ftp+http配合,实现图片服务。ftp服务使用vsftpd实现,http服务使用nginx实现。redis

三、KindEditor富文本编辑器的使用方法。sql

1.4. 规格参数实现。

一、规格参数的解决方案。数据库

a)        方案一:建立多个表进行关联实现商品类目。json

b)        方案二:使用模板方式实现。

二、java对象、json之间的转换。

1.5. 前台工程搭建。

一、理解分布式系统架构思想。

二、Jsonp解决ajax跨域调用的问题。

1.6. 第六天:CMS系统的实现

一、CMS系统的实现思路

二、Httpclient的使用方法

三、首页大广告位的实现

1.7. 内容系统添加缓存

一、redis的使用方法及redis集群的搭建

二、系统中添加缓存逻辑

三、缓存的同步方法。

1.8. 搜索功能实现

一、solr服务在linux环境的搭建

二、使用solr实现搜索功能。

三、索引库中商品的同步

1.9. 商品详情页面实现

一、商品详情页面内容异步加载

二、规格参数按需加载

三、商品详情页面添加缓存及缓存同步

1.10.  单点登陆系统实现

一、服务接口的开发

二、在分布式环境中使用redis实现session共享

三、使用cookie在多个系统中共享。

四、拦截器的使用方法

1.11.  购物车、订单

一、使用cookie保存购物车信息

二、建立订单系统。发布服务,支持post请求提交json格式的数据。

三、在用户提交订单以前,检查用户的登陆状态(拦截器)

1.12.  nginx安装、配置

一、nginx的虚拟机的配置

二、Nginx的反向代理

三、Nginx的负载均衡

四、Nginx的高可用

1.13.  solr集群的搭建、系统部署

一、solrCloud的搭建。Zookeeper的配置、solr集群的分片。

二、Mysql数据库在linux环境的安装

三、使用maven进行系统的热部署。

1.14.  项目总结

 

2.  淘淘商城简历中描述

见以前文章。

 

3.  面试中的问题回答

3.1. 淘淘网站并发数:

1000-2000左右并发。

3.2. 人员配置

产品经理:3人,肯定需求以及给出产品原型图。

项目经理:1人,项目管理。

前端团队:5人,根据产品经理给出的原型制做静态页面。

后端团队:20人,实现产品功能。

测试团队:5人,测试全部的功能。

运维团队:3人,项目的发布以及维护。

 

3.3. 开发周期

采用迭代开发的方式进行,通常一次迭代的周期为一个月左右。

 

3.4. 你说你用了redis缓存,你redis存的是什么格式的数据,是怎么存的

redis中存储的都是key-value格式的。拿商品数据来讲,key就是商品id,value是商品相关信息的json数据。

 

3.5. 你前台portal采用4台服务器集群部署,那能前台高并发访问性能提上去了,那数据库会不会形成一个瓶颈,这一块你是怎么处理的?

portal系统在高并发的状况下若是每次请求都请求都查询数据库确实会出现数据库的瓶颈。为了下降数据库压力,在服务层会添加一个缓存,用redis实现,这样的话请求先到缓存中查找是否有缓存的内容,若是有直接从缓存中取数据,若是没有再到数据库中查询。这样数据库的压力就不会那么大了。

 

3.6. 你购物车存cookie里边 能够实现不登陆就可使用购物车 那么我如今没有登陆把商品存购物车了 而后登陆了而后我换台电脑而且登陆了还能不能看见我购物车的信息?若是看不到怎么作到cookie同步,就是在另一台电脑上能够看到购物车信息

回答:

淘淘商城现阶段使用的仅仅是把购物车的商品写入cookie中,这样服务端基本上么有存储的压力。可是弊端就是用户更换电脑后购物车不能同步。打算下一步这么实现:当用户没有登陆时向购物车添加商品是添加到cookie中,当用户登陆后购物车的信息是存储在redis中的而且是跟用户id向关联的,此时你更换电脑后使用同一帐号登陆购物车的信息就会展现出来。

 

3.7. 若是用户一直添加购物车添加商品怎么办?而且他添加一次你查询一次数据库?互联网上用户那么多,这样会对数据库形成很大压力你怎么办?

当前咱们使用cookie的方式来保存购物车的数据,因此当用户往购物车中添加商品时,并不对数据库进行操做。未来把购物车商品放入redis中,redis是能够持久化的能够永久保存,此时就算是频繁的往购物车中添加数据也没用什么问题。

 

4.  电商活动解决方案

4.1. 电商活动倒计时方案:

一、肯定一个基准时间。可使用一个sql语句从数据库中取出一个当前时间。SELECTNOW();

二、活动开始的时间是固定的。

三、使用活动开始时间-基准时间能够计算出一个秒为单位的数值。

四、在redis中设置一个key(活动开始标识)。设置key的过时时间为第三步计算出来的时间。

五、展现页面的时候取出key的有效时间。Ttl命令。使用js倒计时。

六、一旦活动开始的key失效,说明活动开始。

七、须要在活动的逻辑中,先判断活动是否开始。

 

4.2. 秒杀方案:

一、把商品的数量放到redis中。

二、秒杀时使用decr命令对商品数量减一。若是不是负数说明抢到。

三、一旦返回数值是负数说明商品已售完。