主頁 > 資料庫 > 最通俗易懂的ssm框架整合講解

最通俗易懂的ssm框架整合講解

2020-09-18 10:39:43 資料庫

文章目錄

    • 環境
    • 1 Mybatis
      • 1.1 資料庫組態檔
      • 1.2 配置 Mybatis
    • 2 Spring 整合 Mybatis
      • 2.1 Spring 整合 dao 層
        • 2.1.1 context:property-placeholder標簽作用?
        • 2.1.2 資料庫連接池
        • 2.1.3 配置 SqlSessionFactory 物件
        • 2.1.4 配置掃描dao介面包
      • 2.2 Spring 整合 service 層
    • 3 整合 SpringMVC
      • 3.1 web.xml 檔案是如何執行的?
        • 3.1.1 執行順序
        • 3.1.2 init-param標簽
        • 3.1.3 load-on-startup標簽
      • 3.2 springmvc 組態檔是如何執行的?
        • 3.2.1 mvc:annotation-driven作用?
        • 3.2.2 mvc:default-servlet-handler作用?
        • 3.2.3 context:component-scan 作用?
        • 3.2.4 視圖決議器 作用?
    • 4 Spring 配置整合檔案
    • 結束

環境

  • MySQL 8.0.16

1 Mybatis

1.1 資料庫組態檔

jdbc.driver=com.mysql.cj.jdbc.Driver
# 如果使用mysql 6+,增加一個時區的配置
jdbc.url=jdbc:mysql://localhost:3306/ssmbuild?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC&useSSL=false
jdbc.username=root
jdbc.password=123456

com.mysql.jdbc.Driver 與 com.mysql.cj.jdbc.Driver ?

  • com.mysql.jdbc.Driver 是 mysql-connector-java 5 中的
  • com.mysql.cj.jdbc.Driver 是 mysql-connector-java 6 中的

JDBC 連接 mysql 5:

url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false

JDBC 連接 mysql 6:

url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&?useUnicode=true&characterEncoding=utf8&useSSL=false

1.2 配置 Mybatis

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--配置資料源,交給 spring 去做-->
    <typeAliases>
        <package name="com.fyy.pojo"/>
    </typeAliases>

    <mappers>
        <mapper class="com.fyy.dao.BookMapper"/>
    </mappers>
</configuration>

typeAiases 標簽作用?

其中,<typeAiases>標簽的作用只是為 Java 型別指定一個短的名字,它只和xml 配置有關,存在的意義僅在于用來減少類完全限定名的冗余,

指定一個包名,Mybatis 會在此包名下搜索需要的 Java Bean,每一個在此包下的 Java Bean,在沒有注解的情況下,會使用 Bean 的首字母小寫的非限定類名作為它的別名,比如:com.fyy.pojo.User 的別名為:user ,若有注解,則別名為其注解值,如下例子:

@Alias("hello")
public class Hello(){}

mappers標簽作用?

Mybatis 是基于 Sql 映射配置的框架,Sql 陳述句在Mapper 組態檔中,當構建 SqlSession 類之后,就需要去讀取 Mapper 組態檔中的 sql 配置,

mappers : 映射器,以最佳的方式告訴 Mybatis 去哪里找映射檔案,就是用來配置需要加載的 sql 映射組態檔路徑的,

mappers 下的每一個 mapper 都是一個mapper,配置的都是一個獨立的映射組態檔的路徑,配置方式有以下幾種,

1、介面所在包

<mappers>
	<!-- mapper介面所在的包名 -->
	 <package name="com.fyy.mapper"/>
</mappers>

# package標簽,通過 name 屬性指定 mapper 介面所在的包名,此時對應的映射檔案必須
與介面位于同一路徑下,并且名稱相同,

2、相對路徑配置

<mappers>
   	<mapper resource="com/fyy/mapper/FlowerMapper.xml"/>
</mappers>


# mapper標簽,通過 resource 屬性引入 classpath 路徑的相對資源

3、類注冊引入

<mappers>
  	<mapper class="com.fyy.mapper.FlowerMapper"/>
</mappers>

# mapper 標簽,通過 class 屬性指定 mapper 介面名稱,此時對應的映射檔案必須與介面位于同一路徑
下,并且名稱相同

4、使用 url 絕對路徑方式引入(不推薦)

<mappers>
	<mapper url="file:///var/mappers/UserMapper.xml"/>
</mappers>

# mapper 標簽,通過 url 引入網路資源或者本地磁盤資源

總結

只有配置了 mappers 資訊,Mybatis 才知道去哪里加載 Mapper 組態檔,開發中,根據專案中 Mapper 的配置偏好,選擇整合組態檔的配置方式,


2 Spring 整合 Mybatis

