Claude Code セッションデータ損失:Windows および Mac 向けバックアップスクリプト

✍️ OpenClawRadar📅 公開日: June 7, 2026🔗 Source
Claude Code セッションデータ損失:Windows および Mac 向けバックアップスクリプト
Ad

r/ClaudeAIの複数のユーザーが、Claude Codeがセッションデータを静かに消失することを報告しています。サイドバーにはセッションタイトルが残りますが、クリックすると空のトランスクリプトが表示されます。警告もエラーも復旧手段もありません。これはコンテキスト圧縮時、予期しない終了時、またはストレージ層の問題で発生するようです。

Ad

バックアップソリューション

コミュニティが作成したスクリプトは、~/.claude からすべてのClaude Codeデータ(sessionsprojectsplansdraftsmemory)を別のフォルダにバックアップし、Windowsではタスクスケジューラ、Macではlaunchdを使用して毎日自動実行し、最大7日間のローテーションバックアップを保持します。

Windows(PowerShell + タスクスケジューラ)

バックアップフォルダを作成:

mkdir C:\Users\%USERNAME%\ClaudeBackups

以下の内容を backup-claude-sessions.ps1 としてそのフォルダに保存:

$ErrorActionPreference = "Stop"
$source = "$env:USERPROFILE\.claude"
$backupRoot = "$env:USERPROFILE\ClaudeBackups"
$logFile = Join-Path $backupRoot "backup.log"
$keepDays = 7
$timestamp = Get-Date -Format "yyyy-MM-dd_HHmmss"
$backupDir = Join-Path $backupRoot $timestamp
$dirs = @("sessions", "projects", "plans", "drafts", "memory")

function Write-Log($msg) { $line = "$(Get-Date -Format 'yyyy-MM-dd HH:mm:ss') - $msg" Add-Content -Path $logFile -Value $line -Encoding utf8 }

try { Write-Log "=== Backup started ===" New-Item -ItemType Directory -Path $backupDir -Force | Out-Null foreach ($d in $dirs) { $src = Join-Path $source $d if (Test-Path $src) { $dst = Join-Path $backupDir $d Copy-Item -Path $src -Destination $dst -Recurse -Force $count = (Get-ChildItem $dst -Recurse -File -ErrorAction SilentlyContinue | Measure-Object).Count Write-Log " Copied $d ($count files)" } else { Write-Log " Skipped $d (not found)" } } $size = (Get-ChildItem $backupDir -Recurse -File | Measure-Object -Property Length -Sum).Sum Write-Log " Total backup size: $([math]::Round($size/1MB, 2)) MB" $cutoff = (Get-Date).AddDays(-$keepDays) Get-ChildItem $backupRoot -Directory | Where-Object { $.Name -match '^\d{4}-\d{2}-\d{2}\d{6}$' -and $.CreationTime -lt $cutoff } | ForEach-Object { Remove-Item $.FullName -Recurse -Force -Confirm:$false Write-Log " Rotated old backup: $($.Name)" } Write-Log "=== Backup completed successfully ===" } catch { Write-Log "!!! BACKUP FAILED: $" exit 1 }

install-schedule.ps1 を作成し、管理者として一度実行:

$action = New-ScheduledTaskAction     -Execute "powershell.exe"
    -Argument "-ExecutionPolicy Bypass -WindowStyle Hidden -File "$env:USERPROFILE\ClaudeBackups\backup-claude-sessions.ps1""
