精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

系統設計 | Java 應用中的配置含義和避坑

開發 前端
關于 Mybatis 的 map-underscore-to-camel-case 配置有一個坑,這個配置的含義是把數據庫列名中的下劃線自動映射為 Java 對象中的駝峰命名。

這篇文章整理了 Spring Boot 和常見的應用中間件配置含義,了解這些配置的目的和原理,避免因為錯誤配置導致生產出現問題,特別是有一些安全問題。

PS:寫下來發現東西非常多,很多時候我們都只是拷貝過來改改沒問題就不管了,但是這樣囫圇吞棗,會給項目帶來風險。

1. Spring Boot 相關

優雅停機

優雅停機是指當應用接收到停機信號時,能夠妥善地處理正在進行的請求,釋放資源,并在完成這些工作后再停止應用。

如果不開啟優雅停機,有可能在部署的過程中讓少量未完成的任務和請求直接終止,帶來意想不到的問題。

默認情況下,Spring Boot 沒有啟用優雅停機,而且往往需要和云環境配合使用。

在 Spring Boot 中的配置方式為(本文以 yaml 的格式):

server:
  shutdown: graceful

同時可以設置一個優雅停機的超時時間,如果在超時時間內請求沒有完成,應用將強制停機。

spring:
  lifecycle:
    timeout-per-shutdown-phase: 30s

Kubernetes 在停止 Pod 時,會先發送一個 SIGTERM,并通過 Readiness Probe和Liveness Probe 兩個探針來決定是否釋放容器資源。

探針就是應用通過一個 API(可以是 HTTP 或者 TCP,通常都是 HTTP)告訴 Kubernetes 它當前的狀態,讓 Kubernetes 來決策何時重啟,關于優雅停機的內容比較多,后面單獨一篇文章討論。

在 Spring Boot 中,探針就是 Spring Boot 的 health 接口,可以通過 Indicator 配置。

Indicator

Spring Boot 提供了一些健康狀態的 API,這樣就可以給云平臺優雅停機使用,也可以提供給監控系統用來撥測,如果系統長時間不健康,可以進行告警。

在代碼中實現健康狀態的類叫做 Indicator,基本上默認配置的 Indicator 就夠用了,但有時候需要根據自己需要配置一些 Indicator。

比如依賴了一個重要的三方系統,這個三方系統不啟動起來,當前系統啟動了也沒意義,于是就可以加一個 Indicator,甚至把三方系統的狀態暴露到當前系統的健康狀態信息中。

暴露相關健康 API 需要引入一個 actuator 依賴:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

下面是一個例子:

import org.springframework.boot.actuate.health.Health;
import org.springframework.boot.actuate.health.HealthIndicator;
import org.springframework.stereotype.Component;

@Component
public class CustomHealthIndicator implements HealthIndicator {

    @Override
    public Health health() {
        boolean isHealthy = checkSomeServiceHealth();
        
        if (isHealthy) {
            return Health.up().withDetail("customService", "UP").build();
        } else {
            return Health.down().withDetail("customService", "DOWN").build();
        }
    }

    private boolean checkSomeServiceHealth() {
        // 檢查邏輯
        return true; 
    }
}

訪問 /actuator/health 接口,返回結果大概像下面這樣:

{
  "status": "UP",
  "components": {
    "db": {
      "status": "UP",
      "details": {
        "database": "MySQL",
        "validationQuery": "isValid()"
      }
    },
    "customService": {
      "status": "UP",
      "details": {
        "CustomService": "UP"
      }
    },
    ……
  }
}

打開相關配置:

management:
  endpoints:
    web:
      exposure:
        include: health,info

在這個配置中,info 類似 health, 提供了一些服務信息,例如名稱、版本之類的,但是要注意避免把敏感信息從這個接口中暴露出去了。

Actuator

提到了 Actuator,這里有一些配置是不能在生產環境開啟的,這是比較常見的錯誤,需要注意。

