springboot 配置文件里部分配置未生效的解決
springboot 配置文件里部分配置未生效
最近用springboot搭了個項目,上線過段時間就會出現(xiàn)卡死,猜測是數(shù)據(jù)庫連接池的連接被占滿,用的連接池是druid,于是給項目加上了一個數(shù)據(jù)庫連接池監(jiān)控。
代碼如下:
@Configuration
public class DruidConfiguration {
/**
*
* 注冊一個StatViewServlet
*
* @return
*
*/
@Bean
public ServletRegistrationBean DruidStatViewServle2() {
// org.springframework.boot.context.embedded.ServletRegistrationBean提供類的進行注冊.
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(),
"/druid/*");
// 添加初始化參數(shù):initParams
// 白名單:
// servletRegistrationBean.addInitParameter("allow", "127.0.0.1");
// IP黑名單 (存在共同時,deny優(yōu)先于allow) : 如果滿足deny的話提示:Sorry, you are not
// permitted to view this page.
// servletRegistrationBean.addInitParameter("deny", "192.168.1.73");
// 登錄查看信息的賬號密碼.
servletRegistrationBean.addInitParameter("loginUsername", "admin");
servletRegistrationBean.addInitParameter("loginPassword", "admin");
// 是否能夠重置數(shù)據(jù).
servletRegistrationBean.addInitParameter("resetEnable", "false");
return servletRegistrationBean;
}
/**
*
* 注冊一個:filterRegistrationBean
*
* @return
*
*/
@Bean
public FilterRegistrationBean druidStatFilter2() {
FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean(new WebStatFilter());
// 添加過濾規(guī)則.
filterRegistrationBean.addUrlPatterns("/*");
// 添加不需要忽略的格式信息.
filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid2/*");
return filterRegistrationBean;
}
}
于是重啟項目,進入監(jiān)控頁面發(fā)現(xiàn)與配置文件里面的部分配置對應不上,當時也沒在意,以為是顯示的默認配置。過陣子又卡死了,發(fā)現(xiàn)等待獲取連接的線程數(shù)有10來個,果然和前面預料到的一樣。于是在配置文件里面各種改數(shù)據(jù)庫連接池的配置。
但,并沒有什么卵用,因為項目根本就沒有讀取到這些配置,這個問題,網(wǎng)上也沒能找到類似的文章和解決方案,到現(xiàn)在也沒有發(fā)現(xiàn)問題出現(xiàn)在哪兒,最后的解決辦法是將配置文件里面關(guān)于數(shù)據(jù)庫的配置全都注釋掉,加上了一個java類來配置
代碼如下:
/**
* druid數(shù)據(jù)連接池配置
* @author win 10
*
*/
@Configuration
public class DatasourceConfig {
@Bean
public DruidDataSource druidDataSource() {
//Druid 數(shù)據(jù)源配置
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://127.0.0.1/autoorder?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true");
dataSource.setUsername("root");
dataSource.setPassword("root");
//初始連接數(shù)(默認值0)
dataSource.setInitialSize(3);
//最小連接數(shù)(默認值0)
dataSource.setMinIdle(1);
//最大連接數(shù)(默認值8,注意"maxIdle"這個屬性已經(jīng)棄用)
dataSource.setMaxActive(20);
dataSource.setMaxWait(30000);
try {
dataSource.setFilters("stat,wall,slf4j");
} catch (SQLException e) {
e.printStackTrace();
}
dataSource.setTestWhileIdle(true);
dataSource.setValidationQuery("SELECT 1");
dataSource.setTimeBetweenEvictionRunsMillis(60000);
dataSource.setMinEvictableIdleTimeMillis(30000);
dataSource.setTestOnBorrow(true);
dataSource.setTestOnReturn(false);
return dataSource;
}
}
重啟項目進入發(fā)現(xiàn)配置is working!卡死的問題解決,但是還是未能找到為什么通過resource里面的配置文件部分配置不生效的原因。
貼出配置文件:
# 服務啟動端口
server.port=8776
#定時器開關(guān)
server.scheduler.syncorder=false
server.scheduler.xepnr=false
# 運維管理相關(guān)參數(shù)
timeout.host=5000
timeout.project=5000
#spring.http.encoding.force=true
#spring.http.encoding.charset=UTF-8
#spring.http.encoding.enabled=true
#server.tomcat.uri-encoding=UTF-8
spring.thymeleaf.content-type=text/html
spring.thymeleaf.cache=false
spring.thymeleaf.mode=LEGACYHTML5
# jdbc_config datasource
#spring.datasource.url=jdbc:mysql://127.0.0.1:3306/autoorder?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
#spring.datasource.username=root
#spring.datasource.password=root
#spring.datasource.driver-class-name=com.mysql.jdbc.Driver
#spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
#spring.datasource.maxActive=20
#spring.datasource.initialSize=1
#spring.datasource.minIdle=3
#spring.datasource.maxWait=20000
#連接空閑時長,超過時則會檢查是否可用,與test-while-idle搭配
#spring.datasource.timeBetweenEvictionRunsMillis=60000
#spring.datasource.minEvictableIdleTimeMillis=300000
#連接空閑時檢查是否可用
#spring.datasource.testWhileIdle=true
#每次獲取連接時 檢查是否可用
#spring.datasource.testOnBorrow=true
#每次歸還連接時 檢查是否可用
#spring.datasource.testOnReturn=fasle
#緩存游標是否開啟
#spring.datasource.poolPreparedStatements=false
#spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置監(jiān)控統(tǒng)計攔截的filters,去掉后監(jiān)控界面sql無法統(tǒng)計,'wall'用于防火墻
#spring.datasource.filters=stat,wall,slf4j
#驗證數(shù)據(jù)庫連接的有效性的sql
#spring.datasource.validationQuery=SELECT 1
#開啟連接回收機制
#spring.datasource.removeAbandoned=true
#單位 s
#spring.datasource.removeAbandonedTimeout=180
#spring.datasource.timeBetweenEvictionRunsMillis=300000
# mybatis_config
mybatis.mapper-locations= classpath:org/jc/db/mapper/*Mapper.xml
mybatis.typeAliasesPackage= org.jc.db.entity
#主鍵類型 0:"數(shù)據(jù)庫ID自增", 1:"用戶輸入ID",2:"全局唯一ID (數(shù)字類型唯一ID)", 3:"全局唯一ID UUID";
global-config.id-type=0
##字段策略 0:"忽略判斷",1:"非 NULL 判斷"),2:"非空判斷"
field-strategy= 2
#駝峰下劃線轉(zhuǎn)換
db-column-underline= true
#刷新mapper 調(diào)試神器
global-config.refresh-mapper= true
#數(shù)據(jù)庫大寫下劃線轉(zhuǎn)換
#capital-mode: true
#序列接口實現(xiàn)類配置
#key-generator: com.baomidou.springboot.xxx
#邏輯刪除配置
#logic-delete-value: 0
#logic-not-delete-value: 1
#自定義填充策略接口實現(xiàn)
#meta-object-handler: com.baomidou.springboot.xxx
#自定義SQL注入器
#sql-injector: com.baomidou.springboot.xxx
## log_config DEBUG ERROR INFO WARN
#logging.level.root=info
##logging.level.io.z77z.dao= DEBUG
#logging.file= ./logs/express_interf.log
#logging.pattern.console= %d{yyyy/MM/dd-HH:mm:ss} [%thread] %-5level %logger- %msg%n
#logging.pattern.file= %d{yyyy/MM/dd-HH:mm} [%thread] %-5level %logger- %msg%n
spring.http.multipart.maxFileSize=100Mb
spring.http.multipart.maxRequestSize=200Mb
有看到的小伙伴知道這個問題所在的歡迎指點一二。
記錄一次創(chuàng)建springboot 配置文件不生效的坑
使用idea自動生成了一個springboot項目。把application.properties改成了application.yml文件。打包成jar包運行。神奇的事情發(fā)生了,設置的端口不生效。
解決:
1.自己把yml文件改回properties文件。運行,仍舊不生效
2.上網(wǎng)百度。各種方案。然后還是不行。
3.突發(fā)奇想,因為我創(chuàng)建的項目是只需要一個五分鐘循環(huán)執(zhí)行的任務,所以我沒導入web的maven。故導入。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency>
問題解決?。。?!以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
springboot整合企微webhook機器人發(fā)送消息提醒
這篇文章主要為大家介紹了springboot整合企微webhook機器人發(fā)送消息提醒,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
Springboot RabbitMQ 消息隊列使用示例詳解
本文通過示例代碼介紹了Springboot RabbitMQ 消息隊列使用,對大家的學習或工作具有一定的參考借鑒價值,感興趣的朋友跟隨小編一起看看吧2024-06-06
解決在for循環(huán)中remove list報錯越界的問題
這篇文章主要介紹了解決在for循環(huán)中remove list報錯越界的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
SpringBoot中MapStruct實現(xiàn)優(yōu)雅的數(shù)據(jù)復制
本文主要介紹了SpringBoot中MapStruct實現(xiàn)優(yōu)雅的數(shù)據(jù)復制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-08-08
centos下GitLab+Jenkins持續(xù)集成環(huán)境搭建(安裝jenkins)
這篇文章主要為大家詳細介紹了centos下搭建GitLab+Jenkins持續(xù)集成環(huán)境,安裝jenkins的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04
詳解java封裝返回結(jié)果與RestControllerAdvice注解
這篇文章主要為大家介紹了java封裝返回結(jié)果與RestControllerAdvice注解實例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09

