本文档说明如何将CodeSeek项目推送到GitHub仓库。
- 登录 GitHub
- 点击右上角
+→New repository - 输入仓库名(建议:
codeseek) - 不要勾选 "Initialize this repository with a README"(避免创建冲突)
- 点击
Create repository
# 进入项目目录
cd /path/to/codeseek
# 初始化Git仓库
git init
# 添加所有文件到暂存区
git add .
# 提交到本地仓库
git commit -m "Initial commit: CodeSeek v2.0.0"# 使用HTTPS方式(简单)
git remote add origin https://github.com/你的用户名/codeseek.git
# 或使用SSH方式(推荐,更安全)
git remote add origin git@github.com:你的用户名/codeseek.git
# 验证远程仓库
git remote -v# 首次推送(设置上游分支)
git push -u origin main
# 如果本地默认分支是master,先重命名
git branch -M main
git push -u origin main# 1. 查看当前状态
git status
# 2. 添加修改的文件
git add . # 添加所有修改
git add filename.txt # 添加特定文件
# 3. 提交更改
git commit -m "feat: 添加新功能描述"
# 4. 推送到远程
git push推荐使用 Conventional Commits 规范:
<type>(<scope>): <subject>
<body>
<footer>
类型(type):
feat: 新功能fix: 修复Bugdocs: 文档更新style: 代码格式(不影响功能)refactor: 重构代码perf: 性能优化test: 测试相关chore: 构建/工具相关
示例:
git commit -m "feat(search): 添加搜索建议功能"
git commit -m "fix(auth): 修复登录Token过期问题"
git commit -m "docs: 更新API文档"
git commit -m "refactor(frontend): 重构组件结构"
git commit -m "feat(config): 新增系统配置管理页面"
git commit -m "security: 增强邮箱验证码限流机制"问题: 推送时提示权限错误
解决方案:
# 使用SSH方式需要先配置SSH密钥
# 参考: https://docs.github.com/en/authentication/connecting-to-github-with-ssh
# 或使用HTTPS + Personal Access Token
# GitHub已不再支持密码认证,需要使用Token问题: 本地分支是master,远程是main
解决方案:
# 重命名本地分支
git branch -M main
# 推送到main分支
git push -u origin main问题: 远程仓库初始化了README,导致推送失败
解决方案:
# 拉取远程更改并合并
git pull origin main --allow-unrelated-histories
# 解决冲突后提交
git add .
git commit -m "merge: 合并远程仓库"
# 推送
git push -u origin main问题: 存在未解决的合并冲突
解决方案:
# 查看冲突文件
git status
# 手动解决冲突后
git add <冲突文件>
git commit -m "merge: 解决合并冲突"
# 或中止合并
git merge --abort
# 强制使用远程版本
git fetch --all
git reset --hard origin/main问题: 提交了错误的代码
解决方案:
# 撤销最近一次提交(保留修改)
git reset --soft HEAD~1
# 撤销最近一次提交(丢弃修改)
git reset --hard HEAD~1
# 已推送到远程,需要强制推送(谨慎使用)
git push --force确保项目根目录有 .gitignore 文件:
# 依赖目录
node_modules/
# 构建输出
dist/
build/
# 环境变量
.env
.env.local
.env.*.local
# IDE配置
.idea/
.vscode/
*.swp
*.swo
# 系统文件
.DS_Store
Thumbs.db
# 日志文件
*.log
npm-debug.log*
# Wrangler临时文件
.wrangler/
# TypeScript缓存
*.tsbuildinfo# 创建新功能分支
git checkout -b feature/new-feature
# 切换回主分支
git checkout main
# 合并分支
git merge feature/new-feature
# 删除已合并的分支
git branch -d feature/new-feature# 拉取最新更改
git pull origin main
# 或使用fetch + merge
git fetch origin
git merge origin/main- 创建功能分支进行开发
- 推送分支到GitHub
- 在GitHub上创建Pull Request
- 代码审查后合并
# 创建功能分支
git checkout -b feature/amazing-feature
# 开发完成后推送
git push origin feature/amazing-feature
# 在GitHub上创建PR,合并后删除分支
git checkout main
git pull
git branch -d feature/amazing-feature# 不要提交敏感信息
# 使用环境变量存储密钥
# 在Cloudflare Dashboard中设置secrets
# 如果不小心提交了敏感信息
# 1. 立即更改密钥
# 2. 从Git历史中移除
git filter-branch --force --index-filter \
"git rm --cached --ignore-unmatch path/to/sensitive-file" \
--prune-empty --tag-name-filter cat -- --all
# 3. 强制推送
git push --force --all项目已配置GitHub Actions,可实现自动部署。
.github/workflows/backend-deploy.yml
- 推送到
main分支 - 手动触发
在GitHub仓库设置中添加以下Secrets:
| Secret名称 | 说明 |
|---|---|
CLOUDFLARE_API_TOKEN |
Cloudflare API Token |
CLOUDFLARE_ACCOUNT_ID |
Cloudflare账户ID |
- 登录 Cloudflare Dashboard
- 进入 My Profile > API Tokens
- 创建Token,选择 "Edit Cloudflare Workers" 模板
- 复制Token到GitHub Secrets
推送完成后:
- 访问 GitHub 仓库页面
- 确认所有文件已上传
- 检查 README.md 正确显示
- 验证 GitHub Actions 是否成功运行(如有配置)