当前位置: 首页 > news >正文

在服务器已有目录中部署 Git 仓库

适用场景

本教程为你解决一个非常具体的部署问题:你需要在服务器上一个已经存在的、并且非空的目录(例如由网站面板创建的站点根目录)中,拉取并部署一个 Git 仓库。

因为 git clone 命令只能在空目录或不存在的目录中执行,直接使用会报错,所以我们需要采用“初始化 -> 关联 -> 拉取 -> 重置”这套更灵活的方案。


操作流程

步骤一:准备 GitHub 个人访问令牌 (PAT)

在开始操作服务器之前,我们首先需要准备一个关键的凭据:个人访问令牌(Personal Access Token)。由于 GitHub 不再支持使用账户密码进行命令行操作,令牌是目前唯一的认证方式。

  1. 登录 GitHub
    在你的电脑浏览器上登录 GitHub 账户。

  2. 进入开发者设置
    点击右上角头像 → Settings → 左侧菜单栏底部 Developer settings

  3. 选择令牌类型
    在左侧菜单中,选择 Personal access tokensTokens (classic)

  4. 生成新令牌
    点击页面右上方的 Generate new token 按钮,然后选择 Generate new token (classic)

  5. 配置令牌权限

    • Note (备注):给令牌起个名字,方便你记住它的用途,例如 my-server-deploy
    • Expiration (有效期):选择一个有效期,如 90 days
    • Select scopes (选择权限)这是最重要的一步。 请直接勾选顶级的 repo 复选框。这会授予该令牌所有与仓库相关的权限,足以满足部署需求。
  6. 生成并保存令牌
    滚动到页面底部,点击 Generate token

  7. ⚠️ 立即复制并妥善保管!
    页面会显示一串以 ghp_ 开头的字符,这就是你的令牌。请立即复制它,并保存在一个安全的地方。这个令牌只会显示这一次,刷新或关闭页面后将无法再次查看!


步骤二:登录服务器并执行 Git 操作

现在,你已经拥有了令牌,可以正式开始在服务器上部署了。

  1. 进入目标目录
    通过 SSH 登录你的服务器,然后 cd 到你想要部署代码的目录。

    # 将下面的路径替换成你自己的
    cd /www/wwwroot/www.site.cn
    
  2. 初始化并关联仓库
    首先,将这个目录变成一个本地 Git 仓库;然后,告诉它远程仓库的地址。

    # 1. 初始化
    git init# 2. 关联远程仓库 (将 URL 替换成你自己的)
    git remote add origin https://github.com/www/site.git
    

    你可以运行 git remote -v 来检查是否关联成功。

  3. 拉取远程数据并认证
    这是最关键的交互步骤。运行 fetch 命令来下载远程仓库的所有信息。

    git fetch origin
    

    终端会依次提示你输入凭据:

    • Username for 'https://github.com':

      在这里输入你的 GitHub 用户名,然后回车。

    • Password for 'https://...':

      在这里粘贴你在步骤一中生成的个人访问令牌 (PAT)。注意:输入时光标不会移动,这是正常的,粘贴后直接回车即可。

    如果凭据正确,你会看到下载对象的进度条,代表数据已成功拉取到本地的 .git 数据库中。

  4. 强制更新工作目录
    现在,数据已经下载完毕,我们用最后一条命令,将当前目录的文件强制刷新成和远程仓库一模一样。

    # 警告:此操作会覆盖本地所有文件,请谨慎操作!
    # 确保 origin/main 是你仓库的默认分支 (也可能是 origin/master)
    git reset --hard origin/main
    

    当看到 HEAD is now at ... 的提示时,就意味着你的目录内容已经和远程仓库完全同步了。

  5. 验证成果
    最后,确认一下文件是否都已就位。

    ls -la
    

    列出的文件列表应该和你的 GitHub 仓库根目录完全一致。恭喜你,部署成功!


附录:常见问题排查

  • 问题:认证失败 (Authentication failed)

    • 原因:输入了 GitHub 账户密码,而不是个人访问令牌。
    • 解决:严格按照本教程步骤一生成并使用 PAT。
  • 问题:网络超时 (Connection timed out)

    • 原因:服务器无法连接到 github.com
    • 解决:在服务器上运行 ping github.com 测试网络。如果不通,请检查服务器防火墙或云服务商的安全组规则,确保出站TCP 443 端口是开放的。
  • 问题:所有权可疑 (dubious ownership)

    • 原因:当前用户(如 root)没有此目录的所有权,Git 出于安全考虑发出警告并中断操作。
    • 解决:按照 Git 的提示,将该目录添加为安全目录即可。
      # 将路径替换成你自己的
      git config --global --add safe.directory /www/wwwroot/md.xtyzx.cn
      
http://www.dtcms.com/a/573111.html

相关文章:

  • 宝塔Linux部署 一个基于uni-app 系统指南
  • PostgreSQL 索引
  • Ubuntu20.04配置使用evo工具
  • 远程连接银河麒麟服务器-xrdp方式
  • 做阿里巴巴网站图片大全wordpress添加固定结尾
  • k8s集群搭建(七)-------- 微服务间的调用
  • 华为HCIP网络工程师认证—网络参考模型
  • 商务网站建设策略网站设计 原型图
  • 告别 Class 组件:拥抱 React Hooks 带来的函数式新范式
  • 21、【Ubuntu】【远程开发】技术方案分析:虚拟专用网络(补充)
  • 中山网站制作建设通讯员队伍建设与网站新闻管理
  • 论文阅读:《Hypergraph Motif Representation Learning》
  • 快速了解搭建网站流程——全栈网站搭建指南
  • pdf图片提取器pyqt6版本实现
  • 基于Layui Vue Admin + Spring Boot 3.x 的企业级前后端分离管理系统
  • Apache SeaTunnel 支持 Metalake 开发了!避免任务配置敏感信息暴露
  • 2025年Java面试题及详细解答(MySQL篇)
  • 深入理解 Spring Boot 中的数据库连接池:原理、选型与最佳实践
  • 网站建设实训的目的重庆 新闻发布会
  • Android Init 系列专题【篇六:reboot shutdown】
  • 建设部网站查造价师学院网站建设流程图
  • 人工智能学习中深度学习之python基础之 装饰器(精讲)
  • KP2203LGA宽电压输出PWM驱动控制器芯片典型应用
  • 关闭 macOS 屏幕捕捉 在录制或截图时显示的「录制指示浮窗」。
  • 技术变革:为何C#与.NET是未来的开发方向
  • 借助Redis实现Token黑名单机制
  • 缓存机制:Redis集成
  • 做网站要先申请域名吗搭建网站的英语
  • 优思学院|什么是5M1E?它是如何影响产品质量的?
  • 技术赋能生态保护:无人机RTMP推流平台EasyDSS在野生动植物监测中的应用实践