Spring Cloud微服务项目集成MySQL

在现代微服务架构中,数据持久化是至关重要的一环。Spring Cloud 是一个广泛使用的微服务框架,它提供了一整套解决方案来简化微服务的开发和管理。而MySQL 作为一个开源的关系型数据库系统,在微服务项目中也发挥着重要作用。本文博主将介绍如何在Spring Cloud 微服务项目中集成MySQL,以便实现高效的数据存取和管理。

1.创建Spring-Boot微服务项目

在本文中,博主已经创建了一个Spring-Boot微服务项目,Spring-Boot微服务项目搭建,请参考Spring Cloud微服务项目搭建

2.引入MySQL依赖

在 user 模块的 pom.xml 文件中添加如下的 MySQL依赖:

XML 复制代码
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.33</version>
</dependency>

3.引入阿里巴巴的数据库连接池依赖

在 user 模块的 pom.xml 文件中添加如下的 Druid依赖:

XML 复制代码
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.2.9</version>
</dependency>

在项目中使用 Druid,可以帮助你更好地管理和优化数据库连接,提高应用的整体性能和稳定性。

4.配置MySQL数据库

在**application.yml** 或**application.properties**中配置MySQL数据库连接信息:

bash 复制代码
# 运行端口号
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实体类来映射数据表:

java 复制代码
/**
 * 用户信息实体类
 */
@Data
public class UserInfoModel {

    private String userId;

    private String userName;

    private String userPassword;

    private String userPhone;

    private String userEmail;
}

这里博主使用了 Lombok 工具自动生成 Getter/SettertoString 方法,在父级 pom.xml 或者user 模块的pom.xml 引入Lombok依赖:

XML 复制代码
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>
相关推荐
一 乐37 分钟前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
码事漫谈2 小时前
Protocol Buffers 编码原理深度解析
后端
码事漫谈2 小时前
gRPC源码剖析:高性能RPC的实现原理与工程实践
后端
踏浪无痕3 小时前
AI 时代架构师如何有效成长?
人工智能·后端·架构
程序员小假4 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
萧曵 丶5 小时前
MySQL 主键不推荐使用 UUID 的深层原因
数据库·mysql·索引
武子康5 小时前
大数据-209 深度理解逻辑回归(Logistic Regression)与梯度下降优化算法
大数据·后端·机器学习
maozexijr5 小时前
Rabbit MQ中@Exchange(durable = “true“) 和 @Queue(durable = “true“) 有什么区别
开发语言·后端·ruby
源码获取_wx:Fegn08955 小时前
基于 vue智慧养老院系统
开发语言·前端·javascript·vue.js·spring boot·后端·课程设计
独断万古他化5 小时前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee