1. 程式人生 > >複習電商筆記-1

複習電商筆記-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>