跳转到主要内容

标签(标签)

资源精选(342) Go开发(108) Go语言(103) Go(99) angular(83) LLM(79) 大语言模型(63) 人工智能(53) 前端开发(50) LangChain(43) golang(43) 机器学习(39) Go工程师(38) Go程序员(38) Go开发者(36) React(34) Go基础(29) Python(24) Vue(23) Web开发(20) Web技术(19) 精选资源(19) 深度学习(19) Java(18) ChatGTP(17) Cookie(16) android(16) 前端框架(13) JavaScript(13) Next.js(12) 安卓(11) 聊天机器人(10) typescript(10) 资料精选(10) NLP(10) 第三方Cookie(9) Redwoodjs(9) ChatGPT(9) LLMOps(9) Go语言中级开发(9) 自然语言处理(9) PostgreSQL(9) 区块链(9) mlops(9) 安全(9) 全栈开发(8) OpenAI(8) Linux(8) AI(8) GraphQL(8) iOS(8) 软件架构(7) RAG(7) Go语言高级开发(7) AWS(7) C++(7) 数据科学(7) 智能体(6) whisper(6) Prisma(6) 隐私保护(6) JSON(6) DevOps(6) 数据可视化(6) wasm(6) 计算机视觉(6) 算法(6) Rust(6) 微服务(6) 隐私沙盒(5) FedCM(5) 语音识别(5) Angular开发(5) 快速应用开发(5) 提示工程(5) Agent(5) LLaMA(5) 低代码开发(5) Go测试(5) gorm(5) REST API(5) kafka(5) 推荐系统(5) WebAssembly(5) GameDev(5) CMS(5) CSS(5) machine-learning(5) 机器人(5) 游戏开发(5) Blockchain(5) Web安全(5) nextjs(5) Kotlin(5) 低代码平台(5) 机器学习资源(5) Go资源(5) Nodejs(5) PHP(5) Swift(5) RAG架构(4) devin(4) Blitz(4) javascript框架(4) Redwood(4) GDPR(4) 生成式人工智能(4) Angular16(4) Alpaca(4) 编程语言(4) SAML(4) JWT(4) JSON处理(4) Go并发(4) 移动开发(4) 移动应用(4) security(4) 隐私(4) spring-boot(4) 物联网(4) 网络安全(4) API(4) Ruby(4) 信息安全(4) flutter(4) 专家智能体(3) Chrome(3) CHIPS(3) 3PC(3) SSE(3) 人工智能软件工程师(3) LLM Agent(3) Remix(3) Ubuntu(3) GPT4All(3) 软件开发(3) 问答系统(3) 开发工具(3) 最佳实践(3) RxJS(3) SSR(3) Node.js(3) Dolly(3) 移动应用开发(3) 低代码(3) IAM(3) Web框架(3) CORS(3) 基准测试(3) Go语言数据库开发(3) Oauth2(3) 并发(3) 主题(3) Theme(3) earth(3) nginx(3) 软件工程(3) azure(3) keycloak(3) 生产力工具(3) gpt3(3) 工作流(3) C(3) jupyter(3) 认证(3) prometheus(3) GAN(3) Spring(3) 逆向工程(3) 应用安全(3) Docker(3) Django(3) R(3) .NET(3) 大数据(3) Hacking(3) 渗透测试(3) C++资源(3) Mac(3) 微信小程序(3) Python资源(3) JHipster(3) 语言模型(2) 可穿戴设备(2) JDK(2) SQL(2) Apache(2) Hashicorp Vault(2) Spring Cloud Vault(2) Go语言Web开发(2) Go测试工程师(2) WebSocket(2) 容器化(2) AES(2) 加密(2) 输入验证(2) ORM(2) Fiber(2) Postgres(2) Gorilla Mux(2) Go数据库开发(2) 模块(2) 泛型(2) 指针(2) HTTP(2) PostgreSQL开发(2) Vault(2) K8s(2) Spring boot(2) R语言(2) 深度学习资源(2) 半监督学习(2) semi-supervised-learning(2) architecture(2) 普罗米修斯(2) 嵌入模型(2) productivity(2) 编码(2) Qt(2) 前端(2) Rust语言(2) NeRF(2) 神经辐射场(2) 元宇宙(2) CPP(2) 数据分析(2) spark(2) 流处理(2) Ionic(2) 人体姿势估计(2) human-pose-estimation(2) 视频处理(2) deep-learning(2) kotlin语言(2) kotlin开发(2) burp(2) Chatbot(2) npm(2) quantum(2) OCR(2) 游戏(2) game(2) 内容管理系统(2) MySQL(2) python-books(2) pentest(2) opengl(2) IDE(2) 漏洞赏金(2) Web(2) 知识图谱(2) PyTorch(2) 数据库(2) reverse-engineering(2) 数据工程(2) swift开发(2) rest(2) robotics(2) ios-animation(2) 知识蒸馏(2) 安卓开发(2) nestjs(2) solidity(2) 爬虫(2) 面试(2) 容器(2) C++精选(2) 人工智能资源(2) Machine Learning(2) 备忘单(2) 编程书籍(2) angular资源(2) 速查表(2) cheatsheets(2) SecOps(2) mlops资源(2) R资源(2) DDD(2) 架构设计模式(2) 量化(2) Hacking资源(2) 强化学习(2) flask(2) 设计(2) 性能(2) Sysadmin(2) 系统管理员(2) Java资源(2) 机器学习精选(2) android资源(2) android-UI(2) Mac资源(2) iOS资源(2) Vue资源(2) flutter资源(2) JavaScript精选(2) JavaScript资源(2) Rust开发(2) deeplearning(2) RAD(2)

