Git: 搭建一个本地私人仓库

寝室放个电脑、实验室也有个电脑

为进行数据同步,充分利用实验室的服务器搭建了个本地私人仓库

1. 安装流程

当然首先保证服务器上与PC机上都已经安装了可用的Git

  1. 在PC机创建一个git仓库,该仓库做作为后续同步的仓库了,如:

    在PC机创建了C:\Users\ZhuCC\Desktop\git-test

    进入文件夹中,打开 git bash 输入 git init 初始化该仓库,如下

    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test
    $ git init
    Initialized empty Git repository in C:/Users/ZhuCC/Desktop/git-test/.git/
    (base)

    然后在该文件夹中随意放入一些文件,后续看看同步效果

    - git-test
    - 1.txt # 写个 1
    - 2.txt # 写个 2
    - 3.txt # 写个 3

    然后把这些文件同步一下:

    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test (master)
    $ git add *
    (base)
    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test (master)
    $ git commit -m "first"
    [master (root-commit) e1cb987] first
    3 files changed, 3 insertions(+)
    create mode 100644 1.txt
    create mode 100644 2.txt
    create mode 100644 3.txt
    (base)
  2. 进入服务器中,先输入命令ssh-keygen -t rsa -C创建一个服务器非对称秘钥

    (base) zzq@ubuntu-C246-WU4:~$ ssh-keygen -t rsa
    Generating public/private rsa key pair.
    Enter file in which to save the key (/home/zzq/.ssh/id_rsa): # 回车确定文件就建立在次
    Created directory '/home/zzq/.ssh'.
    Enter passphrase (empty for no passphrase): # 直接回车,不需要passphrase
    Enter same passphrase again:
    Your identification has been saved in /home/zzq/.ssh/id_rsa.
    Your public key has been saved in /home/zzq/.ssh/id_rsa.pub.
    The key fingerprint is:
    SHA256:73+kgj3czGdjTcgKaabdCmiHE4PmIqJygH6zpYaiPwo
    zzq@ubuntu-C246-WU4
    The key's randomart image is:
    +---[RSA 2048]----+
    | |
    | |
    | |
    | . |
    |. o o S . . . |
    |o o = .= + .|
    |E.o ..= oO.* + o |
    |*+o=o. ooo* B * .|
    |B+++o o=.= . |
    +----[SHA256]-----+
  3. 进入.ssh文件,创建 authorized_keys文件,并复制PC机上的公钥到该文件中

    (base) zzq@ubuntu-C246-WU4:~$ cd .ssh/
    (base) zzq@ubuntu-C246-WU4:~/.ssh$ vim authorized_keys
    # 然后PC机的公钥复制进去
    # 公钥的位置在:C:\Users\PC机用户名\.ssh\id_rsa.pub
    # 比如我的为:ssh-rsa A......s= zhuchengchao.zj@outlook.com
    # 复制完成后,如下:
    (base) zzq@ubuntu-C246-WU4:~/.ssh$ cat authorized_keys
    sh-rsa A......vACfSqFpS29u1M2JckD42Ww3CFQs= zhuchengchao.zj@outlook.com

    注意

    如没有该文件的话,在PC机上通过命令:ssh-keygen -t rsa -C "邮箱地址"来生成

  4. 打开文件:/etc/ssh/sshd_config,修改如下:

    RSAAuthentication yes
    PubkeyAuthentication yes
    AuthorizedKeysFile .ssh/authorized_keys
  5. 在服务器上创建一个空文件夹,作为和PC同步的仓库

    (base) zzq@ubuntu-C246-WU4:~$ mkdir git
    (base) zzq@ubuntu-C246-WU4:~$ cd ./git/
    (base) zzq@ubuntu-C246-WU4:~/git$ git init --bare git-test.git
    初始化空的 Git 仓库于 /home/zzq/git/git-test.git/ # 创建成功
    (base) zzq@ubuntu-C246-WU4:~/git$ cd ./git-test.git/ # 进入看下里面有啥
    (base) zzq@ubuntu-C246-WU4:~/git/git-test.git$ ls
    branches config description HEAD hooks info objects refs
  6. 开始同步:把PC机上创建的仓库同步到服务器上创建的仓库,在PC机上操作:

    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test (master)
    $ git remote add origin zzq@10.12.11.192:/home/zzq/git/git-test.git # 进行连接
    (base)
    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test (master)
    $ git remote -v # 查看是否连接成功
    origin zzq@10.12.11.192:/home/zzq/git/git-test.git (fetch)
    origin zzq@10.12.11.192:/home/zzq/git/git-test.git (push)
    (base)
    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop/git-test (master)
    $ git push origin master # 进行推送 PC->服务器
    zzq@10.12.11.192's password: # 输入服务器的密码
    Enumerating objects: 5, done.
    Counting objects: 100% (5/5), done.
    Delta compression using up to 4 threads
    Compressing objects: 100% (2/2), done.
    Writing objects: 100% (5/5), 284 bytes | 284.00 KiB/s, done.
    Total 5 (delta 0), reused 0 (delta 0)
    To 10.12.11.192:/home/zzq/git/git-test.git
    * [new branch] master -> master
    (base) # 推送成功
  7. 把服务器上的内容clone到PC机上,在PC机上操作:

    ZhuCC@DESKTOP-3AB85C8 MINGW64 ~/Desktop
    $ git clone zzq@10.12.11.192:/home/zzq/git/git-test.git
    Cloning into 'git-test'...
    zzq@10.12.11.192's password: # 注入服务器密码
    remote: 对象计数中: 5, 完成.
    remote: 压缩对象中: 100% (2/2), 完成.
    remote: Total 5 (delta 0), reused 0 (delta 0)
    Receiving objects: 100% (5/5), done.
    (base) # 克隆成功

