12k
All articles

如何从终端创建拉取请求

介绍如何使用 GitHub CLI 从终端创建 pull request,涵盖分支管理、冲突解决,以及通过 shell 脚本和模板自动化重复性 PR 任务。

OpenReplay Team
OpenReplay Team
如何从终端创建拉取请求

拉取请求(Pull Requests,简称PRs)是GitHub协作开发的基础,它使代码审查和讨论在更改合并前成为可能。本指南将解释如何使用终端高效创建和管理PRs,主要使用GitHub CLI(gh)工具。

要点

  • 学习使用GitHub CLI管理PR
  • 掌握基于终端的PR工作流程
  • 遵循PR创建的最佳实践
  • 处理常见的故障排除场景
  • 实现高级PR功能

前提条件

开始前,请确保您已准备:

  • 安装并配置Git(下载Git
  • 安装GitHub CLI(gh)(GitHub CLI文档
  • GitHub账户(注册
  • 仓库访问权限和必要的权限
  • 基本了解Git命令

设置GitHub CLI

安装

根据您的操作系统选择:

macOS

# 使用Homebrew
brew install gh

# 使用MacPorts
sudo port install gh

Linux

# Debian/Ubuntu
curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | sudo dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg
echo ""deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main"" | sudo tee /etc/apt/sources.list.d/github-cli.list > /dev/null
sudo apt update
sudo apt install gh

# Fedora
sudo dnf install gh

# Arch Linux
sudo pacman -S github-cli

Windows

# 使用Scoop
scoop install gh

# 使用Winget
winget install --id GitHub.cli

认证

安装后,与GitHub进行认证:

gh auth login

按照交互式提示完成认证。您可以选择HTTPS或SSH协议。

创建拉取请求

1. 准备您的分支

# 更新本地main分支
git checkout main
git pull origin main

# 创建并切换到新的功能分支
git checkout -b feature/your-feature-name

2. 进行更改并提交

# 暂存所有更改
git add .

# 创建一个描述性的提交信息
git commit -m ""feat: implement new feature

- Added new functionality
- Updated documentation
- Fixed related issues""

3. 推送更改

# 将分支推送到GitHub
git push -u origin feature/your-feature-name

4. 创建拉取请求

使用GitHub CLI(推荐)

基本PR创建

gh pr create --title ""Feature: Implement New Functionality"" --body ""Description of changes""

高级PR创建

gh pr create 
  --title ""Feature: Implement New Functionality"" 
  --body ""## Changes
- Implemented new feature
- Updated tests
- Added documentation

## Related Issues
Closes #123"" 
  --base main 
  --head feature/your-feature-name 
  --reviewer username1,username2 
  --label ""enhancement,documentation"" 
  --milestone ""v1.0.0"" 
  --project ""Project Board""

5. 管理您的PR

# 在浏览器中查看PR
gh pr view --web

# 检查PR状态
gh pr status

# 列出所有PR
gh pr list

# 向现有PR添加审阅者
gh pr edit --add-reviewer username1,username2

# 添加标签
gh pr edit --add-label ""priority,bug""

最佳实践

  1. 分支命名
    • 使用描述性前缀:feature/fix/docs/refactor/
    • 如适用,包含问题编号:feature/123-user-authentication
  2. 提交信息
    • 遵循约定式提交(约定
    • 包含范围和描述
    • 引用问题:""fixes #123""
  3. PR描述
    • 如有可用,使用模板
    • 包含上下文和理由
    • 列出相关问题和依赖
    • 为UI更改添加截图
  4. 代码审查
    • 及时回应反馈
    • 根据需要更新PR描述
    • 快速解决冲突

故障排除

常见问题及解决方案

  1. 认证失败

    gh auth login --web
    
  2. 推送被拒绝

    git pull origin main
    git rebase main
    git push -f origin feature/your-feature-name
    
  3. 合并冲突

    git checkout main
    git pull
    git checkout feature/your-feature-name
    git rebase main
    # 解决冲突并继续
    git rebase --continue
    

高级功能

草稿PR

gh pr create --draft

PR模板

在您的仓库中创建.github/pull_request_template.md文件,用于标准化PR描述。

自动化PR创建

您可以为常见的PR模式创建shell别名或脚本:

# 添加到.bashrc或.zshrc
alias pr-create='gh pr create --template ""template.md"" --label ""needs-review""'

记得保持GitHub CLI更新以获取最新功能:

# 更新GitHub CLI
gh update

常见问题解答

认证失败怎么办?

使用 `gh auth login --web` 通过浏览器而不是终端界面进行认证。

如何处理被拒绝的推送?

1. 拉取最新更改:`git pull origin main` 2. 变基您的分支:`git rebase main` 3. 强制推送:`git push -f origin feature/your-feature-name`

如何解决合并冲突?

1. 切换到main分支:`git checkout main` 2. 拉取最新更改:`git pull` 3. 切换到您的分支:`git checkout feature/your-feature-name` 4. 变基:`git rebase main` 5. 解决冲突并继续:`git rebase --continue`

我可以创建草稿PR吗?

是的,使用 `--draft` 标志:`gh pr create --draft`

如何使用PR模板?

在您的仓库中创建 `.github/pull_request_template.md` 文件,用于标准化PR描述。

结论

掌握基于终端的创建和管理拉取请求的方法可以显著提升您的开发工作流程。GitHub CLI(gh)提供了一套强大的工具,可以简化从创建到合并的PR流程。通过遵循本指南中概述的最佳实践并利用GitHub CLI的功能,您可以:

  • 通过避免终端和浏览器之间的上下文切换来节省时间
  • 通过模板和约定保持一致的PR质量
  • 高效处理常见的PR挑战
  • 自动化重复性PR相关任务

Listen to your bugs 🧘, with OpenReplay

See how users use your app and resolve issues fast.
Loved by thousands of developers

We use cookies to improve your experience. By using our site, you accept cookies.