欢迎Gophers!在本教程中,我将展示如何在 Go 应用程序开发中利用 Taskfiles 来获得名利。

(免责声明):本文是在 CircleCI 中采用 Taskfiles 来帮助他们采用 Go 的。我不能因为发现 Taskfiles 而获得任何功劳,因为这是另一个突出优势的团队。

如果您已经加入 Go 社区一段时间,您可能熟悉在 Go 应用程序中使用 Makefile 或类似的构建工具,您甚至可能选择了某种形式的脚本来捕获一些较长的命令以便更轻松发展。

你们当中的受虐狂甚至可能刚刚将所有常规命令都记入了记忆中。如何记住所有不同的构建参数和设置超出了我的范围,但对你能够记住的严重赞誉。

但毫无疑问,Taskfiles 是我最喜欢的新方法之一,它可以在一个地方捕获一些我必须在日常开发活动中运行的更繁琐的命令。

示例任务文件


让我们快速看一下在 taskfile.dev 主页上演示的示例 Taskfile.yml -

version: '3'

tasks:
  hello:
    cmds:
      - echo 'Hello World from Task!'
    silent: true

乍一看,这看起来与 Makefile 非常相似,但是,我发现该工具具有更好的用户体验,并提供了超越 Makefile 系统所具有的丰富功能层。

安装任务工具


对于 mac 开发人员,使用 homebrew 安装很容易:

$ brew install go-task/tap/go-task


对于 Windows 和 *Nix 用户,您应该能够在此处找到有关您正在运行的任何操作系统风格的说明:任务文件安装

附加上下文


安装任务工具后,您就可以运行 Taskfile.yml 中定义的任务,如下所示:

$ task hello
Hello World from Task!


超级直观对吧?

如果您想为每个定义的任务添加更多上下文,您可以添加一个 desc: 块,然后允许您列出如下命令:

version: '3'

tasks:
  hello:
    desc: "A Hello World Task"
    cmds:
      - echo 'Hello World from Task!'
    silent: true

$ task --list
task: Available tasks for this project:
* hello:        A Hello World Task

对于更大、更复杂的项目,如果您想了解如何在本地启动项目等操作,这将非常方便。

在子目录中运行


过去,我发现自己想在特定的子目录中运行特定的命令。使用 Make 这有点问题。您要么必须将命令链接在一起,例如: (cd terraform && make) 这会增加复杂性,要​​么您必须在 make 命令中使用 -C 标志传递目录。

Taskfiles 采用的方法似乎要简单得多:

version: '3'

tasks:
  hello:
    desc: "A Hello World Task"
    cmds:
      - echo 'Hello World from Task!'
    silent: true
  
  terraform-apply:
    desc: "A task demonstrating a subdir"
    dir: terraform
    cmds:
      - pwd 
    silent: true

