保姆級尚硅谷SpringCloud學習筆記(停更中)



前言

大家好呀,我是 白墨,一個熱愛學習與划水的矛盾體。

快過年了,這段時間工作也不好找。閑着呢也是閑着,提升一下自己,學習一下SpringCloud吧!順便做個筆記記錄一下。

授課老師:尚硅谷-周陽

視頻地址:最新版SpringCloud(H版&alibaba)框架開發教程全套完整版從入門到精通(大牛講授spring cloud)

課程項目源碼:周陽老師我自己的(含sql文件)


正文內容

001_課程說明

技術要求:

  • java8+maven+git、GitHub+Nginx+RabbitMQ+SpringBoot2.0(雷鋒楊)
  • 2018發布的SpringCloud第一季(非必要)

002_零基礎微服務架構理論入門

微服務(個人理解):將完整的系統中的各個功能模塊拆分成一個個獨立的服務。

如購物商城項目中包含登錄、訂單、商品這些模塊,就拆分成三個微服務,服務之間相互調用。

微服務優缺點[1]

優點:

  • 單個服務代碼量少,易於維護;
  • 單個微服務可獨立部署和運行;
  • 進程獨立,可以動態升級;
  • 多個相同的微服務可以做負載均衡,提高性能和可靠性;

缺點:

  • 雖然代碼量少,但系統復雜度的總量是不變的;
  • 每一個微服務需要一個團隊維護,小公司玩不起…

分布式微服務架構:服務注冊與發現、服務調用、服務熔斷、負載均衡、服務降級、服務消息隊列、配置中心管理、服務網關、服務監控、全鏈路追蹤、自動化構建部署、服務輕視任務調度操作

大廠案例:

京東

京東.png

阿里

阿里.png

京東物流

s76Kw8.png

SpringCloud與微服務的關系

SpringCloud是分布式微服務架構的一站式解決方案,是多種微服務架構落地技術的集合體,俗稱微服務全家桶。
SpringCloud官網:https://spring.io/

SpringCloud技術棧


003_第二季Boot和Cloud版本選型

本門課選擇SpringBoot2.X版和SpringCloud H版
詳細環境如下:

工具 版本
Cloud Hoxton.SR1
Boot 2.2.2.RELEASE
CloudAlibaba 2.1.0.RELEASE
Java Java8
Maven 3.5及以上
Mysql 5.7及以上

SpringBoot 版本選擇(升級至2.0及以上)

SpringBoot 官網:https://spring.io/projects/spring-boot
源碼:https://github.com/spring-projects/spring-boot/releases/
GA:當前最穩定版本
Pre-release:預發布版本

SpringCloud 版本選擇

官網:https://spring.io/projects/spring-cloud
源碼:https://github.com/spring-projects/spring-cloud

命名規則:
Boot用字母作為版本號,Cloud用字母 (倫敦地鐵站首字母) 作為版本號,並由A-Z的順序迭代。
當SpringCloud的發布內容積累到臨界點或者一個重大BUG被解決后,會發布一個"service releases' 版本,簡稱SRX版本,比如Greenwich.SR2就是SpringCloud發布的Greenwich版本的第2個SRX版本。
sL2B1U.png

Cloud與Boot的對應的依賴關系

推薦:Cloud官網LEARN選項中查看版本后的Reference Doc.
或者:overview選項下翻查看表格選擇。如下。

Release Train Boot Version
2020.0.x aka Ilford 2.4.x
Hoxton 2.2.x, 2.3.x (Starting with SR5)
Greenwich 2.1.x
Finchley 2.0.x

更詳細版本對應關系:使用JSON工具查看JSON串結果

004_Cloud組件停更說明

Cloud升級
服務注冊中心 服務調用 服務調用2 服務降級 服務網關 服務配置 服務總線
✖ Eureka(停更,要學) ✔ Ribbon(正在使用,但已停更,未來將被LoadBalancer替換) ✖ Feign ✖ Hystrix(停更,國內大規模使用中) ✖ Zuul ✖ Config ✖ Bus
✔ Zookeeper ✔ LoadBalancer(還沒成熟) OpenFeign ✔ resilience4j(國外使用) ? Zuul2
(還沒出)
✔ Nacos ✔ Nacos
✔ Consul - - ✔ rentienl(阿里的,國內使用) ✔ gateway - -
✔ Nacos(阿里的,重點推薦,完美替換Eureka) - - - - -
  • ✖為老技術,基本上已停更,但很多公司還在用。
  • ✔為老技術停更后的替代方法。
  • 新老技術都會講解,因此課程量很大。

參考資料:
SpringCloud官網文檔SpringCloud中文文檔
SpringBoot官方文檔

005_父工程Project空間新建

約定>配置>編碼

已經開始到代碼部分了,提醒一下,課程項目源碼:周陽老師我自己的(含sql文件)
由於代碼太多,所以在筆記里我只做重點知識的記錄,畢竟是筆記,還要方便查閱。

  1. New Project
    New Project

  2. 聚合總父工程名字
    在這里插入圖片描述

  3. Maven選版本(不用自帶的,選擇自己的3.5以上的)
    在這里插入圖片描述

  4. 工程名字(項目構建完成后刪掉src文件夾)
    在這里插入圖片描述

  5. 符號編碼
    在這里插入圖片描述

  6. 注解生效激活
    在這里插入圖片描述

  7. java編輯版本選8
    在這里插入圖片描述

  8. File Type過濾(即在idea中隱藏下方的文件格式,個人習慣,可不做)
    在這里插入圖片描述

006_父工程pom文件

  1. 在pom.xml中添加<packaging>pom</packaging>標簽,表示這個pom是個總的父工程
  2. 刪掉src文件夾
  3. 添加下方總控的jar包版本管理標簽
<groupId>com.atguigu.springcloud</groupId>
<artifactId>cloud2020</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>

<!--統一管理jar包版本-->
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <junit.version>4.12</junit.version>
    <log4j.version>1.2.17</log4j.version>
    <lombok.version>1.16.18</lombok.version>
    <mysql.version>8.0.15</mysql.version><!--數據庫版本,根據自己的改-->
    <druid.version>1.1.16</druid.version>
    <mybatis.spring.boot.version>1.3.0</mybatis.spring.boot.version>
</properties>
<!--子模塊繼承之后,提供作用:鎖定版本+子module不用寫groupId和version-->
<dependencyManagement>
    <dependencies>
        <!--spring boot 2.2.2-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-dependencies</artifactId>
            <version>2.2.2.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--spring cloud Hoxton.SR1-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>Hoxton.SR1</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--spring cloud 阿里巴巴-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2.1.0.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <!--mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>${mysql.version}</version>
            <!--      <scope>runtime</scope>-->
        </dependency>
        <!-- druid-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>${druid.version}</version>
        </dependency>
        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>${mybatis.spring.boot.version}</version>
        </dependency>
        <!--junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>${junit.version}</version>
        </dependency>
        <!--log4j-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>${log4j.version}</version>
        </dependency>
        <!--解決maven項目中 無法打包生成空文件夾的問題-->
        <dependency>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-project-info-reports-plugin</artifactId>
            <version>3.0.0</version>
        </dependency>
    </dependencies>
</dependencyManagement>
<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <version>2.3.7.RELEASE</version>
            <configuration>
                <fork>true</fork>
                <addResources>true</addResources>
            </configuration>
        </plugin>
    </plugins>
</build>

007_復習DependencyManagement和Dependencies

dependencyManagement和dependency的區別

Maven使用dependencyManagement元素來提供了一種管理依賴版本號的方式。
通常會在一個組織或者項目的最頂層的父POM中看到dependencyManagement元素。
使用pom.xml中的dependencyManagement元索能讓所有在子項目中引用一個依賴而不用顯式的列出版本號。
Maven會沿着父子層次向上走,直到找到一個擁有dependencyManagement元素的項目,然后它就會使用這個dependencyManagement元素中指定的版本號。
如父類代碼里:

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.15</version>
        </dependency>
    </dependencies>
</dependencyManagement>

然后在子項目里就可以添加mysql-connector時可以不指定版本號 (如果指定了就優先用子項目的版本號),例如:

<dependencies>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
</dependencies>

這樣做的好處就是:如果有多個子項目都引用同一樣依賴,則可以避免在每個使用的子項目里都聲明一個版本號,這樣當想升級或切換到另一個版本時,只需要在頂層父容器里更新,而不需要一個一個子項目的修改;另外如果某個子項目需要另外的一個版本,只需要聲明version就可。

  • dependencyManagement里只是聲明依賴,並不實現引入,因此子項目需要顯示的聲明需要用的依賴。
  • 如果不在子項目中聲明依賴,是不會從父項目中繼承下來的;只有在子項目中寫了該依賴項,並且沒有指定具體版本,才會從父項目中繼承該項,並且version和scope都讀取自父pom
  • 如果子項目中指定了版本號,那么會使用子項目中指定的jar版本。

maven中跳過單元測試(節約時間)

將父工程發布到倉庫

父工程創建完成執行mvn:install將父工程發布到倉庫方便子工程繼承。
測試一下發布:

然后清除:

008-010_支付模塊構建

