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


课程计划

  • 第一天:
    • 1、电商行业的背景介绍–电子商务
    • 2、淘淘商城的系统架构
      • a) 功能介绍
      • b) 架构讲解
    • 3、工程搭建–后台工程
      • a) 使用maven搭建工程(工程大)
      • b) 使用maven的tomcat插件启动工程
    • 4、SVN的使用
  • 第二天:
    • 1、服务中间件dubbo–远程调用技术
    • 2、SSM框架整合
    • 3、整合测试
    • 4、商品列表查询功能实现
  • 第三天:
    • 1、商品类目选择
    • 2、图片上传
      • a) 图片服务器FastDFS
      • b) 图片上传功能实现
    • 3、富文本编辑器KindEditor的使用
    • 4、商品添加功能完成
  • 第四天:
    • 1、前台系统搭建
    • 2、CMS系统的实现–内容管理系统
      • a) 内容分类管理
      • b) 内容管理
    • 3、前台内容动态展示
  • 第五天:
    • 1、Redis服务器搭建–缓存
    • 2、向业务逻辑中添加缓存
    • 3、使用redis做缓存
    • 4、缓存同步
    • 5、Solr服务器安装–搜索
  • 第六天:
    • 1、Solrj使用测试–Solr服务的java客户端
    • 2、把数据库中的数据导入索引库
    • 3、搜索功能的实现
  • 第七天:
    • 1、Solr集群搭建–SlorCloud
    • 2、使用solrj管理solr集群
    • 3、把搜索功能切换到集群版
  • 第八天:
    • 1、什么是MQ–消息队列
    • 2、MQ的应用场景
    • 3、ActiveMQ的使用方法
    • 4、使用消息队列实现商品同步
  • 第九天:
    • 1、商品详情页面展示–动态展示 jsp + redis
    • 2、使用freemarker实现网页静态化
    • 3、ActiveMq同步生成静态网页
  • 第十天:
    • 1、Nginx的安装–访问静态资源
    • 2、Nginx配置虚拟机
    • 3、Nginx实现反向代理
    • 4、Nginx实现负载均衡
    • 5、SSO系统工程搭建–单点登录系统
  • 第十一天:
    • 1、SSO注册功能实现
    • 2、SSO登录功能实现
    • 3、通过token获得用户信息
    • 4、Ajax跨域请求(jsonp)
  • 第十二天:
    • 1、购物车实现
    • 2、订单确认页面展示
  • 第十三天:
    • 1、订单系统完成
    • 2、系统部署–上线流程
  • 第十四天~十六天:
    • 项目实战–需求、分组、实现
    • 项目总结

1、电商行业的背景介绍–电子商务

  近年来,中国的电子商务快速发展,交易额连创新高,电子商务在各领域的应用不断拓展和深化、相关服务业蓬勃发展、支撑体系不断健全完善、创新的动力和能力 不断增强。电子商务正在与实体经济深度融合,进入规模性发展阶段,对经济社会生活的影响不断增大,正成为我国经济发展的新引擎。
  中国电子商务研究中心数据显示,截止到2012年底,中国电子商务市场交易规模达7.85万亿人民币,同比增长30.83%。其中,B2B电子商务交易额达6.25万亿,同比增长27%。而2011年全年,中国电子商务市场交易额达6万亿人民币,同比增长33%,占GDP比重上升到13%;2012年,电子商务占GDP的比重已经高达15%。预计2013年我国电子商务规模将突破十万亿大关。

1.1、11.11

  • 结论:
    • 1、电商行业很挣钱,找互联网相关的工作。
    • 2、电商行业技术要求很高、高可用、海量数据的存储。

1.2、电商行业技术特点

  • 技术新
  • 技术范围广
  • 分布式
  • 高并发、集群、负载均衡、高可用
  • 海量数据
  • 业务复杂
  • 系统安全

2、淘淘商城的系统架构

2.1、淘淘商城介绍

  淘淘网上商城是一个综合性的B2C平台,类似京东商城、天猫商城。会员可以在商城浏览商品、下订单,以及参加各种活动。
  管理员、运营可以在平台后台管理系统中管理商品、订单、会员等。
  客服可以在后台管理系统中处理用户的询问以及投诉。

  • 电商模式:
    • B2B:商家到商家。阿里巴巴、1688(批发)、慧聪网、铭万网。
    • B2C:商家(京东)到用户。京东(自营)。
    • C2C:用户到用户。淘宝(赶集)。
    • B2B2C:商家(天猫)到商家(耐克)到用户。天猫(开发票)。
    • O2O:线上到线下。百度外卖、美团外卖、饿了么。

2.2、功能介绍

  • 后台管理系统:管理商品、订单、类目、商品规格属性、用户管理以及内容发布等功能。
  • 前台系统:用户可以在前台系统中进行注册、登录、浏览商品、首页、下单等操作。
  • 会员系统:用户可以在该系统中查询已下的订单、收藏的商品、我的优惠券、团购等信息。
  • 订单系统:提供下单、查询订单、修改订单状态、定时处理订单。
  • 搜索系统:提供商品的搜索功能。
  • 单点登录系统:为多个系统之间提供用户登录凭证以及查询登录用户的信息。

