• 【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

    # 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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

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

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

    • git remote -v查看所有远程仓库
    origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (fetch)
    origin  http://192.168.1.10/jwensh/qadev-ui-testing.git (push)
    
    • 1
    • 2
    • 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
    [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
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    小建议

    如果有些特殊情况想要保留源地址,也就是旧的地址,可以将其改名字(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 查看
    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)
    
    • 1
    • 2
    • 3
    • 4
  • 相关阅读:
    ubuntu20.04下源码安装hyperscan库安装记录
    云原生之旅 - 6)不能错过的一款 Kubernetes 应用编排管理神器 Kustomize
    如何使用Ruby 多线程爬取数据
    「Docker入门指北」容器很难理解?带你从头到尾捋一遍
    Elasticsearch 集群和分片使用
    Beelzebub过程记录及工具集
    【数据结构-图】最短路径
    spring知识巩固
    vue3相关内容
    Spring Boot中Spring MVC的基本配置讲解与实战(包括静态资源配置,拦截器配置,文件上传配置及实战 附源码)
  • 原文地址:https://blog.csdn.net/u013948858/article/details/134552718