当前位置: 首页 > news >正文

SpringBoot自动化部署实战

嘿,小伙伴们!今天咱们来聊聊怎么把一个Spring Boot项目自动化部署到服务器上。如果你是0基础,别担心,我会尽量用大白话给你讲清楚。跟着我一步步来,你也能轻松搞定!

## 一、准备工作

### 1. 你需要有啥
- **Spring Boot项目**:如果你还没有,可以先用Spring Initializr(<https://start.spring.io/>)快速生成一个。它就像一个“项目生成器”,你只需要选好需要的依赖,比如Spring Web,点一下生成,就会得到一个基础的Spring Boot项目。
- **服务器**:可以是云服务器(比如阿里云、腾讯云),也可以是自己搭的。服务器上需要安装好Java环境(因为Spring Boot是Java写的),一般安装JDK 8或更高版本就行。
- **Git**:这是个版本控制系统,方便我们把代码从本地推到服务器。在本地电脑和服务器上都要装好。
- **SSH工具**:如果你用的是Windows,推荐用Xshell;如果是Mac或Linux,自带的终端就行。SSH工具是用来远程连接服务器的。

### 2. 搭建好服务器环境
- **安装Java**:登录到服务器,用SSH工具。如果是Linux服务器,可以用命令`sudo apt-get install openjdk-11-jdk`(以OpenJDK 11为例)来安装Java。安装好后,用`java -version`命令检查一下版本,确保安装成功。
- **安装Git**:在服务器上也安装Git,命令是`sudo apt-get install git`(对于Ubuntu系统)。安装好后,用`git --version`检查一下。

## 二、本地开发和测试

### 1. 写代码
在本地开发Spring Boot项目,比如写一个简单的接口。在`src/main/java`目录下的`controller`包里新建一个类,比如`HelloController`,然后写一个方法:

```java
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {
    @GetMapping("/hello")
    public String sayHello() {
        return "Hello, Spring Boot!";
    }
}
```
这个接口的作用是,当访问`http://localhost:8080/hello`时,会返回“Hello, Spring Boot!”。

### 2. 测试
在本地运行项目,直接在项目根目录下用命令`mv./nw spring-boot:run`(如果你用的是Maven构建项目)。然后在浏览器里访问`http://localhost:8080/hello`,看到“Hello, Spring Boot!”,就说明本地运行成功了。

## 三、代码推到服务器

### 1. 把代码放到Git仓库
- **创建仓库**:去GitHub或者GitLab上创建一个新的仓库,比如叫`my-spring-boot-app`。
- **关联本地项目**:在本地项目根目录下,打开终端,运行`git init`初始化Git仓库,然后用`git remote add origin <仓库地址>`(把`<仓库地址>`替换成你刚刚创建的仓库地址)把本地仓库和远程仓库关联起来。
- **提交代码**:运行`git add .`把所有文件加入暂存区,然后`git commit -m "Initial commit"`提交代码,最后`git push origin main`(假设你的分支叫`main`)把代码推到远程仓库。

### 2. 在服务器上拉取代码
在服务器上,找个目录,比如`/home/user/myapp`,然后用`git clone <仓库地址>`把代码拉取下来。这样服务器上就有了你的Spring Boot项目代码。

## 四、自动化部署

### 1. 编写部署脚本
在服务器上,新建一个脚本文件,比如叫`deploy.sh`,内容如下:

```bash
#!/bin/bash

# 进入项目目录
cd /home/user/myapp

# 拉取最新代码
git pull origin main

# 构建项目
./mvnw clean package -DskipTests

# 停止旧的Spring Boot应用(如果正在运行)
pkill -f target/myapp.jar

# 启动新的Spring Boot应用
nohup java -jar target/myapp.jar > app.log 2>&1 &
```
这个脚本的作用是:进入项目目录,拉取最新代码,构建项目,停止旧的Spring Boot应用(如果有的话),然后启动新的应用,并把日志输出到`app.log`文件。

### 2. 设置脚本权限
运行`chmod +x deploy.sh`,给脚本设置可执行权限。

### 3. 手动测试脚本
在服务器上,直接运行`./deploy.sh`,看看是不是能正常部署。如果中间有报错,仔细检查脚本里的命令和路径。

### 4. 自动化触发部署
这里用GitHub的Webhook来实现自动化。在GitHub仓库的“Settings”->“Webhooks”里,新建一个Webhook:
- **Payload URL**:填`http://<服务器IP>/deploy`(把`<服务器IP>`替换成你的服务器IP)。
- **Content type**:选`application/json`。
- **Which events would you like to trigger this webhook?**:选`Just the push event`。

然后在服务器上,用一个简单的Spring Boot项目来接收Webhook请求并触发部署脚本。新建一个`WebhookController`:

```java
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class WebhookController {
    @PostMapping("/deploy")
    public String deploy() {
        Runtime.getRuntime().exec("/home/user/myapp/deploy.sh");
        return "Deploying...";
    }
}
```
这个接口的作用是,当GitHub推送代码时,会触发这个接口,然后运行`deploy.sh`脚本,完成自动化部署。

## 五、测试

在本地修改一下代码,比如把`HelloController`里的返回值改成“Hello, New Version!”,然后提交代码到GitHub。GitHub会自动触发Webhook,服务器收到请求后,运行`deploy.sh`脚本,完成部署。部署完成后,访问服务器的`http://<服务器IP>:8080/hello`,看到“Hello, New Version!”,就说明自动化部署成功了!

## 六、常见问题

1. **服务器上Java版本不匹配**:确保服务器上的Java版本和本地开发时的版本一致。可以用`java -version`检查。
2. **脚本权限问题**:如果脚本运行失败,检查是否给脚本设置了可执行权限。
3. **Webhook请求失败**:检查服务器的防火墙是否允许外部访问`/deploy`接口,还有检查Webhook的URL是否正确。

好啦,以上就是Spring Boot自动化部署的全过程。是不是很简单?只要跟着步骤一步步来,你也能轻松搞定自动化部署。如果还有啥问题,欢迎随时问我哦!

相关文章:

  • 生成xcframework
  • <7>-MySQL内置函数
  • 51c嵌入式※~电路~合集32~PWM
  • BERT情感分类
  • BERT 位置嵌入机制与代码解析
  • Python 自动化临时邮箱工具,轻松接收验证码,支持调用和交互模式(支持谷歌gmail/googlemail)
  • ffmpeg 新版本转码设置帧率上限
  • 《通信之道——从微积分到 5G》读书总结
  • SkyReels-V1:开启多模态视频生成的新纪元
  • Flutter 多版本管理工具 Puro ,它和 FVM 有什么区别?
  • Flutter:弹窗UI,不带背景色,自定义图片的弹窗
  • 安装 docker-ce 时 错误:缺少container-selinux >= 2:2.74 错误:缺少 libcgroup
  • PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
  • 零基础学前端-传统前端开发(第二期-HTML介绍与应用)(XSS防御)
  • JxBrowser 8.8.0 版本发布啦!
  • 【HarmonyOS 5】鸿蒙CodeGenie AI辅助编程工具详解
  • 鹰盾加密器系统黑屏问题的深度解析与处理机制
  • SDC命令详解:使用uniquify命令进行唯一化
  • python第48天打卡
  • Netty从入门到进阶(三)
  • 网站落地页如何做/商务软文写作300字
  • 政府网站建设指标评价结果/seo手机优化软件哪个好用
  • 多语种网站营销/seo网站推广杭州
  • 江苏省建设考试网站准考证打印/北京网站推广排名
  • 网站打开速度慢是什么原因/新媒体营销策略
  • 广州天河区做网站的公司/在线seo优化