2.1 Spring 整合 dao 層

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">

<!--    配置整合Mybatis-->
    <!--1、關聯資料庫組態檔-->
    <context:property-placeholder location="classpath:database.properties"/>

    <!--2、連接池-->
    <!--資料庫連接池
    dbcp 半自動化操作 不能自動連接
    c3p0 自動化操作(自動的加載組態檔 并且設定到物件里面)-->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 配置連接池屬性 -->
        <property name="driverClass" value="${jdbc.driver}"/>
        <property name="jdbcUrl" value="${jdbc.url}"/>
        <property name="user" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>

        <!-- c3p0連接池的私有屬性 -->
        <property name="maxPoolSize" value="30"/>
        <property name="minPoolSize" value="10"/>
        <!-- 關閉連接后不自動commit -->
        <property name="autoCommitOnClose" value="false"/>
        <!-- 獲取連接超時時間 -->
        <property name="checkoutTimeout" value="10000"/>
        <!-- 當獲取連接失敗重試次數 -->
        <property name="acquireRetryAttempts" value="2"/>
    </bean>

    <!-- 3.配置SqlSessionFactory物件 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入資料庫連接池 -->
        <property name="dataSource" ref="dataSource"/>
        <!-- 配置MyBaties全域組態檔:mybatis-config.xml -->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
    </bean>

    <!-- 4.配置掃描Dao介面包,動態實作Dao介面注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
        <!-- 給出需要掃描Dao介面包 -->
        <property name="basePackage" value="com.fyy.dao"/>
    </bean>
</beans>

2.1.1 context:property-placeholder標簽作用?

在開發中有些引數是常量,比如:連接資料庫的 url,password,username 等資訊,不需要常變化,但在不同階段又需要變化,有沒有有一種方案方便我們在一個階段內不需要頻繁寫一個引數的值,但在不同階段間又可以方便的切換引數的配置資訊,

解決方案:Spring 3 中提供了一種簡便的方式就是 content:property-placeholder元素,即可解決上述問題,

在 content:property-placeholder 標簽中 利用屬性 localtion ,值為檔案路徑,可以使用 classpath: 指定檔案名即可,這里我們關聯上資料庫配置資訊,

Spring 容器中僅允許最多定義一個 context:property-placeholder ,其余的會被忽略,

2.1.2 資料庫連接池

每次創建一個資料庫連接都是一次極大的資源消費,所以連接復用,通過建立一個資料庫連接池以及一套連接使用管理策略,可以使一個資料庫連接可以得到高效、安全的復用,能避免了資料庫連接池頻繁建立、關閉的開銷,

連接池的本質:介于 Java 和 JDBC 之間的 Java jar 包!

第1步中,我們關聯了資料庫配置資訊,利用 bean 標簽可獲取其中的配置資訊,

可根據專案實際開發中,配置連接池的最大數量、最小數量、關閉連接后是否自動 commit、獲取連接超時時間、獲取連接失敗重試次數等,很多屬性,在這不一 一贅述了,

2.1.3 配置 SqlSessionFactory 物件

SqlSessionFacoty 的作用就是創建 SqlSession,SqlSession 就是一個會話,相當于 JDBC 中的 Connection 物件,每次應用訪問資料庫,就要通過 SqlSessionFactory 創建 SqlSession ,所以 SqlSessionFacoty 應該在 Mybatis 整個生命周期中,每一個資料庫只應該對應一個 SqlSessionFacoty.

SqlSessionFacoty 在整個 Mybatis 運行流程中的作用如下圖,
在這里插入圖片描述
配置 SqlSessionFactory 物件時,將資料庫連接池注入到其中,再配置 mybatis 全域組態檔 ,
我的理解是:在 SqlSessionFactory 創建 SqlSession 連接資料庫時,需要知道資料庫連接池的資訊,以及資料源,

2.1.4 配置掃描dao介面包

MapperScannerConfigurer 自動掃描將 Mapper 介面生成代理注入到 Spring容器,Mybatis 在與 Spring 整合的時候配置 MapperFactoryBean 來生成 Mapper 介面的代理, basePackage 屬性是讓你為映射器介面檔案設定基本的包路徑,你可以使用分號或者逗號作為分隔符設定多余一個包的路徑,每個映射器將會在指定的包路徑中遞回的被搜索到, 注意,沒有必要去指定 SqlSessionFactory 或 SqlSessionTemplate,因為 MapperScannerConfigurer 將會創建 MapperFactoryBean,之后自動裝配,但如果使用了一個以上的 DataSource,那么自動裝配可能會失效,這種情況下,可以使用 sqlSessionFactoryBeanName 或 sqlSessionTemplateBeanName 屬性來設定正確的 bean 名稱來使用,