emmm...

第一遍安装时,其实是不需要输入服务器密码的,可以直接push/clone

后来服务器崩了,被我重装后就需要每次都输入密码了,因为对使用影响不大所有也没有管,若有解决方案的麻烦告诉我一下,谢谢

2. 加上小乌龟

在PC机上,我安装了 TortoiseGit,通过其进行push/clone更加方便

具体对小乌龟的使用参考:TortoiseGit

  1. 配置小乌龟,在PC机上的仓库,右击选择 TortoiseGit -> 设置(s),如下

  2. 后续有 添加文件/ 提交/ 推送 直接右击选择相应功能即可,相当方便,这里按照添加新文件为例进行示范:

    当我在PC机的相应仓库中添加了一个文件:4.txt

    直接在仓库中右击选择TortoiseGit -> 添加(s)

    然后在弹出的界面中,选择提交(C),然后再在弹出的界面中添加上日志信息

    最后进行推送到远端

    推送成功:

参考

https://blog.csdn.net/qq_34284638/article/details/70154557

https://www.cnblogs.com/lixiaochao/p/6293316.html

Git: 搭建一个本地私人仓库的更多相关文章

  1. git怎么创建本地版本仓库

    git怎么创建本地版本仓库 安装git我就不用说了吧!下载地址:https://github.com/msysgit/msysgit/releases/download/Git-1.9.4-previ ...

  2. 微服务架构 - 搭建docker本地镜像仓库并提供权限校验及UI界面

    搭建docker本地镜像仓库并提供权限校验及UI界面 docker本地镜像仓库的作用跟maven私服差不多,特别是公司级或者是小组级开发好的docker仓库可以上传到本地镜像仓库中,需要用时,直接从本 ...

  3. 使用nexus搭建一个maven私有仓库

    使用nexus搭建一个maven私有仓库 大家好,我是程序员田同学.今天带大家搭建一个maven私有仓库. 很多公司都是搭建自己的Maven私有仓库,今天就带大家使用nexus搭建一个自己的私有仓库, ...

  4. 快速搭建一个本地的FTP服务器

    快速搭建一个本地的FTP服务器   如果需要开发FTP文件上传下载功能,那么需要在本机上搭建一个本地FTP服务器,方便调试. 第一步:配置IIS Web服务器 1.1 控制面板中找到"程序& ...

  5. 快速搭建一个本地的FTP服务器 win10及win7

    快速搭建一个本地的FTP服务器   如果需要开发FTP文件上传下载功能,那么需要在本机上搭建一个本地FTP服务器,方便调试. (win10) 第一步:配置IIS Web服务器 1.1 控制面板中找到“ ...

  6. git操作+一个本地项目推到github上+注意

    git init 创建新文件夹,打开,然后执行以创建新的 git 仓库. git config --global user.name "xxx" git config --glob ...

  7. mark一篇文章--用nodejs搭建一个本地反向代理环境

    调试线上代码的时候,我们经常遇到的一个问题就是 本地一套环境,线上一套环境,本地没有的文件用线上的这种需求.我简单来说下使用nodejs如何做到. 先说下不用nodejs我们怎么做,工具比如fiddl ...

  8. 基于nodejs环境,用npm简单搭建一个本地服务器Live-server的使用

    用npm 或者cnpm进行全局安装 cnpm install -g live-server 运行后就可以直接给你虚拟一个本地服务器,而且还可以热同步 运行 live-server

  9. centos7系统下搭建docker本地镜像仓库

    ## 准备工作 用到的工具, Xshell5, Xftp5, docker.io/registry:latest镜像 关于docker的安装和设置加速, 请参考这篇博文centos7系统下 docke ...

