[项目] 淘淘商城 Part.1
电商
- 市场
- 2013:79万笔/分钟
- 2014:13.4万亿,双11支付宝交易峰值285万笔/分钟
- 2015:50万亿
 
- 技术特点
- 一个Tomcat:500并发
- 分布式:上万并发
- 高并发、集群、负载均衡、高可用(冗余)
- 海量数据
- 业务复杂
- 系统安全:记录日志
 
- 架构
- Lamp:linux apache mysql php
- 小型机(ibm)+oracle+emc
- 廉价设备+分布式+java+mysql+缓存
 
项目概述
- 技术选型
- 数据库:mysql
- Dao层:mybatis、数据库连接池(德鲁伊druid)
- 缓存:redis
- 搜索:solr
- Service层:spring
- 表现层:springmvc、jstl、EasyUI、jsp、freemaker
- 图片服务器:FastDFS(分布式文件系统)
- 反向代理服务器:nginx
- 定时器:Quartz
- Web服务器:Tomcat
- 工程管理:maven
 
- 分布式架构
- 优点
- 把模块拆分,使用接口通信,降低模块之间耦合度
- 把项目拆分成若干子项目,不同团队负责不同子项目
- 增加功能时只需增加一个子项目,调用其他系统的接口即可
- 可灵活地进行分布式部署
 
- 缺点
- 系统间需要远程通信,接口开发增加工作量
 
 
- 优点
- 人员配置
- 产品经理:3人,做什么(需求)
- 项目经理:1人,怎么做
- 前端:5人,静态页面
- 后端:20人,实现功能
- 测试:5人
- 运维:3人,发布及维护
 

后台搭建
- 使用maven管理工程
- 创建聚合工程,每个模块都是一个jar包,可被其他系统依赖
- Taotao-parent
- 打包方式为pom
- pom文件中添加项目用到的所有jar包版本
 
- Taotao-common
- 打包方式为jar包
 
- Taotao-manager
- 打包方式为pom
 
- taotao-manager-pojo
- 打包方式为jar
 
- taotao-manager-dao
 - 打包方式为jar
- 依赖mybatis
 
- taotao-manager-service
 - 打包方式为jar
- 依赖Taotao-manager-dao
- 依赖spring
 
- taotao-manager-web
- 打包方式为war
- 依赖Taotao-manager-service
 
- Tomcat插件
- 在聚合工程中添加
- 将Taotao-parent、Taotao-common安装到本地仓库
 

svn使用
- VisualSVN Server
- 上传到svn,忽略setting文件夹,和.classpath,.project文件
- 下载后需转换成maven项目,使用导入“存在的maven工程”导入Eclipse
ssm框架整合
- Dao层
- 整合mybatis和spring
- jar包
 - mybatis的jar包
- Mysql数据库驱动
- 数据库连接池
- Mybatis和spring的整合包
- Spring的jar包
 - 配置文件
 - mybatis的配置文件
- Spirng的配置文件
 - 数据库连接池
- SqlSessionFactory
- mapper文件扫描器
 
 
 
- 整合mybatis和spring
- Service层
- spring的jar包
- 配置文件:applicationContext-service.xml
- 配置包扫描器,扫描所有带@Service注解的类
 
- 事务配置
- 配置文件:applicationContext-trans.xml 
- 事务管理器
- 配置tx
- 配置切面
 
 
- 配置文件:applicationContext-trans.xml 
 
- spring的jar包
- 表现层
- springmvc
- 配置文件:springmvc.xml
- 配置注解驱动
- 配置视图解析器
- 包扫描器,@Controller注解
 
- Web.xml
- Springmvc的前端控制器
- Spring容器初始化的listener
 
 
测试框架
- 需求
- 根据id查询商品信息,返回json数据
 
- 实现  
- DAO层:查询tb_item,根据商品id查询,可用逆向工程生成的代码
- Service层:接收商品id,调用mapper查询商品信息,返回商品的pojo
- Controller层:接收商品id,调用Service返回一个商品的pojo,直接响应pojo,需返回json,使用@ResponseBody
 
[项目] 淘淘商城 Part.1的更多相关文章
- 001淘淘商城项目:项目的Maven工程搭建
		开始一个新的项目,特此记录,资料全部来源于传智播客,感谢. 我们要做一个类似电商的项目.用maven做管理. maven里面主要分为三种工程: 1:pom工程:用在父级工程,聚合工程中 2:war工程 ... 
- 【原】从零开始改造淘淘商城(引入dubbo解决项目耦合)02
		前言: 关于为什么要引入dubbo框架,而不是用spring cloud或者是motan呢,主要是笔者现在公司用的就是dubbo,并且第一次接触到微服务的概念是来源于dubbo,再加上最近dubbo频 ... 