微服務模塊構建方法(5步)

  1. 建Module

  2. 改pom


    <artifactId>cloud-provider-payment8001</artifactId>

    <dependencies>
        <!--spring boot 2.2.2-->
        <!--圖形化監控展現-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
        </dependency>
        <!-- druid-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.10</version>
        </dependency>
        <!--mysql-connector-java-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--jdbc-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>
  1. 寫yml(代碼去我的源碼里面copy

  2. 主啟動

  3. 業務類

    • 構造方法注解化的實現使用了插件lombok,要上線的項目還是全部敲出來較好
    • 前后端分離,返回給前端一個json形式的封裝類
    • dao接口推薦使用@Mapper注解而不是@Repository,因為@Repository插入時可能會有問題
    • 返回結果集建議使用映射resultMap,可以避免大小寫、下划線等錯誤。(如果開啟Mybatis的駝峰匹配,其實也無所謂)

yml配置作用說明

server:
  port: 8001 #端口號

spring:
  application:
    name: cloud-payment-service #微服務名稱
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource #當前數據源操作類型
    driver-class-name: com.mysql.cj.jdbc.Driver #mysql驅動包(8.0中間多了個cj)
    # ? 后面的參數在數據庫8.0以后必填
    url: jdbc:mysql:///db2019?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC
    username: root
    password: lilang..

mybatis:
  mapper-locations: classpath:mapper/*.xml
  #mapper的xml中的parameterType屬性可以省略路徑,只寫實體類名稱了
  type-aliases-package: com.atguigu.springcloud.entities #所有Entity別名類所在包

011_熱部署 Devtools(非必要)

熱部署:開啟后,項目在已部署狀態下,每次代碼改動后無需手動重新部署,可以實時更新。付費插件JRebel也可實現熱部署。

比較耗內存,配置差的電腦就別開了。而且開啟后控制台會經常爆紅,看着不爽。

開啟方法:

  1. 添加DevTools到項目中

  2. 添加maven插件到父工程的pom.xml中(如果報錯就加上版本號)

  3. 開啟IDEA的自動編譯

  4. 開啟熱注冊(Update the value of)

    • 按下快捷鍵Ctlr+Shift+Alt+/,選擇Registry
    • 勾選下圖中的選項
  5. 重啟IDEA

注:開發階段可用熱部署,生產環境中必須關閉

012-013_消費者訂單模塊

80端口

瀏覽器默認為80端口,所以客戶端使用80端口可以方便用戶。
如百度baidu.com:80,我們直接輸入baidu.com就可以了

RestTemplate

RestTemplate提供了多種便捷訪問遠程Http服務的方法,是一種簡單便捷的訪問restful服務模板類,是Spring提供的用於訪問Rest服務的客戶端模板工具集

官網文檔地址:https://docs.spring.io/spring-framework/docs/5.2.2.RELEASE/javadoc-api/org/springframework/web/client/RestTemplate.html

使用:(url,requestMap,ResponseBean.class)這三個參數分別代表REST請求地址請求參數HTTP響應轉換被轉換成的對象類型

config配置類:RestTemplate的依賴注入配置

@Configuration
public class ApplicationContextConfig {
    @Bean
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

controller調用

@Resource //自動注入
private RestTemplate restTemplate;

@GetMapping("/consumer/payment/create")
public CommonResult<Payment> create(Payment payment) {
	return restTemplate.postForObject(PAYMENT_URL + "/payment/create", payment, CommonResult.class);
}

日志

開啟@Slf4j注解后使用log.info();即可生成日志。

@RequestBody注解

@RequestBody主要用來接收前端傳遞給后端的json字符串中的數據的(請求體中的數據); GET方式無請求體,所以使用@RequestBody接收數據時,前端不能使用GET方式提交數據,而是用POST方式進行提交。查看更多>>

沒有自動出現Run Dashboard窗口的解決方法

  1. 打開項目文件夾

  1. 進入.idea文件夾,打開workspace.xml文件

  1. RunDashboard 下添加以下配置
<option name="configurationTypes">
	<set>
		<option value="SpringBootApplicationConfigurationType" />
	</set>
</option>

如圖:

  1. 重啟IDEA,出現下圖選項


014_工程重構

重構目的:將重復的代碼提取到一個公開公用的工程里面

發布公用包

  1. 建 Module

    image-20210511214158253

  2. 改 Pom

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--工具包,如時間日期格式-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.1.0</version>
        </dependency>
    </dependencies>
    
  3. 將原工程中重復的 entities 包拷貝到新建的 cloud-api-commons 工程中

    image-20210511224823903

  4. cloud-api-commons 工程 maven 打包發布到公用的本地庫以供調用。

    在右邊的 Maven 中刷新,然后雙擊 clean ,成功以后再雙擊 install

    image-20210511230158918

改造80、8001

  1. 刪除各自原有的 entities 包
  2. 在各自的 pom 中添加依賴
<dependency><!--引入自己的api通用包,可以使用payment支付entity-->
	<groupId>com.atguigu.springcloud</groupId>
	<artifactId>cloud-api-commons</artifactId>
	<version>${project.version}</version>
</dependency>

未完待續

上次更新時間:2021.05.12


后記

好啦,本文到此結束!如果對你有幫助,可以給我點贊+收藏+關注!你的鼓勵是我更新的動力!


  1. 微服務概念及優缺點 ↩︎


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM