Spring
Spring Cannot create PoolableConnectionFactory 에러
pooney
2020. 5. 6. 02:26
아래 에러는 jdbc 사용 시 db연결이 제대로 이루어지 않았기 때문이다 그럼으로 인하여 커넥션 풀이 제대로 만들어 지지 않았기 때문이다. 이를 해결하기 위해서는 time zone 설정을 하면 해결 할 수 있다.
### Error querying database. Cause: java.sql.SQLException: Cannot create PoolableConnectionFactory (Could not create connection to database server. Attempted reconnect 3 times. Giving up.)
### The error may exist in memo/mapper/memo.xml
### The error may involve memo.list
### The error occurred while executing a query
### Cause: java.sql.SQLException: Cannot create PoolableConnectionFactory (Could not create connection to database server. Attempted reconnect 3 times. Giving up.)
at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:149)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:140)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:135)
해결방법
변경 전
url ="jdbc:mysql://localhost:3306/test"
변경 후
url = "jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Seoul"
mysql 연결 시 에러가 나서 mybatis의 sql문이 작동이 되지않았다. 하지만 SqlSession에 값을 콘솔창 에 출력해 봤는데 값이 나와 연결이 됬다고 생각햇지만 아니였다. 잘 못된 원인 db 연결의 url ="jdbc:mysql://localhost:3306/test " 가 문제 였다 서버 타임존 설정이 안되어 있기 때문이다. jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Seoul 으로 변경하여 jdbc 타임존 에러를 해결하니 연결이 정상 작동 되었다.