springboot配置mysql数据库spring.datasource.url报错的解决
作者:wandrong 发布时间:2023-10-04 12:49:26
springboot配置mysql数据库spring.datasource.url报错
spring.datasource.url=jdbc:mysql://abc:3306/abcd?useUnicode=true&characterEncoding=utf8
很常规地配置了这个mysql的url后发现报错
Wed Oct 24 14:59:16 CST 2018 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.
根据介绍,这里需要在URL那指定useSSL这个属性
然后试过useSSL=true
spring.datasource.url=jdbc:mysql://abc:3306/abcd?useUnicode=true&characterEncoding=utf8&useSSL=true
又报了一个错
Caused by: java.security.cert.CertificateException: java.security.cert.CertPathValidatorException: Path does not chain with any of the trust anchors
at com.mysql.jdbc.ExportControlled$X509TrustManagerWrapper.checkServerTrusted(ExportControlled.java:302)
at sun.security.ssl.AbstractTrustManagerWrapper.checkServerTrusted(SSLContextImpl.java:984)
at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1496)
... 31 common frames omitted
Caused by: java.security.cert.CertPathValidatorException: Path does not chain with any of the trust anchors
at sun.security.provider.certpath.PKIXCertPathValidator.validate(PKIXCertPathValidator.java:153)
at sun.security.provider.certpath.PKIXCertPathValidator.engineValidate(PKIXCertPathValidator.java:79)
at java.security.cert.CertPathValidator.validate(CertPathValidator.java:292)
at com.mysql.jdbc.ExportControlled$X509TrustManagerWrapper.checkServerTrusted(ExportControlled.java:295)
... 33 common frames omitted
没有证书设置的话这里只能useSSL=false
最终这样设置
spring.datasource.url=jdbc:mysql://abc:3306/abcd?useUnicode=true&characterEncoding=utf8&useSSL=false
springboot下datasource连接配置
基本设置
spring.datasource.secondary.url=jdbc:mysql://localhost:3306/test2?useUnicode=true&characterEncoding=utf-8
spring.datasource.secondary.username=test
spring.datasource.secondary.password=123456
spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
#验证连接的有效性
spring.datasource.secondary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.secondary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.secondary.test-on-return=false
spring.datasource.secondary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.secondary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.secondary.min-evictable-idle-time-millis=1800000
spring.datasource.secondary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.secondary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.secondary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.secondary.min-idle=5
datasource
spring.dao.exceptiontranslation.enabled
是否开启PersistenceExceptionTranslationPostProcessor,默认为truespring.datasource.abandon-when-percentage-full
设定超时被废弃的连接占到多少比例时要被关闭或上报spring.datasource.allow-pool-suspension
使用Hikari pool时,是否允许连接池暂停,默认为: falsespring.datasource.alternate-username-allowed
是否允许替代的用户名.spring.datasource.auto-commit
指定updates是否自动提交.spring.datasource.catalog
指定默认的catalog.spring.datasource.commit-on-return
设置当连接被归还时,是否要提交所有还未完成的事务spring.datasource.connection-init-sql
指定连接被创建,再被添加到连接池之前执行的sql.spring.datasource.connection-init-sqls
使用DBCP connection pool时,指定初始化时要执行的sqlspring.datasource.connection-properties.[key]
在使用DBCP connection pool时指定要配置的属性spring.datasource.connection-test-query
指定校验连接合法性执行的sql语句spring.datasource.connection-timeout
指定连接的超时时间,毫秒单位.spring.datasource.continue-on-error
在初始化数据库时,遇到错误是否继续,默认falsespring.datasource.data
指定Data (DML)脚本spring.datasource.data-source-class-name
指定数据源的全限定名.spring.datasource.data-source-jndi
指定jndi的地址spring.datasource.data-source-properties.[key]
使用Hikari connection pool时,指定要设置的属性spring.datasource.db-properties
使用Tomcat connection pool,指定要设置的属性spring.datasource.default-auto-commit
是否自动提交.spring.datasource.default-catalog
指定连接默认的catalog.spring.datasource.default-read-only
是否设置默认连接只读.spring.datasource.default-transaction-isolation
指定连接的事务的默认隔离级别.spring.datasource.driver-class-name
指定driver的类名,默认从jdbc url中自动探测.spring.datasource.fair-queue
是否采用FIFO返回连接.spring.datasource.health-check-properties.[key]
使用Hikari connection pool时,在心跳检查时传递的属性spring.datasource.idle-timeout
指定连接多久没被使用时,被设置为空闲,默认为10msspring.datasource.ignore-exception-on-pre-load
当初始化连接池时,是否忽略异常.spring.datasource.init-sql
当连接创建时,执行的sqlspring.datasource.initial-size
指定启动连接池时,初始建立的连接数量spring.datasource.initialization-fail-fast
当创建连接池时,没法创建指定最小连接数量是否抛异常spring.datasource.initialize
指定初始化数据源,是否用data.sql来初始化,默认: truespring.datasource.isolate-internal-queries
指定内部查询是否要被隔离,默认为falsespring.datasource.jdbc-interceptors
使用Tomcat connection pool时,指定jdbc * ,分号分隔spring.datasource.jdbc-url
指定JDBC URL.spring.datasource.jmx-enabled
是否开启JMX,默认为: falsespring.datasource.jndi-name
指定jndi的名称.spring.datasource.leak-detection-threshold
使用Hikari connection pool时,多少毫秒检测一次连接泄露.spring.datasource.log-abandoned
使用DBCP connection pool,是否追踪废弃statement或连接,默认为: falsespring.datasource.log-validation-errors
当使用Tomcat connection pool是否打印校验错误.spring.datasource.login-timeout
指定连接数据库的超时时间.spring.datasource.max-active
指定连接池中最大的活跃连接数.spring.datasource.max-age
指定连接池中连接的最大年龄spring.datasource.max-idle
指定连接池最大的空闲连接数量.spring.datasource.max-lifetime
指定连接池中连接的最大生存时间,毫秒单位.spring.datasource.max-open-prepared-statements
指定最大的打开的prepared statements数量.spring.datasource.max-wait
指定连接池等待连接返回的最大等待时间,毫秒单位.spring.datasource.maximum-pool-size
指定连接池最大的连接数,包括使用中的和空闲的连接.spring.datasource.min-evictable-idle-time-millis
指定一个空闲连接最少空闲多久后可被清除.spring.datasource.min-idle
指定必须保持连接的最小值(For DBCP and Tomcat connection pools)spring.datasource.minimum-idle
指定连接维护的最小空闲连接数,当使用HikariCP时指定.spring.datasource.name
指定数据源名.spring.datasource.num-tests-per-eviction-run
指定运行每个idle object evictor线程时的对象数量spring.datasource.password
指定数据库密码.spring.datasource.platform
指定schema要使用的Platform(schema-${platform}.sql),默认为:allspring.datasource.pool-name
指定连接池名字.spring.datasource.pool-prepared-statements
指定是否池化statements.spring.datasource.propagate-interrupt-state
在等待连接时,如果线程被中断,是否传播中断状态.spring.datasource.read-only
当使用Hikari connection pool时,是否标记数据源只读spring.datasource.register-mbeans
指定Hikari connection pool是否注册JMX MBeans.spring.datasource.remove-abandoned
指定当连接超过废弃超时时间时,是否立刻删除该连接.spring.datasource.remove-abandoned-timeout
指定连接应该被废弃的时间.spring.datasource.rollback-on-return
在归还连接时,是否回滚等待中的事务.spring.datasource.schema
指定Schema (DDL)脚本.spring.datasource.separator
指定初始化脚本的语句分隔符,默认: ;spring.datasource.sql-script-encoding
指定SQL scripts编码.spring.datasource.suspect-timeout
指定打印废弃连接前的超时时间.spring.datasource.test-on-borrow
当从连接池借用连接时,是否测试该连接.spring.datasource.test-on-connect
创建时,是否测试连接spring.datasource.test-on-return
在连接归还到连接池时是否测试该连接.spring.datasource.test-while-idle
当连接空闲时,是否执行连接测试.spring.datasource.time-between-eviction-runs-millis
指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔spring.datasource.transaction-isolation
指定事务隔离级别,使用Hikari connection pool时指定spring.datasource.url
指定JDBC URL.spring.datasource.use-disposable-connection-facade
是否对连接进行包装,防止连接关闭之后被使用.spring.datasource.use-equals
比较方法名时是否使用String.equals()替换==.spring.datasource.use-lock
是否对连接操作加锁spring.datasource.username
指定数据库名.spring.datasource.validation-interval
指定多少ms执行一次连接校验.spring.datasource.validation-query
指定获取连接时连接校验的sql查询语句.spring.datasource.validation-query-timeout
指定连接校验查询的超时时间.spring.datasource.validation-timeout
设定连接校验的超时时间,当使用Hikari connection pool时指定spring.datasource.validator-class-name
用来测试查询的validator全限定名.spring.datasource.xa.data-source-class-name
指定数据源的全限定名.spring.datasource.xa.properties
指定传递给XA data source的属性
JPA
spring.jpa.database
指定目标数据库.spring.jpa.database-platform
指定目标数据库的类型.spring.jpa.generate-ddl
是否在启动时初始化schema,默认为falsespring.jpa.hibernate.ddl-auto
指定DDL mode (none, validate, update, create, create-drop). 当使用内嵌数据库时,默认是create-drop,否则为none.spring.jpa.hibernate.naming-strategy
指定命名策略.spring.jpa.open-in-view
是否注册OpenEntityManagerInViewInterceptor,绑定JPAEntityManager到请求线程中,默认为: truespring.jpa.properties
添加额外的属性到JPA provider.spring.jpa.show-sql
是否开启sql的log,默认为: false
jooq
spring.jooq.sql-dialect
指定JOOQ使用的SQLDialect,比如POSTGRES.
h2
spring.h2.console.enabled
是否开启控制台,默认为falsespring.h2.console.path
指定控制台路径,默认为: /h2-console
JTA
spring.jta.allow-multiple-lrc
是否允许 multiple LRC,默认为: falsespring.jta.asynchronous2-pc
指定两阶段提交是否可以异步,默认为: falsespring.jta.background-recovery-interval
指定多少分钟跑一次recovery process,默认为: 1spring.jta.background-recovery-interval-seconds
指定多久跑一次recoveryprocess,默认: 60spring.jta.current-node-only-recovery
是否过滤掉其他非本JVM的recovery,默认为: truespring.jta.debug-zero-resource-transaction
是否追踪没有使用指定资源的事务,默认为: falsespring.jta.default-transaction-timeout
设定默认的事务超时时间,默认为60spring.jta.disable-jmx
是否禁用jmx,默认为falsespring.jta.enabled
是否开启JTA support,默认为: truespring.jta.exception-analyzer
设置指定的异常分析类spring.jta.filter-log-status
使用Bitronix Transaction Manager时,是否写mandatory logs,开启的话,可以节省磁盘空间,但是调试会复杂写,默认为falsespring.jta.force-batching-enabled
使用Bitronix Transaction Manager时,是否批量写磁盘,默认为true.spring.jta.forced-write-enabled
使用Bitronix Transaction Manager时,是否强制写日志到磁盘,默认为truespring.jta.graceful-shutdown-interval
当使用Bitronix Transaction Manager,指定shutdown时等待事务结束的时间,超过则中断,默认为60spring.jta.jndi-transaction-synchronization-registry-name
当使用BitronixTransaction Manager
时,在JNDI下得事务同步registry,默认为:java:comp/TransactionSynchronizationRegistryspring.jta.jndi-user-transaction-name
指定在JNDI使用Bitronix Transaction Manager的名称,默认:java:comp/UserTransactionspring.jta.journal
当使用Bitronix Transaction Manager,指定The journal是否disk还是null还是一个类的全限定名,默认diskspring.jta.log-dirTransaction logs directory
.spring.jta.log-part1-filename
指定The journal fragment文件1的名字,默认: btm1.tlogspring.jta.log-part2-filename
指定The journal fragment文件2的名字,默认: btm2.tlogspring.jta.max-log-size-in-mb
指定journal fragments大小的最大值. 默认: 2Mspring.jta.resource-configuration-filename
指定Bitronix Transaction Manager配置文件名.spring.jta.server-id
指定Bitronix Transaction Manager实例的id.spring.jta.skip-corrupted-logs
是否忽略corrupted log files文件,默认为false.spring.jta.transaction-manager-id
指定Transaction manager的唯一标识.jta.warn-about-zero-resource-transaction
当使用Bitronix Transaction Manager时,是否对没有使用指定资源的事务进行警告,默认为: true
来源:https://blog.csdn.net/wandrong/article/details/83347267
猜你喜欢
- 背景分析在项目的开发中,不管是对底层的数据逻辑操作过程,还是业务逻辑的处理过程,还是控制逻辑的处理过程,都不可避免会遇到各种可预知的、不可预
- 一、平衡二叉树的定义平衡二叉树是一种二叉排序树,其中每一个节点的左子树和右子树的高度差至多等于1 。它是一种高度平衡的二叉排序树。意思是说,
- 本文实例为大家分享了Java金额大小写转换的具体代码,供大家参考,具体内容如下/** * @ClassName: NumberConver
- java调用外部程序的方法 在一个java应用中,可能会遇到这样的需求,就是需要调用一些外部的应用做一些处理,比如调用excel,
- java获取系统路径字体、得到某个目录下的所有文件名、获取当前路径package com.liuxing.test;import java.
- 本文研究的主要是Java中后台线程的相关问题,具体介绍如下。以前从来没有听说过,java中有后台线程这种东西。一般来说,JVM(JAVA虚拟
- 一、前言在java中,和C语言一样,也有关于字符串的定义,并且有他自己特有的功能,下面我们一起来学习一下。二、String类概述string
- 本文实例讲述了java实现日期拆分的方法。分享给大家供大家参考。具体如下:如:计算6-1至6-5之间的日期天数及具体日期,预期的结果是得到:
- 一、泛型的概念1.1 基础案例泛型在Java中的应用非常广泛,最常见则是在集合容器中,先看下基础用法:public class Generi
- 效果展示在实际项目当中我们经常看到如下各种剪裁形状的效果,Flutter 为我们提供了非常方便的 Widget 很轻松就可以实现,下面我们来
- Android 消息机制1.概述Android应用启动时,会默认有一个主线程(UI线程),在这个线程中会关联一个消息队列(MessageQu
- java web返回中文乱码ajax返回中文乱码问题 在浏览器按F12查看数据包可以看到charset为 iso-8859-1,这是spri
- 一般文本文件我们以日志文件.log文件为例:import java.io.BufferedReader; import java.io.Fi
- 接触过Android开发的同学们都知道在Android中访问程序资源基本都是通过资源ID来访问。这样开发起来很简单,并且可以不去考虑各种分辨
- 初步探索首先我们要了解equals方法是什么,hashcode方法是什么。equals方法equals 是java的obejct类的一个方法
- 前言本文准确来讲是探讨如何用 Jackson 来序列化 Apache avro 对象,因为简单用 Jackson 来序列化 Apache a
- 网络中数据传输经常是xml或者json,现在做的一个项目之前调其他系统接口都是返回的xml格式,刚刚遇到一个返回json格式数据的接口,通过
- java jdbc连接和使用jdbc导入驱动//jar是已经打包好的class文件集,可以引用到其他工程中 //Build Pa
- 功能介绍大家都知道在Spring boot开发过程中,需要在配置文件里配置许多信息,如数据库的连接信息等,如果不加密,传明文,数据库就直接暴
- 命令模式的介绍命令模式是对命令的封装。命令模式把发出命令的责任和执行命令的责任分割开,委派给不同的对象每一个命令都是一个操作:请求的一方发出