随机推荐

  1. list类型数据的操作指令

    1. 结果是 3 2 1 还可以继续追加如下: 2. 3. 4.删除表头元素(最左侧的元素),并返回该元素 5. 6. 7.删除表尾的元素(最右侧的元素),并返回该元素 8.

  2. 大数据最后一公里——2021年五大开源数据可视化BI方案对比

    个人非常喜欢这种说法,最后一公里不是说目标全部达成,而是把整个路程从头到尾走了一遍. 大数据在经过前几年的野蛮生长以后,开始与数据中台的概念一同向着更实际的方向落地.有人问,数据可视化是不是等同于数据 ...

  3. Weblogic漏洞分析之JNDI注入-CVE-2020-14645

    Weblogic漏洞分析之JNDI注入-CVE-2020-14645 Oracle七月发布的安全更新中,包含了一个Weblogic的反序列化RCE漏洞,编号CVE-2020-14645,CVS评分9. ...

  4. 用python的pandas读取excel文件中的数据

    一.读取Excel文件   使用pandas的read_excel()方法,可通过文件路径直接读取.注意到,在一个excel文件中有多个sheet,因此,对excel文件的读取实际上是读取指定文件.并 ...

  5. 编译执行 VS 解释执行

    一般编译程序从对源程序执行途径的角度不同,可分为解释执行和编译执行. 所谓解释执行是借助于解释程序完成,即按源程序语句运行时的动态结构,直接逐句地边分析边翻译并执行.像自然语言翻译中的口译,随时进行翻 ...

  6. 一文看懂String类中的常用方法

    1.int length(): 返回字符串的长度: return value.length 2.char charAt(int index): 返回某索引处的字符return value[index] ...

  7. uni-app仿抖音APP短视频+直播+聊天实例|uniapp全屏滑动小视频+直播

    基于uniapp+uView-ui跨端H5+小程序+APP短视频|直播项目uni-ttLive. uni-ttLive一款全新基于uni-app技术开发的仿制抖音/快手短视频直播项目.支持全屏丝滑般上 ...

  8. HCNP Routing&Switching之路由过滤工具Filter-Policy

    前文我们了解了路由控制技术中路由策略和路由匹配工具IP-Prefix相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15314262.html:今天我们 ...

  9. html2canvas实现截取指定区域或iframe的区域

    官网文档: http://html2canvas.hertzen.com/ 使用的是 jquery 3.2.1   html2canvas 1.0.0-rc.7 截取根据id的指定区域: var ca ...

  10. CentOS下安装libmcrypt失败

    libmcrypt是什么?? 是加密算法扩展库---支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SA ...