Managing Goose Sessions
A session is a single, continuous interaction between you and Goose, providing a space to ask questions and prompt action. In this guide, we'll cover how to start, exit, and resume a session.
Start Session
- Goose CLI
- Goose Desktop
From your terminal, navigate to the directory from which you'd like to start, and run:
goose session
After choosing an LLM provider, you’ll see the session interface ready for use. Type your questions, tasks, or instructions directly into the input field, and Goose will immediately get to work.
To start a new session at any time, click the three dots in the top-right corner of the application and select New Session from the dropdown menu.
If this is your first session, Goose will prompt you for an API key to access an LLM (Large Language Model) of your choice. For more information on setting up your API key, see the Installation Guide. Here is the list of supported LLMs.
Name Session
- Goose CLI
- Goose Desktop
By default, Goose names your session using the current timestamp in the format YYYYMMDD_HHMMSS
. If you'd like to provide a specific name, this is where you'd do so. For example to name your session react-migration
, you would run:
goose session -n react-migration
You'll know your session has started when your terminal looks similar to the following:
starting session | provider: openai model: gpt-4o
logging to ~/.local/share/goose/sessions/react-migration.json1
Within the Desktop app, sessions are automatically named using the current timestamp in the format YYYYMMDD_HHMMSS
. Goose also provides a description of the session based on context.
Exit Session
Note that sessions are automatically saved when you exit.
- Goose CLI
- Goose Desktop
To exit a session, type exit
. Alternatively, you exit the session by holding down Ctrl+C
.
Your session will be stored locally in ~/.local/share/goose/sessions
.
To exit a session, simply close the application.
Resume Session
- Goose CLI
- Goose Desktop
To resume your latest session, you can run the following command:
goose session -r
To resume a specific session, run the following command:
goose session -r --name <name>
For example, to resume the session named react-migration
, you would run:
goose session -r --name react-migration
While you can resume sessions using the commands above, we recommend creating new sessions for new tasks to reduce the chance of doom spiraling.
- Click
...
in the upper right corner - Click
Previous Sessions
- Click a session
- Click
Resume Session
in the upper right corner
Resume Session Across Interfaces
You can resume a CLI session in Desktop and vice versa.
- Goose CLI
- Goose Desktop
To resume a Desktop session within CLI, get the name of the session from the Desktop app. Note that unless you specifically named the session, its default name is a timestamp in the format YYYYMMDD_HHMMSS
.
- Open Goose Desktop
- Click
...
in the upper right corner - Click
Previous Sessions
- Find the session that you want to resume, and copy the basename (without the
.jsonl
extension).
Desktop Session
Session Description | Session Filename |
---|---|
GitHub PR Access Issue | 20250305_113223.jsonl |
CLI Command
goose session -r --name 20250305_113223
All saved sessions are listed in the Desktop app, even CLI sessions. To resume a CLI session within the Desktop:
- Click
...
in the upper right corner - Click
Previous Sessions
- Click the session you'd like to resume
If you named the session, you'll recognize the filename. However, if you don't remember the exact session name, there is a description of the topic.
- Click
Resume Session
in the upper right corner
CLI Command
goose session -n react-migration
Desktop Session
Session Description | Session Filename |
---|---|
Code Migration to React | react-migration.jsonl |