複習電商筆記-1
- 技術大拼盤
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>