现在,每当我们尝试运行 terraform-apply 任务时,它都会在 terraform 子目录中执行该命令,这真的很不错👌

$ task terraform-apply
/path/to/myproject/terraform


任务依赖


假设您有一个任务只能在其他任务执行后才能运行。这在您的任务文件中定义变得微不足道。

在我们的任务定义中使用 deps: [] ,我们可以列出我们运行任务所需的所有依赖项,它们将为我们执行:

version: '3'

tasks:
  hello:
    desc: "A Hello World Task"
    cmds:
      - echo 'Hello World from Task!'
    silent: true
  
  terraform-plan:
    desc: "A mock terraform plan"
    dir: terraform
    cmds:
      - echo "Running terraform plan..."
    silent: true


  terraform-apply:
    desc: "A mock terraform apply"
    dir: terraform
    deps: [terraform-plan]
    cmds:
      - echo "Running terraform apply..."
    silent: true

现在,当我们运行它时,我们应该看到 terraform-plan 在 terraform-apply 之前执行:

$ task terraform-apply
Running terraform plan...
Running terraform apply...


再一次,在我看来,与 Make 相比,编写这些文件的用户体验要好得多。

动态变量


在某些情况下,您需要能够将动态值传递到您的任务中。使用 vars 块,我们可以定义特定的变量和我们需要获取它们的脚本,如下所示:

version: '3'

tasks:
  hello:
    desc: "A Hello World Task"
    cmds:
      - echo 'Hello World from Task!'
    silent: true

  install:
    desc: "An example of dynamic variables"
    cmds:
      - echo 'Installing tool into {{.HOMEDIR}}'
    silent: true
    vars:
      HOMEDIR:
        sh: echo $HOME/.mydir
  
  terraform-plan:
    desc: "A mock terraform plan"
    dir: terraform
    cmds:
      - echo "Running terraform plan..."
    silent: true


  terraform-apply:
    desc: "A mock terraform apply"
    dir: terraform
    deps: [terraform-plan]
    cmds:
      - echo "Running terraform apply..."
    silent: true



在这里,我们定义了具有动态变量 HOMEDIR 的安装任务。对于更复杂的用例,您可能会卷曲 API 以获取一些数据,或者执行一些更高级的 shell 命令。

如果我们要执行这个命令,你会看到正确的 HOMEDIR 值被插入到执行的命令中:

task install
Installing tool into /Users/elliotforbes/.mydir


Go 开发人员的通用任务文件


现在我们已经介绍了任务文件的一些优点,是时候看看在 Go 应用程序中更逼真的 Taskfile.yml 实现会是什么样子了:

 

build:
    desc: "build the compiled binary"
    cmds:
      - go build -o app cmd/server/main.go

  test:
    desc: "run all unit tests"
    cmds:
      - go test -v ./...

  lint:
    desc: "lint the code"
    cmds:
      - golangci-lint run

  run:
    desc: "runs our app and any dependencies defined within the docker-compose.yml"
    cmds:
      - docker-compose up --build

  integration-test:
    desc: "starts our app and then attempts to run our integration tests"
    cmds:
      - docker-compose up -d db
      - go test -tags=integration -v ./...
    env:
      DB_USERNAME: postgres
      DB_PASSWORD: postgres
      DB_TABLE: postgres
      DB_HOST: localhost
      DB_PORT: 5432
      DB_DB: postgres
      SSL_MODE: disable

  acceptance-tests:
    desc: "starts our app and then attempts to run our e2e tests"
    cmds:
      - docker-compose up -d --build
      - go test -tags=e2e -v ./...

这只是我在 Go 应用程序中包含的一些标准命令的一个轻量级示例。随着它的复杂性趋于增长,这个列表变得更长。

这种方法的优点还意味着我在 CI 管道中运行这些相同的任务要容易得多。我只需要确保在我的管道中安装了 Taskfile 工具,然后我可以重用这些命令来构建我的自动化。

结论


好吧,希望这篇文章让你考虑将 Taskfiles 用于你自己的 Go 应用程序开发。它们确实让我在日常工作中的生活变得更简单,我无法强调与更传统的工具相比,我更喜欢 Taskfiles 的用户体验。

如果您对这种方法有任何疑问或意见,我很乐意在下面的评论部分听到他们的意见!

文章链接