$trigger = New-ScheduledTaskTrigger -Daily -At 8:00AM
$settings = New-ScheduledTaskSettingsSet     -AllowStartIfOnBatteries
    -DontStopIfGoingOnBatteries     -StartWhenAvailable Register-ScheduledTask
    -TaskName "ClaudeSessionsBackup"     -Action $action
    -Trigger $trigger     -Settings $settings
    -Description "Daily backup of Claude Code sessions" `
    -RunLevel Limited
Write-Host "Done! Runs daily at 8:00 AM." -ForegroundColor Green

インストーラを実行:

powershell -ExecutionPolicy Bypass -File "C:\Users%USERNAME%\ClaudeBackups\install-schedule.ps1"

Mac(launchd + シェルスクリプト)

バックアップフォルダを作成:

mkdir -p /ClaudeBackups

/ClaudeBackups/backup-claude-sessions.sh として保存:

#!/bin/bash
set -euo pipefail
SOURCE="$HOME/.claude"
BACKUP_ROOT="$HOME/ClaudeBackups"
LOG_FILE="$BACKUP_ROOT/backup.log"
KEEP_DAYS=7
TIMESTAMP=$(date +"%Y-%m-%d_%H%M%S")
BACKUP_DIR="$BACKUP_ROOT/$TIMESTAMP"
DIRS=("sessions" "projects" "plans" "drafts" "memory")
log() { echo "$(date '+%Y-%m-%d %H:%M:%S') - $1" >> "$LOG_FILE"; }
log "=== Backup started ==="
mkdir -p "$BACKUP_DIR"
for d in "${DIRS[@]}"; do
    src="$SOURCE/$d"
    if [ -d "$src" ]; then
        cp -R "$src" "$BACKUP_DIR/$d"
        count=$(find "$BACKUP_DIR/$d" -type f | wc -l | tr -d ' ')
        log " Copied $d ($count files)"
    else
        log " Skipped $d (not found)"
    fi
done
size=$(du -sb "$BACKUP_DIR" | cut -f1)
log " Total backup size: $(echo "scale=2; $size/1048576" | bc) MB"
find "$BACKUP_ROOT" -maxdepth 1 -type d -name "????-??-??_??????" -mtime +$KEEP_DAYS -exec rm -rf {} + -exec log " Rotated old backup: {}" ;
log "=== Backup completed successfully ==="

実行可能にしてlaunchdでスケジュール設定(plistの設定については元の投稿を参照)。

このスクリプトはClaude Codeから完全に独立して動作するため、Claudeがクラッシュしたりデータが失われても、バックアップは保持されます。各実行は backup.log に記録され、確認できます。

📖 ソース記事: r/ClaudeAI

Ad

👀 See Also

自己進化スキルパターンの検証:5ラウンド実験結果
Tools

自己進化スキルパターンの検証:5ラウンド実験結果

開発者は、MySQLデータベース(29テーブル、590MBのスマートビル管理データ)で5ラウンドの実験を行い、Claude Code向けの自己進化型スキル設計パターンを検証しました。主な結果は、63.6%のファイブゲート拒否率、段階的収束、誤った知識が一切残らない100%の精度でした。

OpenClawRadar
ナレッジレイヴン:Claude用検索可能ナレッジベースプラグイン
Tools

ナレッジレイヴン:Claude用検索可能ナレッジベースプラグイン

Knowledge Ravenは、Claude DesktopプラグインまたはMCPサーバーを介して、Confluence、Notion、Google Drive、Dropbox、GitHubなどのソースからClaudeがドキュメントを検索できるツールで、意味検索、キーワード検索、完全なドキュメント取得を提供します。

OpenClawRadar
ローカルAIエージェントとクラウドAIエージェントの比較:OpenClawとTwin.so
Tools

ローカルAIエージェントとクラウドAIエージェントの比較:OpenClawとTwin.so

OpenClawは、完全なデータ制御を備えたマシン上で動作するオープンソースのローカルAIエージェントです。一方、Twin.soは、24時間365日の自動化を実現する20万以上のコミュニティ構築エージェントを備えたクラウドベースのプラットフォームです。

OpenClawRadar
OpenClaw-Mem0プラグインは、コンテキストウィンドウ外に永続メモリを追加します
Tools

OpenClaw-Mem0プラグインは、コンテキストウィンドウ外に永続メモリを追加します

openclaw-mem0プラグインは、メモリストレージをOpenClawのコンテキストウィンドウの外部に完全に移行し、圧縮やセッション再起動による損失を防ぎます。クラウドとローカルの両方のセットアップオプションで、自動的な想起とキャプチャを提供します。

OpenClawRadar