Task进行CI/CD简单又适用

一、下载和环境配置

下载

https://github.com/go-task/task

环境配置

主要是在系统path中增加task的目录

二、初始化task文件

b 复制代码
task --init

这个目录下就会生成一个Taskfile.yml,接下来我们就写补充我们自己的

三、编写补充自己的内容

先看代码

b 复制代码
# yaml-language-server: $schema=https://taskfile.dev/schema.json

version: '3'

vars:
  GREETING: Hello, world!
  SSH_CMD: "C:\\Windows\\System32\\OpenSSH\\ssh.exe"
  SCP_CMD: "C:\\Windows\\System32\\OpenSSH\\scp.exe"
  SERVER_DEPLOY_DIR: /home/zeng
  JAR_FILE: eureka-server-1.0-SNAPSHOT.jar

tasks:
  default:
    desc: Print a greeting message
    cmds:
      - echo "{{.GREETING}}"
    silent: true
  build:
    desc: Build the project
    cmds:
      - echo "Building the project..."
      - mvn clean compile
      - echo "Build complete."
  package:
    desc: Package the project
    cmds:
      - echo "Packaging the project..."
      - mvn package -DskipTests
      - echo "Package complete."
  start:
    desc: Start the application,本地运行
    deps:
      - package  #确保先打包
    cmds:
      - echo "Starting the application..."
      - java -jar ./target/eureka-server-1.0-SNAPSHOT.jar
  deploy:
    desc: Deploy the application to the server,部署到服务器
    deps:
      - package  #确保先打包
    cmds:
      - echo "Deploying the application to the server..."
      # - C:\Windows\System32\OpenSSH\ssh.exe zeng@192.168.50.252 "sudo mkdir -p /home/zeng/mytest"
      - C:\Windows\System32\OpenSSH\scp.exe ./target/eureka-server-1.0-SNAPSHOT.jar zeng@192.168.50.252:/home/zengh/
      - C:\Windows\System32\OpenSSH\ssh.exe zeng@192.168.50.252 "if [ -f /home/zeng/{{.PROJECT_NAME}}.pid ]; then kill \$(cat {{.SERVER_DEPLOY_DIR}}/{{.PROJECT_NAME}}.pid) || true; rm -f {{.SERVER_DEPLOY_DIR}}/{{.PROJECT_NAME}}.pid; fi"
      - C:\Windows\System32\OpenSSH\ssh.exe  zeng@192.168.50.252 "cd /home/zeng && nohup java -jar eureka-server-1.0-SNAPSHOT.jar > logs/mytest.log 2>&1 & echo \$! > mytest.pid"
  

再看执行,结合3张图片,想必你已经看懂了。

可以定义多个task

task的名字可以自己定义,

执行的时候用task 名字来执行



四、先要取消服务器密码登录

因为ssh是需要输入密码的,我们是希望不需要中间人为干预,使用密钥认证

第一步:

b 复制代码
ssh-keygen -t rsa -b 2048
#一路回车就好

生成两个文件:

把其中的id_rsa.pub公钥。复制里面的内容到服务器的~/.ssh/authorized_keys文件中:

方法1:执行

b 复制代码
ssh-copy-id 用户名@服务器地址

方法2:直接写字板打开复制粘贴

五、仔细分析这里的任务

有基础的,我就不一句一句解释了。

相关推荐
饕餮争锋7 小时前
CI/CD 概念详解
ci/cd
puamac9 小时前
GitLab CI/CD 故障排查手册
ci/cd·gitlab
Bigger10 小时前
实战:搭建 AI Code Review 自动化流水线
前端·ci/cd·自动化运维
wb0430720110 小时前
从接单到出餐——从阿明的“手写菜单“到自动化流水线,看 CI/CD 与 DevOps 的完整旅程
ci/cd·架构·自动化·devops
JackSparrow4142 天前
使用Ansible批量管理+更新产品环境服务器配置
运维·服务器·ci/cd·kubernetes·自动化·ansible·sre
smartpi_ai2 天前
CI-73T 裸片方案 MICBIAS 电容 C11 设计:模块与芯片的差异解析
ci/cd
lili00122 天前
AI编程三件套CI集成与质量门禁:从“看起来对“到“证据确凿“
java·人工智能·python·ci/cd·ai编程
隔窗听雨眠3 天前
GitLab CI前端加载慢优化实录
ci/cd·gitlab
jiayong233 天前
MySQL 排序规则冲突问题与 utf8mb4_general_ci 统一方案
android·mysql·ci/cd
若鱼文化创意3 天前
品牌设计CI规划使用后交付偏差先分项核对验收标准
python·ci/cd