Actuator 除了提供了 health,info 兩個接口,還提供了一堆接口,方便觀察 Spring Boot 應用,這些接口都可以在開發環境開啟。例如:

  • /health: 顯示應用的健康狀態及詳細信息。
  • /info: 顯示應用的一些基本信息(例如版本、描述等)。
  • /env: 查看和調試環境屬性,了解配置項的來源。
  • /beans: 用于調試 Bean 的創建和依賴關系。
  • /metrics: 查看應用的性能指標,如內存使用情況、GC 活動等。
  • /httptrace: 用于查看最近 HTTP 請求的詳細信息。
  • /mappings: 用于查看所有請求映射的路徑,方便調試路由問題。

這些接口開啟后會造成安全、性能問題。

所以推薦的配置如下。

開發環境:

management:
  endpoints:
    web:
      exposure:
        include: "*"
  endpoint:
    health:
      show-details: always  # 顯示詳細健康信息,方便調試

endpoints 只是暴露外部是否可以訪問,實際的功能需要單獨開啟,health,info,metrics 三個接口是默認開啟的。

如果需要打開 beans,可以單獨開啟:

management:
  logfile:
    enabled: true           # 允許查看日志文件,方便調試
  env:
    enabled: true           # 允許查看環境變量配置
  configprops:
    enabled: true           # 允許查看配置屬性,幫助調試
  beans:
    enabled: true           # 允許查看 Bean 信息,調試依賴關系
  heapdump:
    enabled: true           # 啟用 Heap Dump,用于內存分析
  threaddump:
    enabled: true           # 啟用線程轉儲,用于線程分析
  mappings:
    enabled: true           # 允許查看所有請求映射,調試路由問題
  httptrace:
    enabled: true           # 啟用 HTTP 請求追蹤

而生產環境,需要將其關閉,只保留需要開啟的配置:

management:
  endpoints:
    web:
      exposure:
        include: "health,info,metrics"
  endpoint:
    health:
      show-details: never   # 隱藏健康檢查的詳細信息,防止敏感數據泄露

日志

日志配置錯誤會導致磁盤被日志寫滿,另外日志級別過低,性能會急劇下降。

在以前還不是容器時代,我們常常使用日志文件存儲日志,再使用一些工具轉存走,有時候清理日志的腳本失效,導致磁盤被日志寫爆的場景非常多。

下面是一個在容器環境下 Spring Boot 默認日志庫的配置:

logging:
  level:
    root: INFO
    org.springframework: WARN #這里放上特定包的日志配置
  pattern:
    console: "%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n"
  file:
    enabled: false # 生產環境通常不直接寫入文件,而是由 K8s 日志收集系統處理
  stdout:
    enabled: true

在生產上我們一般將日志級別設置為 INFO,并關閉文件輸出,而是將日志輸出到 stdout 中,由容器捕獲。

在開發環境,我們通常把日志設置為 DEBUG,更加方便調試。

秘鑰和口令

正常情況下,大多數應用都不會把口令存放到配置文件中,敏感信息需要放到秘鑰管理系統中(Key Management System)。

例如,在 k8s 中,我們可以使用 Secrets 代替明文的 ConfigMap;云平臺往往提供了相關的 KMS 產品,例如 Alicloud KMS。

2.Mysql

這里給出一個 Mysql 和 Mybatis 的典型配置,并解釋一下關鍵配置的含義和避坑經驗。

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydatabase?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC&autoReconnect=true&rewriteBatchedStatements=true
    username: your_username
    password: your_password
    driver-class-name: com.mysql.cj.jdbc.Driver
    hikari:
      maximum-pool-size: 10
      minimum-idle: 5
      idle-timeout: 30000
      max-lifetime: 1800000
      connection-timeout: 30000

