重启之后清除登录信息

This commit is contained in:
2025-07-15 19:55:59 +08:00
parent 4caff7542e
commit 0b2974e2c9
18 changed files with 1873 additions and 86 deletions

153
LOCK_FILE_FIX.md Normal file
View File

@@ -0,0 +1,153 @@
# 锁文件和缓存问题修复说明
## 问题描述
运行 `npm run dev` 时遇到以下问题:
1. **锁文件被占用**`EBUSY: resource busy or locked, unlink 'lockfile'`
2. **单实例检查失败**:即使锁文件无效,也无法启动新实例
3. **缓存错误**`Unable to move the cache: 拒绝访问``Failed to delete the database`
## 问题原因分析
1. **文件占用**:锁文件被其他进程占用,无法删除
2. **进程检查不准确**:锁文件中的 PID 为 NaN导致进程检查失败
3. **缓存冲突**:多个实例同时访问缓存目录导致冲突
4. **权限问题**:某些文件需要管理员权限才能删除
## 修复内容
### 1. 改进锁文件删除机制 (`src/main/utils/singleInstance.js`)
- 添加 `safeDeleteFile()` 方法,处理文件被占用的情况
- 在 Windows 上使用 `del /F /Q` 命令强制删除
- 改进错误处理和日志记录
### 2. 智能单实例检查
- 检查是否有实际的窗口存在,而不仅仅依赖锁文件
- 如果找不到现有窗口,允许强制启动新实例
- 添加详细的日志记录
### 3. 缓存清理和配置 (`src/main/index.js`)
- 添加缓存相关命令行参数
- 在应用启动时清理缓存目录
- 避免缓存冲突
### 4. 托盘菜单增强 (`src/main/tray.js`)
- 改进"清理实例锁"功能,处理文件占用情况
- 添加"强制重启应用"选项
- 提供更安全的文件删除机制
### 5. 测试脚本 (`test-lock-cleanup.js`)
- 提供锁文件清理功能的测试
- 验证文件删除机制
- 帮助调试锁文件问题
## 修复后的功能特点
### 安全的文件删除
1. **多重尝试**:首先尝试直接删除,失败后使用系统命令
2. **错误处理**:区分不同类型的错误,提供相应的解决方案
3. **日志记录**:详细记录删除过程和结果
### 智能启动逻辑
1. **窗口检查**:检查是否有实际的窗口存在
2. **强制启动**:如果锁文件无效且无窗口,允许强制启动
3. **详细日志**:记录每个决策步骤
### 缓存管理
1. **启动时清理**:应用启动时自动清理缓存目录
2. **命令行配置**:添加缓存相关配置避免冲突
3. **错误处理**:处理缓存清理过程中的错误
## 使用方法
### 自动修复
1. 重新运行 `npm run dev`
2. 应用会自动处理锁文件和缓存问题
3. 如果锁文件被占用,会尝试强制删除
### 手动清理
1. 右键点击托盘图标
2. 选择"清理实例锁"或"强制重启应用"
3. 查看日志确认操作结果
### 测试功能
```bash
# 测试锁文件清理功能
node test-lock-cleanup.js
```
## 修复后的启动流程
### 正常启动
```
[时间] 开始检查单实例锁...
[时间] 发现锁文件: [路径]
[时间] 进程 [PID] 不存在,尝试删除无效锁文件
[时间] 成功删除文件: [路径]
[时间] 单实例锁检查结果: true
[时间] 这是第一个实例,继续启动
[时间] 应用已准备就绪,开始初始化...
[时间] 清理缓存目录: [路径]
[时间] 缓存目录清理完成: [路径]
```
### 锁文件被占用
```
[时间] 发现锁文件: [路径]
[时间] 文件被占用,无法删除: [路径]
[时间] 使用 del 命令删除文件: [路径]
[时间] 单实例锁检查结果: true
[时间] 这是第一个实例,继续启动
```
### 强制启动
```
[时间] 单实例锁检查结果: false
[时间] 检测到已有实例运行
[时间] 未找到现有实例窗口,可能是锁文件问题,允许强制启动
[时间] 这是第一个实例,继续启动
```
## 常见问题解决
### 1. 锁文件仍然无法删除
1. 使用托盘菜单的"强制重启应用"功能
2. 手动删除锁文件:
```cmd
del /F /Q "C:\Users\[用户名]\AppData\Roaming\market-manager-gui\lockfile"
```
3. 重启开发环境
### 2. 缓存错误仍然存在
1. 手动清理缓存目录:
```cmd
rmdir /S /Q "C:\Users\[用户名]\AppData\Roaming\market-manager-gui\Cache"
rmdir /S /Q "C:\Users\[用户名]\AppData\Roaming\market-manager-gui\Code Cache"
```
2. 以管理员身份运行应用
### 3. 权限问题
1. 以管理员身份运行命令提示符
2. 手动删除相关文件
3. 检查文件权限设置
## 注意事项
### 1. 开发环境
- 在开发过程中,锁文件和缓存可能会频繁创建和删除
- 如果遇到问题,使用托盘菜单的清理功能
- 查看日志文件获取详细信息
### 2. 生产环境
- 确保应用正常退出时能清理锁文件
- 监控缓存目录的大小
- 定期检查是否有无效锁文件
### 3. 调试建议
- 使用 `test-lock-cleanup.js` 脚本测试文件删除功能
- 查看日志文件了解锁文件和缓存的状态
- 使用托盘菜单的手动清理功能
## 相关文件
- `src/main/utils/singleInstance.js` - 单实例锁管理工具(已更新)
- `src/main/index.js` - 主进程启动文件(已更新)
- `src/main/tray.js` - 托盘功能(已更新)
- `test-lock-cleanup.js` - 锁文件清理测试脚本