2.3、系统架构

2.3.1、传统架构

  • 存在的问题:
    • 1、功能耦合度高
    • 2、系统维护成本高
    • 3、如果并发量大,无法解决高并发的问题
2.3.2、1000个并发

  • 存在的问题:
    • 1、系统无法有效进行水平扩展(集群不能针对功能模块)
    • 2、用户存在重复登录的问题
      • 针对第二点:需要session共享,是以session广播的形式,比较消耗资源(宽带)。
  • 如果要达到10000并发
    • 需要20台服务器做tomcat集群。
    • 注意:当tomcat集群中节点数量增加,服务能力先增加后下降。所以集群中节点数量不能太多,一般也就5个左右。
2.3.3、分布式架构(10000个并发)
  • 需要按照功能点把系统拆分,拆分成独立的功能。单独为某一个节点添加服务器。需要系统之间配合才能完成整个业务逻辑。叫做分布式
  • 分布式架构:多个子系统相互协作才能完成业务流程。系统之间需要进行通信
  • 集群同一个工程部署到多台服务器上。相当于同一个工程代码拷贝多份部署到多台服务器,每台服务器单独独立部署运行。
  • 分布式架构:
    • 把系统按照模块拆分成多个子系统,多个子系统相互协作才能完成业务流程系统之间需要进行通信。
  • 优点:
    • 1、把模块拆分,使用接口通信降低模块之间的耦合度
    • 2、把项目拆分成若干个子项目,不同的团队负责不同的子项目。
    • 3、增加功能时只需要再增加一个子项目,调用其他系统的接口就可以。
    • 4、可以灵活的进行分布式部署
  • 缺点:
    • 1、系统之间交互需要使用远程通信,接口开发增加工作量
    • 2、各个模块有一些通用的业务逻辑无法共用
2.3.4、基于SOA的架构

SOA:Service Oriented Architecture 面向服务的架构。也就是把工程拆分成服务层表现层两个工程。服务层中包含业务逻辑,只需要对外提供服务即可。表现层只需要处理和页面的交互,业务逻辑都是调用服务层的服务来实现。

2.3.5、淘淘商城系统架构

3、技术选型和开发环境

3.1、技术选型

  • Spring、SpringMVC、Mybatis
  • JSP、JSTL、jQuery、EasyUI、KindEditor(富文本编辑器)
  • Redis(缓存服务器,单点登录,购物车)
  • Solr(全文搜索)
  • dubbo(分布式服务框架)
  • HttpClient(HTTP 协议访问客户端)
  • ActiveMQ(消息队列)
  • Quartz(定时任务)
  • FastDFS(图片服务器)
  • FreeMarker(网页静态化)
  • Nginx(反向代理服务器)
  • MyCat(数据库中间件)

3.2、开发工具版本和环境

  • Eclipse Mars.2 Release (4.5.2)
  • Maven 3.5.4
  • Tomcat 7.0.47(Maven Tomcat Plugin)
  • JDK 1.7
  • Mysql 5.7
  • Dubbo 2.5.3
  • Nginx 1.8.0
  • Redis 3.0.0
  • ActiveMQ 5.13.0
  • Win10 操作系统
  • SVN (版本管理)

4、工程搭建–后台工程

4.1、使用maven的好处

  • 使用maven管理工程的好处如下:
      1. jar包的管理
      1. 工程之间的依赖管理
      1. 自动打包
      1. 统一的版本的控制

4.2、后台工程搭建分析

详解如下:

Maven的常见打包方式:jar、war、pom
pom工程一般都是父工程,管理jar包的版本、maven插件的版本、统一的依赖管理。聚合工程。

taotao-parent:父工程,打包方式pom,管理jar包的版本号。
    |          项目中所有工程都应该继承父工程。
    |--taotao-common:通用的工具类、通用的pojo。打包方式jar
    |--taotao-manager:服务层工程。聚合工程。pom工程
        |--taotao-manager-pojo:打包方式jar
        |--taotao-manager-dao:打包方式jar
        |--taotao-manager-interface:打包方式jar
        |--taotao-manager-service:打包方式war (为了发布服务的方便)
    |--taotao-manager-web:表现层工程。打包方式war

4.3、工程搭建

Maven相关配置:

  • M2Eclipse是eclipse中的Maven插件。(低版本的ecplise需要手动安装,高版本的eclipse自带,本博主用的是高版本的ecplise)
  • M2Eclipse是MyEclipse中自带的Maven插件。
    • 注意:
      • 如果我们单独用命令行的方式进行maven的使用时,我们用户的配置文件默认在~/.m2/setting.xml
      • 如果我们使用Eclipse或者MyEclipse的方式进行maven的使用时,我们用户的配置文件可以想放哪里就放哪里,只需要指定配置文件的路径即可。
  • 本地仓库目录:默认位置在:~/.m2/repository
  • 因为我们使用eclipse开发,所以我们把本地仓库放到我们安排好的目录中,需要在eclipse中指定用户的配置文件路径即可。如下图:
  • 本地仓库的使用,我们既可以提前下好所需要的jar包,也可以边开发边联网下载!

