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:直接写字板打开复制粘贴

五、仔细分析这里的任务

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

相关推荐
康康的AI博客3 小时前
用Claude Code构建企业级GitHub CI/CD安全自动化流程
安全·ci/cd·github
奋斗者1号5 小时前
CI/CD 详解
ci/cd
lyx_20166 小时前
火山引擎GitHub CI + 对象存储 + CDN静态资源网站部署总结
ci/cd·github·火山引擎
十月南城3 天前
压测方法论——目标、场景、指标与容量评估的闭环
运维·web安全·ci/cd·微服务·云计算
遇见火星4 天前
CI/CD实战:从手动部署到自动化流水线
运维·ci/cd·自动化
卓码软件测评5 天前
第三方软件测试测评机构【使用web_reg_save_param_ex函数:掌握LoadRunner关联的黄金法则 】
测试工具·ci/cd·性能优化·单元测试·测试用例
Wpa.wk5 天前
持续集成 - 持续集成工具-Jenkins的部署流程
java·运维·经验分享·ci/cd·自动化·jenkins
ValidationExpression5 天前
学习:企业标准的容器化 CI,CD 发布流程
学习·ci/cd
007张三丰5 天前
Jenkins API 与 Pipeline 深度结合:打造高阶 CI/CD 自动化体系
ci/cd·自动化·jenkins·持续集成