在现代微服务架构中,数据持久化是至关重要的一环。Spring Cloud是一个广泛使用的微服务框架,它提供了一整套解决方案来简化微服务的开发和管理。而MySQL作为一个开源的关系型数据库系统,在微服务项目中也发挥着重要作用。本文博主将介绍如何在Spring Cloud微服务项目中集成MySQL,以便实现高效的数据存取和管理。
1.创建Spring-Boot微服务项目
在本文中,博主已经创建了一个Spring-Boot微服务项目,Spring-Boot微服务项目搭建,请参考Spring Cloud微服务项目搭建
2.引入MySQL依赖
在 user 模块的 pom.xml 文件中添加如下的 MySQL依赖:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.33</version>
</dependency>
3.引入阿里巴巴的数据库连接池依赖
在 user 模块的 pom.xml 文件中添加如下的 Druid依赖:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.9</version>
</dependency>
在项目中使用 Druid,可以帮助你更好地管理和优化数据库连接,提高应用的整体性能和稳定性。
4.配置MySQL数据库
在application.yml
或application.properties
中配置MySQL数据库连接信息:
# 运行端口号
server:
port: 8001
spring:
application:
name: user-service # 服务名
datasource:
url: jdbc:mysql://${host}:3306/database?useSSL=false&serverTimezone=UTC&characterEncoding=UTF-8&allowPublicKeyRetrieval=true
username: username
password: password
driver-class-name: com.mysql.cj.jdbc.Driver # 数据库连接池
type: com.alibaba.druid.pool.DruidDataSource
5.创建实体类
在Spring Boot应用中可以通过JPA实体类来映射数据表:
/**
* 用户信息实体类
*/
@Data
public class UserInfoModel {
private String userId;
private String userName;
private String userPassword;
private String userPhone;
private String userEmail;
}
这里博主使用了 Lombok 工具自动生成 Getter/Setter 和 toString 方法,在父级 pom.xml 或者 user 模块的 pom.xml 引入 Lombok 依赖:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>