Eclipse相关配置:

  • eclipse 设置默认编码为Utf-8
  • 需要设置的几处地方为:
    • Window --> Preferences --> General --> Content Type --> Text --> JSP 最下面设置为UTF-8
    • Window --> Preferences --> General --> Workspace 面板Text file encoding 选择UTF-8
    • Window --> Preferences --> Web --> JSP Files 面板选择 ISO 10646/Unicode(UTF-8)
    • Window --> Preferences --> General --> Workspace 面板 New text file line delimiter 选择 Unix
4.3.1、taotao-parent
  • 父工程必须是pom工程。
    • 创建步骤如下:
      (1)

      (2)

      (3)
  • pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
    http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<groupId>com.taotao</groupId>
	<artifactId>taotao-parent</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>pom</packaging>
	<!-- 集中定义依赖版本号 -->
	<properties>
		<junit.version>4.12</junit.version>
		<spring.version>4.2.4.RELEASE</spring.version>
		<mybatis.version>3.2.8</mybatis.version>
		<mybatis.spring.version>1.2.2</mybatis.spring.version>
		<mybatis.paginator.version>1.2.15</mybatis.paginator.version>
		<mysql.version>5.1.32</mysql.version>
		<slf4j.version>1.6.4</slf4j.version>
		<jackson.version>2.4.2</jackson.version>
		<druid.version>1.0.9</druid.version>
		<httpclient.version>4.3.5</httpclient.version>
		<jstl.version>1.2</jstl.version>
		<servlet-api.version>2.5</servlet-api.version>
		<jsp-api.version>2.0</jsp-api.version>
		<joda-time.version>2.5</joda-time.version>
		<commons-lang3.version>3.3.2</commons-lang3.version>
		<commons-io.version>1.3.2</commons-io.version>
		<commons-net.version>3.3</commons-net.version>
		<pagehelper.version>3.4.2-fix</pagehelper.version>
		<jsqlparser.version>0.9.1</jsqlparser.version>
		<commons-fileupload.version>1.3.1</commons-fileupload.version>
		<jedis.version>2.7.2</jedis.version>
		<solrj.version>4.10.3</solrj.version>
		<dubbo.version>2.5.3</dubbo.version>
		<zookeeper.version>3.4.7</zookeeper.version>
		<zkclient.version>0.1</zkclient.version>
		<activemq.version>5.13.0</activemq.version>
		<freemarker.version>2.3.23</freemarker.version>
		<quartz.version>2.2.2</quartz.version>
	</properties>
    <!-- 统一依赖jar包版本的管理, 其下的标签dependencies只是版本的管理,并不是依赖jar包-->
	<dependencyManagement>
		<dependencies>
			<!-- 时间操作组件 -->
			<dependency>
				<groupId>joda-time</groupId>
				<artifactId>joda-time</artifactId>
				<version>${joda-time.version}</version>
            </dependency>
            <!-- Apache工具组件 -->
            <dependency>
            	<groupId>org.apache.commons</groupId>
            	<artifactId>commons-lang3</artifactId>
            	<version>${commons-lang3.version}</version>
            </dependency>
            <dependency>
            	<groupId>org.apache.commons</groupId>
            	<artifactId>commons-io</artifactId>
            	<version>${commons-io.version}</version>
            </dependency>
            <dependency>
            	<groupId>commons-net</groupId>
            	<artifactId>commons-net</artifactId>
            	<version>${commons-net.version}</version>
			</dependency>
			<!-- Jackson Json处理工具包 -->
			<dependency>
				<groupId>com.fasterxml.jackson.core</groupId>
				<artifactId>jackson-databind</artifactId>
				<version>${jackson.version}</version>
            </dependency>
            <!-- httpclient -->
            <dependency>
            	<groupId>org.apache.httpcomponents</groupId>
            	<artifactId>httpclient</artifactId>
            	<version>${httpclient.version}</version>
			</dependency>
			<!-- quartz任务调度框架 -->
			<dependency>
				<groupId>org.quartz-scheduler</groupId>
				<artifactId>quartz</artifactId>
				<version>${quartz.version}</version>
            </dependency>
            <!-- 单元测试 -->
            <dependency>
            	<groupId>junit</groupId>
            	<artifactId>junit</artifactId>
            	<version>${junit.version}</version>
				<scope>test</scope><!-- test表示该范围传递不到下面去 -->
			</dependency>
			<!-- 日志处理 -->
			<dependency>
				<groupId>org.slf4j</groupId>
				
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值