- 技术大拼盘
22台服务器,整体架构8层优化,支持百万级并发!具有初架水平!顶级技术
技术说明
Nginx+Tomcat集群
负载均衡,极大提升系统的并发访问能力
Amoeba+Mysql主从
实现数据库实时备份和读写分离,提升数据的安全性和查询性能
Redis缓存
极大提升系统的查询性能,减轻对数据库的访问压力
SSO单点登录
httpclient实现权限独立控制解决分布式集群下session共享
Dubbox购物车、订单
微服务方式实现购物车系统和订单系统
RabbitMQ消息队列
实现架构送耦合,极大提升系统的并发能力
Lucene+Solr
解决海量数据亿级别的快速查询问题
Docker部署
从VM虚拟机升级为Docker容器,提高部署开发效率
主要技术序号
知识点
重要程度
难度系数
掌握程度
业务:商品分类、商品、前台、权限单点登录、购物车、订单、商品全文检索
★★★★★
1
熟练
Spring、SpringMVC、MyBatis主流框架
★★★
1
熟练
富客户端EasyUI、KindEditor图文控件
★
1
会用
Maven 一键构建继承和聚合
★★
1
熟练
PowerDesinger表设计及优化
★★★★
3
会用
通用Mapper插件,自动生成调用代码
★
1
会用
Nginx 负载均衡
★★★★★
1
精通
Tomcat集群
★★★
1
熟练
RESTFul 访问方式
★★★★★
1
熟练
HttpClient系统间调用
★★
1
熟练
Redis 缓存服务器,分片,哨兵,集群高可用
★★★★★
1
精通
RabbitMQ 消息队列
★★★
3
熟练
MySQL主从复制,Amoeba读写分离
★★★★★
2
精通
Lucene、Solr搜索
★★★★
3
熟练
Linux/CentOS 操作系统
★★★
1
熟练
思考:
序号
知识点
类型
难度系数
掌握程度
系统架构图
画图
3
熟练
Maven的继承和聚合
论述
1
熟练
业务的纵向切分和水平切分
论述
3
熟练
BaseService在common包下,事务是配置的com.jt.manage.service。这样会造成BaseService中的方法没有事务吗?
论述
1
熟练
通用Mapper+JPA怎么就实现了无需写SQL,而自动产生SQL语句的?
论述
1
熟练
知识点:
序号
知识点
类型
难度系数
掌握程度
京淘项目背景
论述
1
熟练
SSM架构
技术
1
熟练
通用Mapper及其工作原理
论述
1
了解
JPA概念作用
论述
1
了解
Maven继承和聚合
技术
3
熟练
创建各项目框架和jt-manage后台项目
技术
3
熟练
京淘继承、聚合实现
技术
1
熟练
各系统核心业务说明整个工程分为8个工程,细分为26个子工程。
序号
项目名称
各子系统
业务子系统
1
jt-web
前台商城系统:用户可以访问商城首界面,查看不同分类下的商品,浏览商品的详细信息,并可以查询商品,将商品加入购物车,最终提交订单,还包括用户注册和登录。
2
jt-manage
后台管理系统:商品分类管理、商品信息管理、商品规格属性、注册用户管理以及CMS内容发布管理等功能。
包括:jt-manage-mapper/pojo/service/web四个子项目
3
jt-cart
购物车系统:未登录商品选择,登录商品选择,修改商品数量,计算支付金额,下单提交到订单系统。
4
jt-order
订单系统:提供下单、查询订单、修改订单状态、定时处理订单。
5
jt-search
搜索系统:提供商品的搜索功能。
支撑子系统
6
jt-parent
jar包依赖管理
7
jt-common
公用工具类
8
jt-sso
单点登录系统:为多个系统之间提供用户登录凭证以及查询登录用户的信息。
-
-
- 开发工具和环境
Windows7/CentOS 5.6
Power Designer 15.6
Eclipse Mars Release 4.5.0
JDK 1.7 必须。一些高级应用需要高版本支持
Maven 3.3.9
Tomcat 7.0.59
Nginx 1.9.0
Redis 2.8.9
MySQL 5.5.27(注意5.0导入jtdb.sql会报错必须升级) + Amoeba
-
系统架构图
- 开发工具和环境
-
- 搭建Maven环境
-
-
- Maven项目管理结构
-
Maven垂直切分
- jt-parent -- 父工程,pom类型,统一管理公用jar依赖
- jt-common -- jar类型,通用的组件、工具类
- jt-manage -- pom类型,后台管理系统,管理商品、分类等功能
-
Maven水平切分
- jt-manage-pojo -- jar类型,后台持久类
- jt-manage-mapper -- jar类型,后台持久层接口
- jt-manage-service -- jar类型,后台业务层
- jt-manage-web -- war类型,后台的前台controller、jsp、映射文件
-
依赖关系
- jt-manage-mapper 依赖pojo
- jt-manage-service依赖pojo,依赖mapper,依赖common
- jt-manage-web依赖pojo,依赖mapper,依赖service,依赖common
-
利用依赖的传递性简化
- pojo依赖common,mapper依赖pojo,service依赖mapper,web依赖service
- Maven项目管理结构
-
创建新的工作空间(eclipse)
配置字体大小
配置jdk
配置maven
安装installations
UserSettings配置(maven)
创建项目组jt
创建项目组,可将多个项目放在一个项目组中。配置如下图:
新建项目组如下图所示:
起名为jt京淘,如下图所示:
创建maven java父工程:jt-parent
子模块的POM继承这些配置:子模块继承这些配置的时候,仍然要声明groupId和artifactId,表示当前配置是继承于父POM的,从而直接使用父POM的版本对应的资源。
选择组建立maven java工程,如下图所示:
项目创建完成,但项目报错,更新下工程就可以。
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.jt.parent</groupId>
<artifactId>jt-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<name>jt-parent</name>
<url>http://maven.apache.org</url>
<!-- 集中定义依赖版本号 -->
<properties>
<junit.version>4.10</junit.version>
<spring.version>4.1.3.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>
<bonecp-spring.version>0.8.0.RELEASE</bonecp-spring.version>
<druid.version>1.0.9</druid.version>
<mapper.version>2.3.2</mapper.version>
<pagehelper.version>3.4.2</pagehelper.version>
<jsqlparser.version>0.9.1</jsqlparser.version>
<slf4j.version>1.6.4</slf4j.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>2.4</commons-io.version>
<commons-fileupload.version>1.3.1</commons-fileupload.version>
<jackson.version>2.4.2</jackson.version>
<httpclient.version>4.3.5</httpclient.version>
<jedis.version>2.6.0</jedis.version>
</properties>
<dependencies>
<!-- 单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>${mybatis.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>${mybatis.spring.version}</version>
</dependency>
<dependency>
<groupId>com.github.miemiedev</groupId>
<artifactId>mybatis-paginator</artifactId>
<version>${mybatis.paginator.version}</version>
</dependency>
<!-- MySql -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!-- 通用Mapper -->
<dependency>
<groupId>com.github.abel533</groupId>
<artifactId>mapper</artifactId>
<version>${mapper.version}</version>
</dependency>
<!-- 分页插件 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>${pagehelper.version}</version>
</dependency>
<dependency>
<groupId>com.github.jsqlparser</groupId>
<artifactId>jsqlparser</artifactId>
<version>${jsqlparser.version}</version>
</dependency>
<!-- 连接池 -->
<dependency>
<groupId>com.jolbox</groupId>
<artifactId>bonecp-spring</artifactId>
<version>${bonecp-spring.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.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>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpmime</artifactId>
<version>4.3.1</version>
</dependency>
<!-- JSP相关 -->
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>${jstl.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>${servlet-api.version}</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>${jsp-api.version}</version>
<scope>provided</scope>
</dependency>
<!-- 时间操作组件 -->
<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-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>${commons-fileupload.version}</version>
</dependency>
<!-- jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>${jedis.version}</version>
</dependency>
<!-- 字符加密、解密 -->
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.9</version>
</dependency>
<!-- 数据校验 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>5.1.3.Final</version>
</dependency>
</dependencies>
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<!-- 资源文件拷贝插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.7</version>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<!-- java编译插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.2</version>
<configuration>
<source>1.7</source>
<target>1.7</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
</plugins>
</build>
</project>