大白話理解:掃描dao層的介面,MapperScannerConfigurer 會自動為每個介面生成一個 介面代理,這個介面代理是介面的實作類,并注入到Spring容器中,

2.2 Spring 整合 service 層

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans.xsd
   http://www.springframework.org/schema/context
   http://www.springframework.org/schema/context/spring-context.xsd">

    <!-- 掃描service相關的bean -->
    <context:component-scan base-package="com.fyy.service" />

    <!--BookServiceImpl注入到IOC容器中-->
    <bean id="BookServiceImpl" class="com.fyy.service.BookServiceImpl">
        <property name="bookMapper" ref="bookMapper"/>
    </bean>

    <!-- 配置事務管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入資料庫連接池 -->
        <property name="dataSource" ref="dataSource" />
    </bean>
</beans>

事務管理器:DataSourceTransactionManager

事務管理是應用系統開發中必不可少的一部分,Spring 為事務管理提供了豐富的功能支持,Spring 事務管理分為編碼式和宣告式的兩種方式,編程式事務指的是通過編碼方式實作事務;宣告式事務基于 AOP,將具體業務邏輯與事務處理解耦,宣告式事務管理使業務代碼邏輯不受污染, 因此在實際使用中宣告式事務用的比較多,宣告式事務有兩種方式,一種是在組態檔(xml)中做相關的事務規則宣告,另一種是基于 @Transactional 注解的方式,

其中 組態檔宣告事務,是將資料庫連接池注入到 事務管理器中,關于注解方式宣告事務,就不在這里做過多介紹,后期會單獨拿出來分享Spring事務,


3 整合 SpringMVC

web.xml 組態檔

3.1 web.xml 檔案是如何執行的?

3.1.1 執行順序

訪問順序為:1->2->3->4,其中 2 和 3 的值必須相同,

url-pattern標簽代表當一個請求發送到 servlet 容器時,容器會先將請求的 url 減去 當前應用背景關系的路徑作為 servlet 的映射 url,比如我訪問的是 http://localhost/test/aaa.html,我的應用背景關系是 test,容器會將 http://localhost/test 去掉,剩下的 /aaa.html 部分拿來做 servlet 映射匹配,如果與 設定的 url-pattern 映射匹配成功,請求才會被 DispatcherServlet 處理,圖中的 <url-pattern> 中的值為:/,代表所有請求都會被處理,

而被DispatcherServlet 處理前,還會經過 2 ,3 步驟,url 匹配成功后,這個 url 訪問名為 servlet-name 中值的 servlet,兩個 servlet-name 值必須相同,因為 servlet 標簽中的 servlet-name 標簽映射到 servlet-class 標簽中的值,最終訪問 servlet-class 標簽中的 DispatcherServlet 類,此時,請求才會被 DispatcherServlet 處理,

3.1.2 init-param標簽

圖中 \標簽中的 \標簽作用是,設定 springmvc 組態檔位置以及名稱,springmvc組態檔不設定默認位置是:webapp,可以使用 classpath 設定檔案的名稱為:spring-mvc.xml ,代表 springmvc 組態檔名必須為 spring-mvc.xml,如不使用 classpath 設定其路徑及名稱,默認在 webapp下,名稱為:\標簽中的值 + "-servlet.xml",例如:如 標簽中值為:springmvc,則默認的 springmvc 組態檔名為:springmvc-servlet.xml

3.1.3 load-on-startup標簽

圖中 \標簽作用是,設定 servlet加載時間,如不設定默認在第一次請求訪問時加載 servlet,若設定此標簽值為正整數,會將 servlet 的加載時間提前到專案啟動時,此標簽中可以寫整數,但寫負整數和0和沒有設定是一樣的效果,只有設定為正整數才會將 servlet 的加載時間提前到專案啟動時,也就是 tomcat 啟動時,值越小,代表優先級越高,

3.2 springmvc 組態檔是如何執行的?

spring-mvc.xml 組態檔

3.2.1 mvc:annotation-driven作用?

springmvc注解驅動會自動注冊:DefaultAnnotationHandlerMapping 與 AnnotationMethodHandlerAdapter 兩個bean,這兩個 bean 是 SpringMVC 為 @Controller 分發請求所必須的,解決了使用 @Controller 注解的前提配置,

在 Spring MVC 3.1 以上:

  • DefaultAnnotationHandlerMapping 變更為:RequestMappingHandlerMapping
  • AnnotationMethodHandlerAdapter 變更為:RequestMappingHandlerAdapter
通常如果我們希望通過注解的方式來進行 SpringMVC開發,我們會在 springmvc 組態檔中使用 注解驅動:\,那這個標簽做了什么?通過尋找原始碼,找到注解驅動的實作類是:org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser

我們來看看這個類主要做了什么作業?

