首页 >数据库 >mysql教程 >将 AWS RDS 连接到 Spring Boot

将 AWS RDS 连接到 Spring Boot

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-11 04:22:14987浏览

简介

在本文中,我将逐步介绍在配置安全组并将其连接到 Spring Boot 应用程序并测试连接后设置 AWS RDS MySQL 实例的过程。

第1步:创建新的安全组

在设置RDS实例之前,您需要确保该实例可访问。您可以通过配置 AWS 安全组 来做到这一点。安全组充当虚拟防火墙来控制入站和出站流量。

  • 访问 AWS 控制台:转到 EC2 仪表板 > 安全组 > 创建安全组
  • 入站规则
    • 选择类型为MYSQL/Aurora(因为我打算使用MySQL),它打开端口3306(MySQL默认端口)。
    • 设置为我的IP,然后它会自动获取您的IP地址以连接RDS实例。
  • 出站规则
    • 设置允许所有流量,以保证实例可以与其他资源自由通信。

Connecting AWS RDS to Spring Boot

Connecting AWS RDS to Spring Boot

设置安全组后,继续配置RDS实例

第 2 步:配置 RDS 实例

  • 选择数据库引擎:在本例中,选择MySQL

Connecting AWS RDS to Spring Boot

  • 选择模板:为简单起见,您可以使用免费套餐,因为我将设置一个演示应用程序。

Connecting AWS RDS to Spring Boot

  • 设置数据库实例
    • 选择单个数据库实例(如果您不需要高可用性)。
    • 定义数据库实例标识符主用户名(我使用默认名称“admin”)和密码

Connecting AWS RDS to Spring Boot

  • 选择数据库实例类
    • 我选择了 db.t3.micro(最小资源选项),因为不需要更多 CPU 或 RAM。

Connecting AWS RDS to Spring Boot

  • 选择存储类型
    • 通用 SSD 和 20 GB 存储价值足以满足我的演示应用程序的需要。

注意:我不需要此数据库的特定 EC2 实例,因为不需要分配计算资源。

Connecting AWS RDS to Spring Boot

配置这些设置后,单击创建数据库开始配置RDS实例。创建需要几分钟。

第 3 步:配置 Spring Boot 应用程序

现在您的 RDS MySQL 实例已启动并运行,您可以继续配置 Spring Boot 应用程序以连接到它。

我不会深入研究 Spring boot,我只是展示一些 Java 文件和配置来了解一下。如果您是 Spring boot 的新手,请在实现之前对 Spring boot 应用程序有一个基本的了解。

3.1。更新 application.properties

在 Spring Boot 项目中,您需要在 application.properties 文件中添加必要的数据库连接详细信息。连接将使用端点(在 RDS 实例的连接性和安全性下)以及 RDS 设置期间设置的凭据。

spring.application.name=DevOps
spring.datasource.url=jdbc:mysql://<End Point>/devops
spring.datasource.username=admin
spring.datasource.password=<Password>
spring.jpa.hibernate.ddl-auto=update
  • spring.datasource.url:这是您的 RDS 实例的 URL(将主机替换为您收到的实际 RDS 端点)。
  • spring.datasource.usernameadmin 用户或您在设置过程中配置的主用户名。
  • spring.datasource.password:您为 RDS 实例配置的密码。
  • spring.jpa.hibernate.ddl-auto:设置为 update 自动更新您的架构(非常适合开发)。

3.2。添加 MySQL 依赖

确保您的 pom.xml(对于 Maven)或 build.gradle(对于 Gradle)具有 MySQL 驱动程序依赖项。

对于 Maven:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

对于 Gradle:

implementation 'mysql:mysql-connector-java'

注意:确保还添加 spring-boot-starter-data-jpa 依赖项。

3.3。定义 JPA 实体和存储库

您现在可以定义 JPA 实体和相应的存储库。例如,要创建 User 实体:

@Entity
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    <getters, setters and constructions>
}

和存储库接口:

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
}

第 4 步:创建一个简单的 REST 控制器

创建一个控制器来处理与User实体相关的请求。以下代码展示了如何创建一个简单的 POST 方法来保存用户数据:

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    @PostMapping
    public String saveUser(@RequestBody User user){
        try {
            userService.saveUser(user);
            return "Success!";
        } catch (Exception e) {
            return e.getMessage();
        }
    }
}

UserService 类负责将数据保存到数据库。

spring.application.name=DevOps
spring.datasource.url=jdbc:mysql://<End Point>/devops
spring.datasource.username=admin
spring.datasource.password=<Password>
spring.jpa.hibernate.ddl-auto=update

第 5 步:验证 MySQL Workbench 中的连接

您可以使用 MySQL Workbench 连接到 AWS RDS 实例来验证连接。输入连接详细信息如下:

  • 主机:您的 RDS 实例的端点。
  • 用户名:管理员用户名。
  • 密码:您为数据库设置的密码。
  • 端口:3306。

连接后,您可以浏览数据库和表以确认您的 Spring Boot 应用程序正在与 MySQL 数据库交互。

Connecting AWS RDS to Spring Boot



第 6 步:使用 Postman 进行测试

您可以使用Postman测试POST端点。向 http://localhost:8080/user 发送 POST 请求,并使用 JSON 正文:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

如果一切设置正确,您应该会看到一个响应“成功!”

Connecting AWS RDS to Spring Boot



结论

您现在已成功将 Spring Boot 应用程序连接到 AWS RDS MySQL 实例。通过执行上述步骤,您能够:

  • 为 MySQL 设置 AWS RDS 实例。
  • 配置必要的安全组以进行访问控制。
  • 通过 JDBC 将您的 Spring Boot 应用程序连接到 RDS 实例。
  • 通过 Postman 发送 POST 请求并验证数据库条目来测试设置。

此设置可确保为 AWS 上托管的 Spring Boot 应用程序提供无缝且可扩展的数据库后端。

如果您需要任何进一步的帮助或者您有任何改进设置的想法,请告诉我!

谢谢!
Connecting AWS RDS to Spring Boot

以上是将 AWS RDS 连接到 Spring Boot的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn