無趣味の戯言

👯‍♀️

Gemini CLI のサブエージェントを試してみた

話題の家電やデジタル製品がレンタルで試せる GYMGATE 商品一覧はこちらから

こんにちは、だいちゃんです。

以前、このブログで「myHub」という僕専属の AI チームを作った話を書きました。

Gemini CLIで専属チームを組成してみる | 無趣味の戯言

元々は、Claude Code で会社を組織する YouTube 動画を見て、無料で使える Gemini CLI でどこまでイケるかを試してたんですが、 Gemini CLI にも「サブエージェント機能」が追加された らしいので、より近いことができるんじゃないかなと思い、早速試してみました。

サブエージェントが使えるメリット

実際、1つのエージェントの中で複数の役割を演じる以前のやり方でも、困る場面はあまりなかったですが、以下の2点でメリットを享受できそうでした。

  • 並行処理が可能になる
  • コンテキストの負担軽減

一番デカそうなのが、並行処理が可能になる点です。これにより、裏でAIに作業をさせつつ、別の相談ができたりするらしい。これを活かすべく、今回チームメンバーの入れ替えで「スタッフ」を追加しました。裏で簡単な作業をやってもらうアルバイト的な使い方をしてみます。

コンテキストの負担軽減は、あまり困ることはなかったのですが、今後ガンガン使っていく上でメリットが効いてきそうだと感じました。これまでは複数の役割を1つのコンテキストとして扱っていたので、例えば記事を書かせたあとに「今日の残りタスクは?」と聞いてもうまく返してくれない、みたいなことが無くなるようです。

元々コンテキストが溢れる懸念はしていたので、myhub/logs/ に1日毎のログファイルを作り、常に更新するよう指示しているので、コンテキストが分かれる効果は...って気もしますが、余計なコンテキストが別枠で管理されるのは良いことです。

変更箇所

前回の記事からの変更箇所としては、各チームメンバー(旧:役割・現:エージェント)ごとの指示ファイルの置き場所が /instructions/ から /.gemini/agents/ に変更になります。加えて、各ファイルの冒頭部分にYAMLフロントマターを記載してエージェントとして認識できるようにしてあげます。

---
name: engineer
description: 技術参謀。プロジェクトの仕様策定、ドキュメント編集を担当。
tools:
  - read_file
  - grep_search
  - glob
  - list_directory
  - write_file
  - google_web_search
model: inherit
---

エンジニアエージェントだと上記のようなブロックを入れて myhub/.gemini/agents/engineer.md として保存します。

特にエージェントを指定しなかった時に読み込まれる GEMINI.md の変更箇所は、上記の新しいフォルダ構成に書き換えたり、“役割” と書かれている箇所を “エージェント” に置換する程度です。

また、前述の通り、今回はチームメンバーの入れ替えも行いました。

旧メンバー:

  • 秘書
  • PM
  • エンジニア
  • ライター
  • カウンセラー

新メンバー:

  • 秘書
  • エンジニア
  • ライター
  • メンター
  • スタッフ

カウンセラーはメンターに名称を変更して、もっと幅広い相談ができるように位置づけを変えてみました。

そして、バックグラウンドで処理ができるメリットを活かすべく「スタッフ」を新たに入れてみました。エンジニアにスクリプトを書いてもらって自動化するほどでもない、1度きりの単純作業とかに使おうと思います。

また、PMはクビになりました。わざわざPMエージェントを立ち上げて相談するほどのタスクもなさそうなので、秘書が担ってくれます。

スタッフへの依頼

早速、note のエクスポートデータ(巨大な XML ファイル)を解析して、記事ごとに分割して Markdown 形式で保存するというタスクを振ってみました。1回きりのタスクだし、自分でスクリプトを書くのも地味に面倒だし、手動ではやりたくない作業です。

処理内容としては、実際にファイル操作をしているというよりは、Python スクリプトを作って、実行して、作ったスクリプトを削除して実現しているようでした。

とはいえ、自然言語でサクッと依頼できるし、スクリプトの検証とかも不要なので色んな場面で活用できそうな気はします。

運用方法

運用方法はこれまでと変わらず、毎朝の紙にジャーナリングした内容を inbox 内の Markdown ファイルに記載して、Gemini CLI を立ち上げて整理を依頼する流れです。

その際、サブエージェントに任せられそうなタスクは提案してくれるので、必要に応じて @agent の形で別途依頼をしていく流れになります。


日々いろんなサービスが切磋琢磨して機能追加しているので、ぶっちゃけどこに課金すべきか分からなくなってきましたね。

個人的にはGoogle系サービス使うことが多いのでGeminiには頑張ってもらいたいところ。

とはいえ、無料で使える範囲は使い倒したいと思うので、しばらくは Gemini CLI のチューニングでどこまでいけるか頑張ってみたいと思います。

Buy Me A Coffee