前言
項目介紹
系統分為3大部分:微服務、網站前臺、網站管理后臺;功能模塊分為:問答、招聘、交友中心等
該項目融合了Docker容器化部署、第三方登陸、SpringBoot、SpringCloud、SpringData、RabbitMQ等,該項目采用完全的前后端分離,根據API文檔開發
技術架構
后端架構:SpringBoot+SpringCloud+SpringData+StringMVC
前端架構:Node.js+Vue.js+ElementUI+NUXT
【注】:SpringBoot是Spring的純注解版,SpringCloud是一個整合第三方技術的架構,采用SpringBoot方式(零配置文件)封裝到Spring框架
SpringData是持久層的框架,用來替代Mybatis,更強大的是不僅支持關系型數據庫,也支持非關系型數據庫的增刪改查
前后端分離
整體架構
SpringData JPA
?SpringData JPA詳解
系統設計與工程搭建
模塊劃分
RESTful
Restful一種軟件架構風格,提供了一種設計原則和約束條件,基于http協議,適用于客戶端和服務器端交互。目的是降低應用之間的耦合度,方便框架分布式處理程序
例如:用戶請求的url使用同一個URL,用不同的請求方式get/post/delete/put等對請求的處理方法進行區分,在前后臺分離開發中,不會對請求的資源地址產生混淆
SpringMVC對RESTtful提供了支持
1.?利用@RequestMapping 指定待處理請求的url模板和http請求的動作類型
2.?利用@PathVariable將url請求模板中的變量映射到處理方法參數上
3. 前臺利用AJAX,在客戶端發出put、delete動作的請求
一般請求格式如下:
@RequestMapping(value="/{id}",method=RequestMethod.GET)
@RequestMapping(value="/{id}",method=RequestMethod.POST)
@RequestMapping(value="/{id}",method=RequestMethod.DELETE)
@RequestMapping(value="/{id}",method=RequestMethod.PUT)
安全冪等性
安全:沒有發生臟讀、幻讀、不可重復讀等;冪等:在操作成功條件下,對數據沒有產生不好的影響
1.GET:安全且冪等,向服務端發索取數據的請求,類似select操作
2.POST:不安全且不冪等,向服務器端發送數據,但是該請求會改變數據的種類等資源,類似insert操作
3.PUT:不安全但冪等,向服務器端發送數據,類似update操作
4.DELETE:不安全但冪等,刪除某一個資源,類似delete操作
Docker創建MySQL服務
0. Linux上已經裝過Docker和各種鏡像
1. 在宿主機上啟動docker,執行命令: systemctl start docker
2. 查看鏡像,執行命令:docker images
3. 下載鏡像,執行命令:docker search xxx ,然后執行 docker pull xxxx
4. 制作容器:docker run -di --name=tensquare_mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=private centos/mysql-57-centos7
5. 查看正在運行的容器:docker ps -a
6. 關閉容器:docker?stop CONTAINER ID
7. 開啟容器:docker?start CONTAINER ID
8. 刪除容器:docker?rm CONTAINER ID
9. 通過Navicat連接MySQL微服務
?
tensquare_common模塊開發
1.?新建entity包,創建類Result,用于控制器類返回結果,這是由于前端需要接收JSON對象,可以通過@ResponseBody,直接將Bean轉為JSON對象
2.?創建類PageResult ,用于返回分頁結果
3. 返回碼定義類StatusCode
4.?分布式ID生成器,由于數據庫要分片部署(MyCat),所以不能使用數據庫本身的自增功能來產生主鍵值,只能由程序來生成唯一的主鍵值,util包下的IdWorker.java
tensquare_base模塊開發
1. pom.xml文件引入依賴


<?xml version="1.0" encoding="UTF-8"?><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"><parent><artifactId>tensquare_parent</artifactId><groupId>com.tensquare</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>tensquare_base</artifactId><dependencies><!--SpringBoot整合JPA--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><!--依賴的common模塊--><dependency><groupId>com.tensquare</groupId><artifactId>tensquare_common</artifactId><version>1.0-SNAPSHOT</version></dependency><!--數據庫鏈接--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency></dependencies></project>
2.創建啟動類


package com.tensquare.base;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.context.annotation.Bean; import util.IdWorker;/*** @author Oxygen* @create 2018-11-30 - 18:49*/ @SpringBootApplication public class BaseApp {public static void main(String[] args) {SpringApplication.run(BaseApp.class);}@Bean //只有當某個類用到時,通過@Bean注入到容器public IdWorker idWorker() {return new IdWorker();} }
3.?在resources下創建數據庫配置文件application.yml


server:port: 9001 #base微服務端口號 spring:application:name: tensquare-base #模塊名字,必須寫-datasource:driver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://X.X.X.X:3306/tensquare_base?characterEncoding=utf-8 username: Xpassword: Xjpa:database: mysqlshow-sql: true
4. CURD
5. 公共異常處理


package com.tensquare.base.controller;import entity.Result; import entity.StatusCode; import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.RestControllerAdvice;/*** 統一異常處理** @author Oxygen* @create 2018-12-01 - 19:26*/ @RestControllerAdvice //如果全部異常處理返回json,那么可以使用 @RestControllerAdvice 代替 @ControllerAdvice , // 這樣在方法上就可以不需要添加 @ResponseBody。 public class BaseExcepitonHandler {@ExceptionHandler(value = Exception.class)public Result exception(Exception e) {e.printStackTrace();return new Result(false, StatusCode.ERROR, e.getMessage());} }