mybatis:
  mapper-locations: classpath*:mapper/*.xml
  type-aliases-package: com.example.project.domain
  configuration:
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

連接字符串中的配置:

  • useUnicode:啟用了 Unicode 支持。
  • characterEncoding:字符編碼,最好在 useUnicode 配置后,characterEncoding 也明確配置一下,否則它會選擇一個默認的 Unicode 字符編碼。另外,我們現在用的更多的是 utf8mb4,它是 UTF8 的拓展字符集,可以處理更多特性,例如表情,最多占用 4 個字節的空間。
  • useSSL:如果啟用,需要證書,一般我們都沒有配置。
  • serverTimezone:關于時區,我們一般都不讓數據庫決策,而讓應用決定寫入數據的時區,這個問題我在以前的文章,《系統設計中需要考慮到的時間問題》,做過詳細說明。
  • autoReconnect:自動重連,如果不開啟的話,數據庫重啟了應用也必須重啟。
  • rewriteBatchedStatements:自動優化批量插入時的性能。

關于 driver-class-name,對于 MySQL Connector/J 8.0 以上,類名換成了 com.mysql.cj.jdbc.Driver,舊版本是 com.mysql.jdbc.Driver。

關于 hikari 配置的含義:

  • maximum-pool-size: 最大連接數,連接池中的最大連接數。
  • minimum-idle: 最小空閑連接數。
  • idle-timeout: 空閑連接被回收前的最大等待時間(毫秒)。
  • max-lifetime: 連接在池中的最長存活時間(毫秒)。
  • connection-timeout: 獲取連接的超時時間(毫秒)。

hikari 的配置只是建議值,hikari 配置邏輯是什么呢?一般是基于性能測試反復調整,但還是有一些規律。

這里有個坑,有時候為了優化性能,提高了最大連接數。但一般數據庫的連接數是有限制的,比如 1000。假設一個系統共同一個Mysql實例,系統共有 10 個服務,每個服務如果有 10 個容器,最大連接數最多就只能配置到 10 了,否則就會報沒有鏈接的錯誤(而且是偶爾出現這類問題)。

maximumPoolSize 通常設置為數據庫的并發連接限制的 50% 到 80% 之間,單個容器允許 10 個 Mysql 連接并不大,maximum-pool-size 可以在 10 - 50 之間調整。

connection-timeout 過短,在數據庫負載高或網絡不穩定的情況下,可能導致頻繁的連接超時,可以嘗試往長一點調整。

max-lifetime、minimum-idle 取決于負載情況,如果持續負載比較高,可以設置長一些,不用為數據庫節省資源,讓連接長時間保持。

關于 Mybatis 的 map-underscore-to-camel-case 配置有一個坑,這個配置的含義是把數據庫列名中的下劃線自動映射為 Java 對象中的駝峰命名。例如,user_name 列將映射為 userName 屬性。但有的時候,命名不規范,有些詞可能是一個詞組而沒有大寫,會導致匹配失敗。

責任編輯:武曉燕 來源: TechLead 少個分號
相關推薦

2020-08-26 07:37:25

Nacos微服務SpringBoot

2010-07-13 15:31:49

ftp命令

2024-03-28 12:51:00

Spring異步多線程

2018-01-20 20:46:33

2024-04-03 12:30:00

C++開發

2024-04-24 13:45:00

2025-07-22 08:25:31

Android廣播LiveData

2020-06-12 11:03:22

Python開發工具

2023-04-12 08:18:40

ChatGLM避坑微調模型

2021-02-26 00:46:11

CIO數據決策數字化轉型

2022-09-26 09:53:18

開發緩存

2020-12-16 10:00:59

Serverless數字化云原生

2022-07-12 08:24:01

隊列容量調度hadoop

2018-09-05 11:51:55

數據庫NoSQLMongoDB

2025-06-18 10:00:00

Redis事務Java

2023-05-24 10:06:42

多云實踐避坑

2021-05-07 21:53:44

Python 程序pyinstaller

2021-02-22 17:00:31

Service Mes微服務開發

2021-05-08 12:30:03

Pythonexe代碼

2022-03-04 18:11:16

信服云
點贊
收藏

51CTO技術棧公眾號

在线看一区二区| 成人免费观看av| 日韩在线免费视频| 免费人成视频在线播放| аⅴ资源新版在线天堂| 狠狠色丁香久久婷婷综| 久久人人爽国产| av男人的天堂av| 国产成年精品| 欧美日韩一区二区在线| 日本高清不卡aⅴ免费网站| 中文字幕在线亚洲| 欧美又黄又嫩大片a级| 激情aⅴ欧美一区二区欲海潮| 久久久.com| 99在线视频免费观看| 亚洲中文字幕无码爆乳av| 亚洲成人三区| 亚洲欧美一区二区激情| 久久aaaa片一区二区| 欧美自拍电影| 亚洲一二三区视频在线观看| 四虎一区二区| 天堂在线资源8| 久国产精品韩国三级视频| 91av在线不卡| 国产精品成人免费观看| 精品一区毛片| 亚洲成av人片在线观看香蕉| 国产精品自在自线| 大胆人体一区二区| 亚洲影视资源网| 亚洲狠狠婷婷综合久久久| 人妻妺妺窝人体色www聚色窝 | 亚洲国产精品一区在线观看不卡| 丁香花免费高清完整在线播放| 蜜桃一区二区三区在线观看| 91av中文字幕| 麻豆一区产品精品蜜桃的特点| 日韩欧美自拍| 国产视频欧美视频| 无码国产69精品久久久久网站 | 中文字幕免费一区二区| 中文国产成人精品| 精品无码在线观看| 亚洲丝袜啪啪| 日韩av网站大全| 精品国产免费久久久久久婷婷| 日本久久久久| 欧美日韩视频在线观看一区二区三区| 北条麻妃在线视频观看| 国产一二在线播放| 伊人开心综合网| 日本不卡一区二区三区四区| 亚洲视频tv| 91啦中文在线观看| 久久久久久久久久久久久9999| 日韩有码第一页| 高清久久久久久| 成人免费视频网站入口| 亚洲经典一区二区三区| 国产精品911| 91高跟黑色丝袜呻吟在线观看| 国产精品欧美激情在线| 黄色精品一二区| 成人妇女免费播放久久久| 91麻豆视频在线观看| 久国产精品韩国三级视频| 成人中心免费视频| h狠狠躁死你h高h| 国产精品一区二区在线播放| 2022国产精品| 天堂中文资源在线观看| 91色.com| 日韩一区国产在线观看| 三区四区在线视频| 亚洲精品一二三| 久久这里只有精品8| 国产免费拔擦拔擦8x高清在线人| 欧美日韩一区二区在线 | 免费在线视频欧美| 亚洲美女在线一区| 真人抽搐一进一出视频| 美女在线视频免费| 欧美图片一区二区三区| 992kp免费看片| 波多野结衣在线一区二区| 亚洲精品wwwww| 日韩人妻无码精品综合区| 欧美中文一区二区| 欧美成人亚洲成人| 中日韩黄色大片| 人妖欧美一区二区| 91在线播放视频| 亚洲 另类 春色 国产| 国产欧美日韩另类视频免费观看| 中文字幕一区二区三区在线乱码 | 免费的毛片视频| 麻豆成人久久精品二区三区小说| 成人亲热视频网站| 欧美一级视频免费| 国产欧美日韩中文久久| 97超碰人人爱| 亚洲美女炮图| 8v天堂国产在线一区二区| 国产精品福利导航| 99久久久久久中文字幕一区| 午夜美女久久久久爽久久| 糖心vlog精品一区二区| 懂色av中文一区二区三区| 欧美性bbwbbwbbwhd| 国产剧情在线| 欧美性猛交xxxx免费看| 一级日本黄色片| 久久91麻豆精品一区| 欧美日韩国产成人在线观看| 国产婷婷色一区二区在线观看| 国内精品免费在线观看| 欧洲亚洲一区二区| segui88久久综合9999| 欧美日韩一级视频| 国产中文字幕一区二区| 综合天堂av久久久久久久| 日韩免费中文字幕| 黄色美女一级片| 国产精品不卡在线观看| 国产性xxxx18免费观看视频| 日韩在线网址| 久久精品国产亚洲精品| 中文字幕一区二区人妻视频| 不卡一区在线观看| 成年人视频大全| 久久免费资源| 亚洲人成五月天| 日韩福利片在线观看| 国产精品资源在线看| 婷婷四房综合激情五月| 爱情电影社保片一区| 亚洲成人网久久久| 免费视频一二三区| 国模无码大尺度一区二区三区 | 91综合久久一区二区| 国产999精品久久久影片官网| 免费激情视频网站| 一区二区三区四区亚洲| 天天操精品视频| 色综合天天综合网中文字幕| 国产精品第一区| 久久久资源网| 日本精品视频一区二区三区| 五级黄高潮片90分钟视频| 在线精品一区| 精品国产中文字幕| 成人一级福利| 亚洲国产小视频在线观看| 国产精品999久久久| 国产69精品久久777的优势| 五月天激情图片| 日韩视频一区二区三区四区| 欧美大尺度在线观看| 国产高清在线免费| 亚洲影视资源网| 天堂www中文在线资源| 亚洲三级观看| 蜜桃视频在线观看91| 波多野结衣亚洲| 亚洲午夜未删减在线观看 | 色综合久久中文字幕| 丰满圆润老女人hd| 日韩高清一级片| 亚洲国产一区二区在线| 国产精品**亚洲精品| 美女扒开尿口让男人操亚洲视频网站 | 天天射天天综合网| 亚洲qvod图片区电影| 婷婷色在线资源| 亚洲国产97在线精品一区| 国产女同在线观看| 国产欧美一区二区精品仙草咪| 中日韩av在线播放| 国产一区二区三区自拍| 久久精品综合一区| 欧美123区| 久久影院在线观看| 色呦呦免费观看| 日本韩国精品在线| 国产成人av免费在线观看| 成人性生交大合| 精品www久久久久奶水| 欧美a级片视频| 成人18视频| 我爱我色成人网| 欧美成在线观看| 欧美偷拍视频| 欧美情侣在线播放| 懂色av.com| 亚洲国产成人在线| 美国黄色一级视频| 免费在线视频一区| 精品无码国产一区二区三区av| 精品久久网站| 97人人模人人爽人人喊38tv| 性欧美18xxxhd| 久久的精品视频| 毛片免费在线播放| 日韩一区二区影院| 国产精品午夜一区二区| 亚洲成人福利片| 免费黄色国产视频| 91亚洲资源网| 国产黄色一区二区三区| 久久只有精品| 奇米影视亚洲色图| 婷婷综合激情| 欧美一进一出视频| 成人h动漫精品一区二区器材| 国产精品久久77777| 9999在线视频| 不卡av在线播放| www.久久热.com| 日韩精品视频免费| 人人妻人人玩人人澡人人爽| 欧美丰满少妇xxxbbb| 日本成人一级片| 日韩欧亚中文在线| 国产精品成人久久| 亚洲激情欧美激情| 亚洲aaa视频| 久久精品人人做| 日韩免费高清一区二区| 国产激情一区二区三区四区 | 久久久久亚洲AV成人| 国产精品美日韩| 最近中文字幕免费视频| 99视频国产精品| 亚洲成a人片在线www| 国产伦精一区二区三区| 天天综合天天添夜夜添狠狠添| 久久久久久夜| 黄色片久久久久| 亚洲一区日韩| 5月婷婷6月丁香| 亚洲看片一区| 超碰成人免费在线| 亚洲高清二区| 人妻少妇精品久久| 亚洲国产精品第一区二区| 国产 欧美 日本| 欧美三级黄美女| avav在线播放| 国产精品国码视频| 无码 制服 丝袜 国产 另类| 亚洲天堂成人| 日本a在线免费观看| 亚洲高清网站| av免费观看大全| 亚洲一区日本| 免费观看成人网| 亚洲综合欧美| 欧美黄色一级片视频| 青青草97国产精品免费观看| 蜜臀av免费观看| 久久精品国产一区二区| www.com久久久| 国产高清精品网站| 亚洲少妇中文字幕| 99久久精品国产一区| 国产精品揄拍100视频| 国产婷婷色一区二区三区在线| 波多野在线播放| 中文字幕av一区二区三区免费看 | 国产精品探花在线观看| 天堂va久久久噜噜噜久久va| 图片小说视频色综合| 欧美一级中文字幕| 一区二区91| 亚洲一级免费观看| 国产一区不卡视频| 中文字幕第3页| 国产视频在线观看一区二区三区 | 在线观看的毛片| 九九精品视频在线看| 中文字幕无码毛片免费看| 国产精品资源网站| 91精品国产自产| 国产精品久久久久久亚洲伦| avove在线播放| 精品免费在线视频| 亚洲一区二区三区网站| 精品国产一区久久| 国产小视频免费在线网址| 日韩视频在线免费| av免费不卡国产观看| 国产成人精品日本亚洲| 国内精品视频| 麻豆久久久9性大片| 欧美激情黄色片| 欧美一级视频免费看| 日韩**一区毛片| 香蕉久久久久久av成人| 国产精品网站一区| 国产手机在线视频| 欧美巨大另类极品videosbest| 人妻少妇精品无码专区久久| 最近2019好看的中文字幕免费 | 97超级碰碰人国产在线观看| 成人四虎影院| 黄色小网站91| 香蕉av一区二区| 免费在线观看的av网站| 国产成人精品网址| 国产午夜精品福利视频| 精品久久久久久久久久久久久久| 一级黄色录像大片| 亚洲精品视频免费| 成年网站在线视频网站| 国产日韩欧美在线| 国产一区二区三区日韩精品| 拔插拔插海外华人免费| 久久99国产精品免费网站| 亚洲第一页av| 亚洲国产一区二区三区青草影视| 一级黄色片在线| 亚洲男人av电影| 国产精品yjizz视频网| 91精品网站| 欧美好骚综合网| 一级在线免费视频| 国产亚洲欧美日韩日本| 99热在线观看免费精品| 日韩一级完整毛片| 精品视频在线一区二区| 国产精品露脸自拍| 久久av超碰| 北条麻妃在线观看| 97精品久久久午夜一区二区三区| 国产一级性生活| 精品久久久影院| 午夜小视频福利在线观看| 91久久久久久久| 欧美激情国产在线| 精品久久久99| 国产精品不卡在线观看| 91av国产精品| 精品国内自产拍在线观看| 粉嫩av一区二区三区四区五区| 欧美日韩免费观看一区| 久久这里有精品15一区二区三区| 不卡一区二区在线观看| 日韩欧美亚洲成人| 毛片在线播放网站| 国产精品99久久久久久久久 | 亚洲精品成人久久久| 99久久精品免费看国产小宝寻花 | 欧美日本在线视频中文字字幕| 精品国产鲁一鲁****| 国内外成人激情免费视频| 国产乱妇无码大片在线观看| 色欲人妻综合网| 日韩欧美国产麻豆| 国内小视频在线看| 久久99国产精品| 爽爽淫人综合网网站| 亚洲激情图片网| 日韩一区二区精品葵司在线| av在线导航| 国产在线播放一区二区| 中文一区在线| 99久久精品免费视频| 欧美人成免费网站| 青春草在线免费视频| 国产自产在线视频一区| 久久精品女人| 精品伦精品一区二区三区视频密桃 | 蜜桃视频成人m3u8| 亚洲一区精彩视频| 国产成人免费视频网站| 五月婷婷中文字幕| 中文字幕国产日韩| 91精品啪在线观看国产手机| 国产中文字幕在线免费观看| 中文字幕二三区不卡| 国产口爆吞精一区二区| 久久久久久综合网天天| 神马电影久久| 亚洲图片 自拍偷拍| 午夜精品一区二区三区免费视频| 狠狠狠综合7777久夜色撩人| 成人动漫网站在线观看| 99精品福利视频| 91动漫免费网站| 亚洲精品国产精品久久清纯直播| 日韩精品影院| 久久艹国产精品| 中文字幕免费观看一区| 亚洲精品视频网| 国产精品久久久久99| 在线视频观看日韩| 三级黄色免费观看| 亚洲国产精品热久久|