AnnotationDrivenBeanDefinitionParser類向工廠中注冊了幾個 bean 實體,其中包括:

  • RequestMappingHandlerMapping
  • BeanNameUrlHandlerMapping
  • RequestMappingHandlerAdapter
  • HttpRequestHandlerAdapter
  • SimpleControllerHandlerAdapter
  • ExceptionHandlerExceptionResolver
  • ResponseStatusExceptionResolver
  • DefaultHandlerExceptionResolver

上面的bean實體都是做什么的呢?

前兩個 bean 是 HandlerMapping 介面的實作類,用來處理請求映射的,其中第一個處理是 @RequestMapping 注解的,第二個是將 controller 類的名字映射為 請求 url,中間三個 adpter 是用來處理請求的,具體說就是確定呼叫哪個 controller 的哪個方法來處理當前請求,第一個處理 @Controller 注解的處理器,支持自定義方法引數和回傳值,第二個是處理繼承 HttpRequestHandler 的處理器,第三個處理繼承自 Controller 介面的處理器,后面三個是用來處理例外的決議器,

結論

如果使用@Controller 注解,沒有配置注解驅動: <mvc:annotation-driven> 的話,那么所有的請求都無法找到 DispatcherServlet ,并無法把請求分發至控制器,添加注解驅動后,才會掃描所有帶有 @Controller 注解的類,由 spring 管理并維護,

3.2.2 mvc:default-servlet-handler作用?

還記得我們在 web.xml 中配置了 url-pattern,用來過濾請求,SpringMVC 將接收到的所有請求都看做是一個普通請求,包括對于靜態資源的請求,這樣一來,所有對于靜態資源的請求都會被看做是一個普通的后臺控制器請求,而靜態資源的請求會因為找不到資源而報404例外,查看 tomcat 日志就可以看到會有警告,

在這里插入圖片描述

對于此問題 SpringMVC 在全域組態檔中提供了一個 <mvc:default-servlet-handler>標簽,在 web 容器啟動的時候會在背景關系中定義一個 DefaultServletHttpRequestHandler ,它會對 DispatcherServlet 請求進行處理,如果該請求已經做了映射,那么會接著交給后臺對應的處理程式,如果沒有映射,就交給 web 應用服務器默認的 servlet 處理,從而找到對應的靜態資源,只有找不到靜態資源時會報錯,

如果默認的 Servlet 容器不用默認的 default ,用不同名稱進行自定義配置,或者在預設 Servlet 名稱未知的情況下使用了不同的 Servlet 容器,則必須顯示提供默認 Servlet 的名稱,

<mvc:default-servlet-handler default-servlet-name="myCustomDefaultServlet"/>

3.2.3 context:component-scan 作用?

掃描組件,將所有使用 @Controller 注解的類作為 SpringMVC 的控制層,其中 base-package 屬性是指定掃描的包,

3.2.4 視圖決議器 作用?

視圖決議器,是將 prefix + 視圖名稱 + suffix = 確定最終要跳轉的頁面,其中視圖名稱是什么?? 處理請求的方法會回傳一個字串,這個字串即視圖名稱,最侄訓通過組態檔中配置的視圖決議器實作頁面的跳轉,例如:
@Controller
public class TestController {
    @RequestMapping("hello")
    public String hello() {
        System.out.println("success");
        return "success";
    }
}

# 其中回傳字串為:success,所以處理此請求最終要跳轉的頁面為:/WEB-INF/view/success.jsp

關于 SpringMVC的講解可以查看小編的另一篇文章,SpringMVC從基礎到原始碼


4 Spring 配置整合檔案

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd">

    <import resource="classpath:spirng/spring-dao.xml"/>
    <import resource="classpath:spirng/spring-service.xml"/>
    <import resource="classpath:spirng/spring-mvc.xml"/>
</beans>
applicationContext.xml,Spring 的核心組態檔,也可以通過組態檔修改名稱, 什么時候讀取組態檔,當我們在客戶端新建 ApplicationContext 實體時,會加載此組態檔,其中常用的 ApplicationContext 實作類有:
  • ClassPathXmlApplicationContext
  • ClassPathResource
  • XmlWebApplicationContext
  • FileSystemXmlApplicationContext
其中 \ 是將多個組態檔通過匯入的方式整合,讓配置資訊更清晰,達到了解耦的效果,

結束

以上就是本人學習ssm框架配置的總結,有的地方不夠深入,但對于初學者來說應該也會識訓頗豐,如有錯誤,還請大佬們指正!

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/73088.html

標籤:其他

上一篇:京東 9.17筆試題 Java

下一篇:震撼!!京東架構師親自花費一個月時間總結的BATJ面試真題,劍指金九銀十。

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more