- day78_淘淘商城项目_11_单点登录系统实现 + 用户名回显 + ajax请求跨域问题详解_匠心笔记
		课程计划 1.SSO注册功能实现 2.SSO登录功能实现 3.通过token获得用户信息 4.ajax跨域请求解决方案--jsonp 1.服务接口实现 SSO系统就是解决分布式环境下登录问题的,本 ... 
- day68_淘淘商城项目_01
		原文:day68_淘淘商城项目_01 课程计划 第一天: 1.电商行业的背景介绍--电子商务 2.淘淘商城的系统架构 a) 功能介绍 b) 架构讲解 3.工程搭建--后台工程 a) 使用maven搭建 ... 
- day68_淘淘商城项目_01_电商介绍 + 互联网术语 + SOA + 分布式 + 集群介绍 + 环境配置 + 框架搭建_匠心笔记
		课程计划 第一天: 1.电商行业的背景介绍--电子商务 2.淘淘商城的系统架构 a) 功能介绍 b) 架构讲解 3.工程搭建--后台工程 a) 使用maven搭建工程(工程大) b) 使用maven的 ... 
- 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第二天】
		淘淘商城(SpringMVC+Spring+Mybatis) 是传智播客在2015年9月份录制的,几年过去了.由于视频里课上老师敲的代码和项目笔记有些细节上存在出入,只有根据日志报错信息作出适当的调 ... 
- 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第一天】
		本人做过一年的MATLAB编程和简单维护过VB和C++的项目.是跟着网上获得的黑马的Java双元视频课来自学入门Java知识和常用框架的使用. 淘淘商城(SpringMVC+Spring+Mybati ... 
- ZZJ_淘淘商城项目:day01(RESTful Web Service、SVN)
		淘淘商城项目是很适合初级Java程序员练习的实战项目,本次复习是另一位张老师教授的课,内容上与之前入老师版taotao商城比较有些新东西加了进来. 因此有必要记录下那些直到现在还可供参考的技术亮点分享 ... 
- 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十二天】(系统架构讲解、nginx)
		https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ... 
- 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十一天】(购物车+订单)
		https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ... 
随机推荐
- Spring Boot  MVC 单张图片和多张图片上传 和通用文件下载
			@Autowired private ServerConfig serverConfig; /** * 通用下载请求 * * @param fileName 文件名称 * @param delete ... 
- PAT (Basic Level) Practice (中文)1070 结绳 (25 分) 凌宸1642
			PAT (Basic Level) Practice (中文)1070 结绳 (25 分) 凌宸1642 题目描述 给定一段一段的绳子,你需要把它们串成一条绳.每次串连的时候,是把两段绳子对折,再如下 ... 
- Etcd常用运维命令
			目录 常用命令 常见操作 如何缩容? 如何扩容? 数据目录丢失或被误删除,节点启动失败或者加入集群报错? 操作步骤 操作步骤不正确的各种常见错误日志 常用命令 #查看集群member情况 etcdct ... 
- Kafka 常见问题汇总
			Kafka 常见问题汇总 1. Kafka 如何做到高吞吐.低延迟的呢? 这里提下 Kafka 写数据的大致方式:先写操作系统的页缓存(Page Cache),然后由操作系统自行决定何时刷到磁盘. 因 ... 
- HCL实验8:NAT搭建私有网络
			NAT 通过NAT技术,进行私有网络的搭建 拓扑图 先对路由器的端口进行配置 R1 [H3C]sys R1 [R1]INT G0/0 [R1-GigabitEthernet0/0]ip address ... 
- Crackme_003
			功能: 拿到文件,先执行一下.功能如下: 1.nag窗口 会先出现如下nag窗口,持续几秒 2.注册窗口: 出现错误会提示:You Get Wrong Try Again 破解: 1.查壳: 无壳, ... 
- 自动化kolla-ansible部署ubuntu20.04+openstack-victoria之替换logo-13
			自动化kolla-ansible部署ubuntu20.04+openstack-victoria之替换logo-13 欢迎加QQ群:1026880196 进行交流学习 替换 openstack das ... 
- WERTYU UVA - 10082
			 A common typing error is to place the hands on the keyboard one row to the right of the correct po ... 
- JAVAEE_Servlet_17_关于乱码问题
			关于乱码问题 * 数据传递过程中的乱码 解释:数据传递过程中的乱码是指: 将数据从浏览器发送给服务器的时候,服务器接收到的数据是乱码的. - ISO-8859-1 是国际标准码,不支持中文编码,它兼容 ... 
- Day14_75_反射(reflect)
			反射 反射的基本概念 反射是由Smith在1982年首次提出,主要是指程序可以访问,检测,修改它本身状态或行为的一种能力.并且能够根据自身行为的状态或结果,调整和修改所描述行为的状态和相关语义. ja ... 
