复习电商笔记-1

  1. 技术大拼盘

    22台服务器,整体架构8层优化,支持百万级并发!具有初架水平!

     

    顶级技术

    技术说明

    1.  

    Nginx+Tomcat集群

    负载均衡,极大提升系统的并发访问能力

    1.  

    Amoeba+Mysql主从

    实现数据库实时备份和读写分离,提升数据的安全性和查询性能

    1.  

    Redis缓存

    极大提升系统的查询性能,减轻对数据库的访问压力

    1.  

    SSO单点登录

    httpclient实现权限独立控制解决分布式集群下session共享

    1.  

    Dubbox购物车、订单

    微服务方式实现购物车系统和订单系统

    1.  

    RabbitMQ消息队列

    实现架构送耦合,极大提升系统的并发能力

    1.  

    Lucene+Solr

    解决海量数据亿级别的快速查询问题

    1.  

    Docker部署

    从VM虚拟机升级为Docker容器,提高部署开发效率


    主要技术

    序号

    知识点

    重要程度

    难度系数

    掌握程度

    1.  

    业务:商品分类、商品、前台、权限单点登录、购物车、订单、商品全文检索

    ★★★★★

    1

    熟练

    1.  

    Spring、SpringMVC、MyBatis主流框架

    ★★★

    1

    熟练

    1.  

    富客户端EasyUI、KindEditor图文控件

    1

    会用

    1.  

    Maven 一键构建继承和聚合

    ★★

    1

    熟练

    1.  

    PowerDesinger表设计及优化

    ★★★★

    3

    会用

    1.  

    通用Mapper插件,自动生成调用代码

    1

    会用

    1.  

    Nginx 负载均衡

    ★★★★★

    1

    精通

    1.  

    Tomcat集群

    ★★★

    1

    熟练

    1.  

    RESTFul 访问方式

    ★★★★★

    1

    熟练

    1.  

    HttpClient系统间调用

    ★★

    1

    熟练

    1.  

    Redis 缓存服务器,分片,哨兵,集群高可用

    ★★★★★

    1

    精通

    1.  

    RabbitMQ 消息队列

    ★★★

    3

    熟练

    1.  

    MySQL主从复制,Amoeba读写分离

    ★★★★★

    2

    精通

    1.  

    Lucene、Solr搜索

    ★★★★

    3

    熟练

    1.  

    Linux/CentOS 操作系统

    ★★★

    1

    熟练

     

    思考:

    序号

    知识点

    类型

    难度系数

    掌握程度

    1.  

    系统架构图

    画图

    3

    熟练

    1.  

    Maven的继承和聚合

    论述

    1

    熟练

    1.  

    业务的纵向切分和水平切分

    论述

    3

    熟练

    1.  

    BaseService在common包下,事务是配置的com.jt.manage.service。这样会造成BaseService中的方法没有事务吗?

    论述

    1

    熟练

    1.  

    通用Mapper+JPA怎么就实现了无需写SQL,而自动产生SQL语句的?

    论述

    1

    熟练

    知识点:

    序号

    知识点

    类型

    难度系数

    掌握程度

    1.  

    京淘项目背景

    论述

    1

    熟练

    1.  

    SSM架构

    技术

    1

    熟练

    1.  

    通用Mapper及其工作原理

    论述

    1

    了解

    1.  

    JPA概念作用

    论述

    1

    了解

    1.  

    Maven继承和聚合

    技术

    3

    熟练

    1.  

    创建各项目框架和jt-manage后台项目

    技术

    3

    熟练

    1.  

    京淘继承、聚合实现

    技术

    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

    单点登录系统:为多个系统之间提供用户登录凭证以及查询登录用户的信息。


     
      1. 开发工具和环境

        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
         

      2. 系统架构图

 

  1. 搭建Maven环境
     
      1. Maven项目管理结构
      2. Maven垂直切分

      3. jt-parent            -- 父工程,pom类型,统一管理公用jar依赖
      4. jt-common            -- jar类型,通用的组件、工具类
      5. jt-manage            -- pom类型,后台管理系统,管理商品、分类等功能
      6. Maven水平切分

      7. jt-manage-pojo    -- jar类型,后台持久类
      8. jt-manage-mapper -- jar类型,后台持久层接口
      9. jt-manage-service    -- jar类型,后台业务层
      10. jt-manage-web     -- war类型,后台的前台controller、jsp、映射文件
      11. 依赖关系

      12. jt-manage-mapper 依赖pojo
      13. jt-manage-service依赖pojo,依赖mapper,依赖common
      14. jt-manage-web依赖pojo,依赖mapper,依赖service,依赖common
      15. 利用依赖的传递性简化

      16. pojo依赖common,mapper依赖pojo,service依赖mapper,web依赖service

创建新的工作空间(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>

猜你喜欢

转载自blog.csdn.net/qq_40680190/article/details/84025923
今日推荐