电商

  • 市场

    • 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. Spring Boot MVC 单张图片和多张图片上传 和通用文件下载

    @Autowired private ServerConfig serverConfig; /** * 通用下载请求 * * @param fileName 文件名称 * @param delete ...

  2. PAT (Basic Level) Practice (中文)1070 结绳 (25 分) 凌宸1642

    PAT (Basic Level) Practice (中文)1070 结绳 (25 分) 凌宸1642 题目描述 给定一段一段的绳子,你需要把它们串成一条绳.每次串连的时候,是把两段绳子对折,再如下 ...

  3. Etcd常用运维命令

    目录 常用命令 常见操作 如何缩容? 如何扩容? 数据目录丢失或被误删除,节点启动失败或者加入集群报错? 操作步骤 操作步骤不正确的各种常见错误日志 常用命令 #查看集群member情况 etcdct ...

  4. Kafka 常见问题汇总

    Kafka 常见问题汇总 1. Kafka 如何做到高吞吐.低延迟的呢? 这里提下 Kafka 写数据的大致方式:先写操作系统的页缓存(Page Cache),然后由操作系统自行决定何时刷到磁盘. 因 ...

  5. HCL实验8:NAT搭建私有网络

    NAT 通过NAT技术,进行私有网络的搭建 拓扑图 先对路由器的端口进行配置 R1 [H3C]sys R1 [R1]INT G0/0 [R1-GigabitEthernet0/0]ip address ...

  6. Crackme_003

    功能: 拿到文件,先执行一下.功能如下: 1.nag窗口 会先出现如下nag窗口,持续几秒 2.注册窗口: 出现错误会提示:You Get Wrong  Try Again 破解: 1.查壳: 无壳, ...

  7. 自动化kolla-ansible部署ubuntu20.04+openstack-victoria之替换logo-13

    自动化kolla-ansible部署ubuntu20.04+openstack-victoria之替换logo-13 欢迎加QQ群:1026880196 进行交流学习 替换 openstack das ...

  8. WERTYU UVA - 10082

    ​ A common typing error is to place the hands on the keyboard one row to the right of the correct po ...

  9. JAVAEE_Servlet_17_关于乱码问题

    关于乱码问题 * 数据传递过程中的乱码 解释:数据传递过程中的乱码是指: 将数据从浏览器发送给服务器的时候,服务器接收到的数据是乱码的. - ISO-8859-1 是国际标准码,不支持中文编码,它兼容 ...

  10. Day14_75_反射(reflect)

    反射 反射的基本概念 反射是由Smith在1982年首次提出,主要是指程序可以访问,检测,修改它本身状态或行为的一种能力.并且能够根据自身行为的状态或结果,调整和修改所描述行为的状态和相关语义. ja ...