centos7nginx搭建网站不能连接数据库报错

centos7nginx搭建网站不能连接数据库报错,第1张

网络的问题。搭建网站不能连接数据库报错多数是网络连接异常导致。

1、首先打开电脑检查网络。

2、其次打开centos7nginx进行测试网络连接是否异常。

3、最后点击centos7nginx重新进入即可。

当我用JDBC连接MySql数据库时,编译报了如下错误

错误1:

Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.

这要求我们注册驱动时,把Class.forName("com.mysql.jdbc.Driver")改成 Class.forName("com.mysql.cj.jdbc.Driver")

当我信息满满的修改之后重新编译时,再次出现了错误:

错误2:

Fri Feb 22 08:55:38 CST 2019 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=false,修改后 jdbc:mysql://localhost:3306/ds3?useSSL=false

当我修改后,本以为这下应该没问题了,没想到,再一次出现了问题

错误3:

Exception in thread "main" java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

这要求我们修改时区,修改成jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC

终于,不在报错误了。

错误4:当我们配置xml文件时,要把&转为其本身的转义字符

配置properties文件的urlurl=jdbc:mysql:///ds3?useSSL=false&serverTimezone=UTC配置xml文件的url<property name="url">jdbc:mysql://localhost:3306/ds3?useSSL=false&serverTimezone=UTC</property>

数据库连接错误原因有很多的,一般来说:

首先,你先确认下MySQL数据库、用户名和密码是否正确;

另外连接MySQL需要开放默认的3306端口,你再检查下是否已打开3306端口。 下面是我在网上找到的解决方法:方法一:

# /etc/init.d/mysql stop

# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &

# mysql -u root mysql

mysql>UPDATE user SET Password=PASSWORD('newpassword') where USER='root'

mysql>FLUSH PRIVILEGES

mysql>quit# /etc/init.d/mysql restart

# mysql -uroot -p

Enter password: <输入新设的密码newpassword>

mysql>方法二:

直接使用/etc/mysql/debian.cnf文件中[client]节提供的用户名和密码:

# mysql -udebian-sys-maint -p

Enter password: <输入[client]节的密码>

mysql>UPDATE user SET Password=PASSWORD('newpassword') where USER='root'

mysql>FLUSH PRIVILEGES

mysql>quit# mysql -uroot -p

Enter password: <输入新设的密码newpassword>

mysql>上面两种方法适用于Linux系统,下面方法针对Windows系统 *** 作: 1. 管理员登陆系统,停止mysql服务或者结束mysqld-nt进程

2. 进入命令行,来到mysql的安装目录.假设安装目录为 d:\mysql\ , CMD进入命令行

3. 运行 d:\mysql\bin\mysqld-nt --skip-grant-tables 启动mysql,关闭权限的检查

4. 运行 d:\mysql\bin\mysqladmin -u root flush-privileges password "newpassword" 重设root密码

5. 重新启动mysql服务。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9250075.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存