电商

  • 市场

    • 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包
      1. mybatis的jar包
      2. Mysql数据库驱动
      3. 数据库连接池
      4. Mybatis和spring的整合包
      5. Spring的jar包
      • 配置文件
      1. mybatis的配置文件
      2. Spirng的配置文件
        • 数据库连接池
        • SqlSessionFactory
        • mapper文件扫描器
  • Service层
    • spring的jar包

      • 配置文件:applicationContext-service.xml
      • 配置包扫描器,扫描所有带@Service注解的类
    • 事务配置
      • 配置文件:applicationContext-trans.xml 
        1. 事务管理器
        2. 配置tx
        3. 配置切面 
  • 表现层
    • 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的更多相关文章

  1. 001淘淘商城项目:项目的Maven工程搭建

    开始一个新的项目,特此记录,资料全部来源于传智播客,感谢. 我们要做一个类似电商的项目.用maven做管理. maven里面主要分为三种工程: 1:pom工程:用在父级工程,聚合工程中 2:war工程 ...

  2. 【原】从零开始改造淘淘商城(引入dubbo解决项目耦合)02

    前言: 关于为什么要引入dubbo框架,而不是用spring cloud或者是motan呢,主要是笔者现在公司用的就是dubbo,并且第一次接触到微服务的概念是来源于dubbo,再加上最近dubbo频 ...

  3. day78_淘淘商城项目_11_单点登录系统实现 + 用户名回显 + ajax请求跨域问题详解_匠心笔记

    课程计划 1.SSO注册功能实现 2.SSO登录功能实现 3.通过token获得用户信息 4.ajax跨域请求解决方案--jsonp 1.服务接口实现   SSO系统就是解决分布式环境下登录问题的,本 ...

  4. day68_淘淘商城项目_01

    原文:day68_淘淘商城项目_01 课程计划 第一天: 1.电商行业的背景介绍--电子商务 2.淘淘商城的系统架构 a) 功能介绍 b) 架构讲解 3.工程搭建--后台工程 a) 使用maven搭建 ...

  5. day68_淘淘商城项目_01_电商介绍 + 互联网术语 + SOA + 分布式 + 集群介绍 + 环境配置 + 框架搭建_匠心笔记

    课程计划 第一天: 1.电商行业的背景介绍--电子商务 2.淘淘商城的系统架构 a) 功能介绍 b) 架构讲解 3.工程搭建--后台工程 a) 使用maven搭建工程(工程大) b) 使用maven的 ...

  6. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第二天】

    淘淘商城(SpringMVC+Spring+Mybatis)  是传智播客在2015年9月份录制的,几年过去了.由于视频里课上老师敲的代码和项目笔记有些细节上存在出入,只有根据日志报错信息作出适当的调 ...

  7. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis) 的学习实践总结【第一天】

    本人做过一年的MATLAB编程和简单维护过VB和C++的项目.是跟着网上获得的黑马的Java双元视频课来自学入门Java知识和常用框架的使用. 淘淘商城(SpringMVC+Spring+Mybati ...

  8. ZZJ_淘淘商城项目:day01(RESTful Web Service、SVN)

    淘淘商城项目是很适合初级Java程序员练习的实战项目,本次复习是另一位张老师教授的课,内容上与之前入老师版taotao商城比较有些新东西加了进来. 因此有必要记录下那些直到现在还可供参考的技术亮点分享 ...

  9. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十二天】(系统架构讲解、nginx)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  10. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十一天】(购物车+订单)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

随机推荐

  1. vue封装公用弹出框方法,实现点击出现操作弹出框

    vue封装公用弹出框方法,实现点击出现操作弹出框 如上图所示,这次要实现一个点击出现操作弹框的效果:并将这个功能封装成一个函数,便于在项目的多个地方使用. 具体思路是: 封装一个组件,组件保护一个插槽 ...

  2. 简易计算器实现:while循环+switch语句

    个人练习: 写一个计算器,要求实现加减乘除功能,并且能循环接收新的数据,通过用户交互实现(即Scanner对象) 用到了 while循环 switch语句,实现了数据的循环输入并计算!!!!妙啊!!! ...

  3. [树形DP]没有上司的晚会

    没 有 上 司 的 晚 会 没有上司的晚会 没有上司的晚会 题目描述 Ural大学有N个职员,编号为1~N.他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.每个职 ...

  4. 编程相关术语(Python)

    1. 程序的组成 程序 (program):(1)由一系列定义计算机如何执行计算的指令组成.(本质) (2)程序(算法)由对象.表达式和语句组成.(元素) 1.1程序的指令类型 输入 (input): ...

  5. 02 . MongoDB复制集,分片集,备份与恢复

    复制集 MongoDB复制集RS(ReplicationSet): 基本构成是1主2从的结构,自带互相监控投票机制(Raft(MongoDB)Paxos(mysql MGR 用的是变种)) 如果发生主 ...

  6. inline&register

    inline关键字: 内联只是一个请求,不代表编译器会响应:同时某些编译器会将一些函数优化成为内联函数. C++在类内定义的函数默认是内联函数,具体是否真变成内联函数还需看编译器本身. registe ...

  7. Mybatis3源码笔记(三)Configuration

    1. XMLConfigBuilder 上一篇大致介绍了SqlSession的生成.在DefaultSqlSessionFactory的构造函数中就提到了Configuration这个对象.现在我们来 ...

  8. JDBC_12_JDBC事务

    JDBC事务 JDBC中事务默认自动提交,每执行一次SQL就会自动提交一次. 这样的话可能出现数据安全性问题. connection.setAutoCommit(false) false代表关闭自动提 ...

  9. NetCore去注册Eureka

    首先先安装nuget组件:Steeltoe.Discovery.ClientCore 然后在ConfigureServices中进行注入 services.AddDiscoveryClient(Con ...

  10. 【Idea】实用的快捷键清单

    1.Ctrl + Shift +i:快速查看某个类/方法 2.Ctrl +:(Ace Jump插件启动) 3.alt+F1:快速查看某个类/方法 所在的包 4.Ctrl +w :选中某个单词 5.Ct ...