【GIT】代码仓库服务器变更本地修改并推送

author: jwensh

date: 20231122

问题背景

没有使用域名的 gitlb 服务器搬移(IP地址变了), 以至于 gitlab 管理的项目无法进行连接及推送。因为涉及到多个项目工程,所以可以用本地配置修改的方式来进行重新关联(这种修改 remote 的方式适用于多个平台代码仓库间同步代码

命令行操作方式

old_ip:http://192.168.1.10/jwensh/qadev-ui-testing.git

new_ip:http://192.168.100.1/jwensh/qadev-ui-testing.git

shell 复制代码
# git version 2.39.3 (Apple Git-145)

╰─$ git remote -h
usage: git remote [-v | --verbose]
   or: git remote add [-t <branch>] [-m <master>] [-f] [--tags | --no-tags] [--mirror=<fetch|push>] <name> <url>
   or: git remote rename [--[no-]progress] <old> <new>
   or: git remote remove <name>
   or: git remote set-head <name> (-a | --auto | -d | --delete | <branch>)
   or: git remote [-v | --verbose] show [-n] <name>
   or: git remote prune [-n | --dry-run] <name>
   or: git remote [-v | --verbose] update [-p | --prune] [(<group> | <remote>)...]
   or: git remote set-branches [--add] <name> <branch>...
   or: git remote get-url [--push] [--all] <name>
   or: git remote set-url [--push] <name> <newurl> [<oldurl>]
   or: git remote set-url --add <name> <newurl>
   or: git remote set-url --delete <name> <url>

    -v, --verbose         be verbose; must be placed before a subcommand

1. 通过命令直接覆盖修改远程地址

进入 qadev-ui-testing 项目的目录下,命令行输入

  • git remote -v查看所有远程仓库
shell 复制代码
origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (fetch)
origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (push)
  • git remote set-url origin http://192.168.100.1/jwensh/qadev-ui-testing.git 直接覆盖修改

2. 通过命令先删除旧的,再添加远程仓库

  • git remote rm origin
  • git remote add origin http://192.168.100.1/jwensh/qadev-ui-testing.git

3. 直接修改配置文件

修改 [remote "origin"] 下面的 url 即可

  • vim qadev-ui-testing/.git/config
shell 复制代码
[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
        ignorecase = true
        precomposeunicode = true
[remote "origin"]
        url = http://192.168.1.10/jwensh/qadev-ui-testing.git
        fetch = +refs/heads/*:refs/remotes/origin/*
[branch "main"]
        remote = origin
        merge = refs/heads/main

小建议

如果有些特殊情况想要保留源地址,也就是旧的地址,可以将其改名字(github,gitee)

  • git remote rename origin old_origin 将 origin 更改为 old_origin
  • git remote add origin http://192.168.100.1/jwensh/qadev-ui-testing.git 然后在新添加一个 origin
  • git remote -v 查看
shell 复制代码
old_origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (fetch)
old_origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (push)
origin  	http://192.168.100.1/jwensh/qadev-ui-testing.git (fetch)
origin  	http://192.168.100.1/jwensh/qadev-ui-testing.git (push)
相关推荐
码农君莫笑22 分钟前
《信管通低代码信息管理系统开发平台》Windows环境安装说明
服务器·数据库·windows·低代码·c#·bootstrap·.netcore
fnd_LN32 分钟前
Linux文件目录 --- mkdir命令,创建目录,多级目录,设置目录权限
linux·运维·服务器
Domain-zhuo1 小时前
Git和SVN有什么区别?
前端·javascript·vue.js·git·svn·webpack·node.js
沛沛老爹2 小时前
CI/CD是什么?
运维·git·ci/cd
IPdodo全球网络服务2 小时前
如何通过TikTok引流到私域流量池
运维·服务器·网络
开疆智能3 小时前
ModbusTCP转Profinet:工业通信的利器
linux·服务器·网络
向阳花花花花3 小时前
git clone 和 conda 换源
git·conda
彩虹糖_haha3 小时前
Linux高并发服务器开发 第六天(rwx 对于目录和文件的区别 gcc编译器 动态库静态库)
linux·运维·服务器
溟洵3 小时前
【C++】异步(并发)实现 线程池 ---附源码+实现步骤(future、async、promise、package_task、任务池原理和框架)
服务器·网络·c++·分布式·后端
breaksoftware5 小时前
Windows Subsystem for Linux——设置默认登录用户名
linux·运维·服务器