Maison développement back-end Golang Publication d'applications CLI (avec Apt et YUM)

Publication d'applications CLI (avec Apt et YUM)

Oct 05, 2024 am 06:10 AM

Publishing CLI Apps (with Apt & YUM)

イントロ

私は最近、CLI アプリのファンになっています。おそらくそれは、私の子供時代の端末 (486/33 の DOS や父の古い Apple IIe から始まりました) の魅力なのかもしれません。私は Gen X Commodore64 の時代には少し遅すぎましたが、Windows 95 だけではなく、それ以上のことを知るにはちょうど間に合いました。ダイヤルアップと 56k モデムが主流だった興味深い時代でした。最近のほとんどのブログ投稿には、SEO のために文字数を増やすためにイントロが冗長になっているのは知っていますが、これが、最近の若い人たちの多くが GUI アプリしか知らない中で、私が今でも CLI を愛する理由でもあります。 Z 世代の子供たちが、たとえ簡単な作業であってもターミナルを起動するのを見るのが、これほど嬉しいことはありません。アルファ世代が BBS とは何かを知るまで待ってください。 「おじいちゃんコンピューター」と彼らは言うでしょう? 「芝生から出て行け」✊✊

CoolRetroTerm のようなプロジェクトは、CLI への愛を取り戻すために、間違いなく私の心の中に暖かい場所を持っています。私は今でも、ブログの一部を古い Netbook の Micro で行うことを好みます。本当に、書くことだけに集中できます。 VSCode ZenMode と MarkText はかなり近いものなのではないでしょうか?


flowchart LR
Build_App --> GH_Actions --> ??? --> Profit!!!



Copier après la connexion

包装

それはともかく、余談ですが…

小さな CLI アプリ Stampy を作成した後、小さな問題に遭遇しました。それをどのように配布するか?少なくとも、私は Python パッケージングの恐ろしい怒りを避けるために (Python でビルドしたいのと同じくらい) GoLang で書くことを頭で考えるだけの賢さはありました。私がいつも困惑していることの 1 つは、人々がどのようにして素晴らしい CLI アプリを APT や YUM などの高級なパッケージ管理システムに公開するかということでした。

通常、アプリをビルドするには、単純な go build を実行するだけです。そしてブーム、インスタントバイナリ。これはローカル開発にとっては素晴らしいことですが、クロスプラットフォームのコンパイルにはあま​​り役に立ちません。その方法を示す素晴らしいガイドがいくつかありますが…私の ?? については、お読みください。そこで、さらに詳しく調べてみると、優れたツールがなければなりませんでした…そして、確かに、GoReleaser がありました!

非常によく書かれたドキュメントを読んだ後、簡単にローカルのクロスプラットフォーム ビルドを行うことができました。


goreleaser --snapshot --clean



Copier après la connexion

GitHub リリースでは、事前に作成された優れた GH アクションがあるため、ビルドを実行するのも簡単でした!

ユーザーは、eget (優れた) や シチュー (はるかに優れた) などのツールを使用して私のアプリをインストールできるようになりました!

github.com/xxx をインストールすることもできますが、これで行われるのは、リポジトリのクローンを作成し、ローカルでビルドし、ビンを $GOBIN フォルダーに置くことだけです。適切なパッケージ管理ツールと実際には同じではありませんが、すでに Go をインストールしているにとっては、いざという時に機能します。私の意見では、平均的なユーザーにとっては実際には選択肢ではありません。 ?

それだけではなく、GoReleaser はパッケージングも提供しています。これで、DEB と RPM を簡単に作成できるようになりました。恐怖の apt-get install stampy にまた一歩近づきました。唯一欠けていたのは、APT リポジトリの作成方法でした。この最後の重要な部分は確かに簡単ではありません。私はこれを GitHub Pages でセルフホストする方法を検討するのに 1 時間ほど費やしました。それは実行可能ですが、Packagecloud のような無料サービスを使用して、1 件あたり 0 ドルの低コストで署名とリポジトリのホスティングを処理する方がはるかに簡単です。月?.

ワークフロー全体の例はここでご覧いただけます

ブログ投稿そのものに遭遇した人のために、コード ブロックの中にその簡素化されたバージョンも含めておきます。

高レベルの概要として、GHA は次のことを行います:

  • GoReleaser 構成を書き込みます
  • リリーサー自体を実行します
  • 次のジョブの .debs をアップロードします
  • 連鎖ジョブでは、.deb をプルして PackageCloud にアップロードします
  • 完了!

GitHub アクションの例


name: Release

on:
  pull_request:
  push:
    # run only against tags
    tags:
      - "*"

permissions:
  contents: write
  packages: write
  issues: write

jobs:
  goreleaser:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout
        uses: actions/checkout@v4
        with:
          fetch-depth: 0
      - name: Set up Go
        uses: actions/setup-go@v5
        with:
          go-version: stable

      - name: Release config
        run: |
          cat << EOF > /tmp/goreleaser-github.yaml
          project_name: EXAMPLE
          version: 2
          builds:
            - env: [CGO_ENABLED=0]
              goos:
                - linux
              goarch:
                - amd64
          nfpms:
            -
              maintainer: YOU <your@email.com>
              bindir: /usr/local/bin
              description: Copy formatted timestamp to system clipboard
              homepage: https://github.com/USERNAME/REPO
              license: MIT
              formats:
                - deb

          release:
            draft: false # If set to true, will not auto-publish the release.
            replace_existing_draft: true
            replace_existing_artifacts: true
            target_commitish: "{{ .Commit }}"
            prerelease: auto
            make_latest: true
            mode: replace
            include_meta: true
          EOF          

      - name: Run GoReleaser
        uses: goreleaser/goreleaser-action@v6
        with:
          distribution: goreleaser
          # 'latest', 'nightly', or a semver
          version: "~> v2"
          args: release --clean --verbose --config /tmp/goreleaser-github.yaml
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

      - name: Upload .deb artifact x86
        uses: actions/upload-artifact@v3
        with:
          name: deb-package
          path: dist/*amd64.deb

  pkgcld_amd64-deb:
    runs-on: ubuntu-latest
    needs:
      - goreleaser
    strategy:
      max-parallel: 3
      matrix:
        distro:
        - debian/bookworm
        - ubuntu/noble
        - ubuntu/jammy
    steps:
      - name: Download .deb artifact
        uses: actions/download-artifact@v3
        with:
          name: deb-package

      - name: Push package to packagecloud.io
        uses: computology/packagecloud-github-action@v0.6
        with:
          package-name: ./*.deb
          packagecloud-username: USERNAME
          packagecloud-reponame: APP_NAME
          packagecloud-distro: ${{ matrix.distro }}
          packagecloud-token: ${{ secrets.PACKAGECLOUD_TOKEN }}



Copier après la connexion

ℹ️重要

プログラム構造や go.mod ファイルなどが適切にセットアップされていることを確認する必要があります。そうしないと、アプリを適切に公開する際に問題が発生します。

補足: Homebrew を使用してアプリを配布することもできますが、PAT シークレットを含む GH アクションがさらに複雑であることと、Apt で十分にカバーされているという事実のため、私は気にしませんでした。 おいしい、そしてシチュー…おいしい! ?

これは、アプリをリリースするときの重要な 2 番目の事柄につながります。 ?DOCUMENTATION?、そして無視されていた Readme.md?!

Readme のフォーマット

まともな Readme には必要だと思う要素がいくつかあります。これらの要素は、ドキュメントがほとんど、あるいはまったくない、あるいは最悪の場合、ドキュメントが不十分なアプリの中であなたのアプリを目立たせるのに役立ちます。

Je vous recommande fortement de suivre ce format pour créer votre propre fichier Lisez-moi ! Je suis un grand fan des badges pour le style, mais j'ai l'impression qu'avoir une petite démo GIF montre vraiment aux gens de quoi il s'agit, tout comme la liste des captures d'écran de vos applications GUI. Utiliser ASCIINEMA était assez simple, et ils ont également un joli convertisseur GIF pour que tout soit parfait.

? Astuce

En remarque, j'ai demandé à CodeGPT de m'écrire quelques tests unitaires GoLang, qui, je le sais, sont normalement pénibles à écrire. C'est un plugin fantastique si vous utilisez la suite JetBrains.

Exemple Lisez-moi

  • Badges de test
  • Démo GIF
  • Badges de couverture
  • Go Bulletin
  • Installer
    • Gestionnaire de packages (ex apt)
    • Installation binaire (ex eget)
    • Allez installer le extrait
  • Utilisation
    • INSTRUCTIONS CLAIRES et exemples d'extraits de code
  • Paramètres
    • Où les paramètres sont enregistrés
    • Utilisez-vous des fichiers INI, JSON, Env Vars ?
  • Comment accéder à l'aide intégrée
  • Comment créer l'application à partir des sources
  • Art antérieur (c'est-à-dire travail/inspiration précédent)

Conclure

De la même manière que lorsque j'ai commencé à apprendre à publier des applications Python, je suis heureux de pouvoir dire que je sens que je peux distribuer correctement n'importe quelle application que j'écris dans GoLang à l'avenir. C’est une compétence intéressante que j’ai acquise, et avec cet article de blog, j’espère qu’il pourra aider les autres à faire de même ! Bravo !

-Jelloeater


? Mastodonte | ? Courriel | ? Commentaires | ☕ Offre-moi un café

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
<🎜>: Grow A Garden - Guide de mutation complet
3 Il y a quelques semaines By DDD
Nordhold: Système de fusion, expliqué
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel Java
1672
14
Tutoriel PHP
1276
29
Tutoriel C#
1256
24
Golang vs Python: performance et évolutivité Golang vs Python: performance et évolutivité Apr 19, 2025 am 12:18 AM

Golang est meilleur que Python en termes de performances et d'évolutivité. 1) Les caractéristiques de type compilation de Golang et le modèle de concurrence efficace le font bien fonctionner dans des scénarios de concurrence élevés. 2) Python, en tant que langue interprétée, s'exécute lentement, mais peut optimiser les performances via des outils tels que Cython.

Golang et C: concurrence vs vitesse brute Golang et C: concurrence vs vitesse brute Apr 21, 2025 am 12:16 AM

Golang est meilleur que C en concurrence, tandis que C est meilleur que Golang en vitesse brute. 1) Golang obtient une concurrence efficace par le goroutine et le canal, ce qui convient à la gestion d'un grand nombre de tâches simultanées. 2) C Grâce à l'optimisation du compilateur et à la bibliothèque standard, il offre des performances élevées près du matériel, adaptées aux applications qui nécessitent une optimisation extrême.

Partage avec Go: un guide du débutant Partage avec Go: un guide du débutant Apr 26, 2025 am 12:21 AM

GOISIDEALFORBEGINNERNERS et combinant pour pourcloudandNetWorkServicesDuetOtssimplicity, Efficiency, andCurrencyFeatures.1) InstallgofromTheofficialwebsiteandverifywith'goversion'..2)

Golang vs C: Performance et comparaison de la vitesse Golang vs C: Performance et comparaison de la vitesse Apr 21, 2025 am 12:13 AM

Golang convient au développement rapide et aux scénarios simultanés, et C convient aux scénarios où des performances extrêmes et un contrôle de bas niveau sont nécessaires. 1) Golang améliore les performances grâce à des mécanismes de collecte et de concurrence des ordures, et convient au développement de services Web à haute concurrence. 2) C réalise les performances ultimes grâce à la gestion manuelle de la mémoire et à l'optimisation du compilateur, et convient au développement du système intégré.

Golang vs Python: différences et similitudes clés Golang vs Python: différences et similitudes clés Apr 17, 2025 am 12:15 AM

Golang et Python ont chacun leurs propres avantages: Golang convient aux performances élevées et à la programmation simultanée, tandis que Python convient à la science des données et au développement Web. Golang est connu pour son modèle de concurrence et ses performances efficaces, tandis que Python est connu pour sa syntaxe concise et son écosystème de bibliothèque riche.

Golang et C: les compromis en performance Golang et C: les compromis en performance Apr 17, 2025 am 12:18 AM

Les différences de performance entre Golang et C se reflètent principalement dans la gestion de la mémoire, l'optimisation de la compilation et l'efficacité du temps d'exécution. 1) Le mécanisme de collecte des ordures de Golang est pratique mais peut affecter les performances, 2) la gestion manuelle de C et l'optimisation du compilateur sont plus efficaces dans l'informatique récursive.

La course de performance: Golang vs C La course de performance: Golang vs C Apr 16, 2025 am 12:07 AM

Golang et C ont chacun leurs propres avantages dans les compétitions de performance: 1) Golang convient à une concurrence élevée et à un développement rapide, et 2) C fournit des performances plus élevées et un contrôle fin. La sélection doit être basée sur les exigences du projet et la pile de technologie d'équipe.

Golang contre Python: les avantages et les inconvénients Golang contre Python: les avantages et les inconvénients Apr 21, 2025 am 12:17 AM

GolangisidealforBuildingsCalableSystemsDuetoitSefficiency and Concurrency, tandis que les Implicites de l'Indrecosystem et le Golang'sDesignenCourageSlecElNCORES

See all articles