远程提交一个大一点的文件
用git远程提交的一个好处就是,相比较在github或者gitee直接提交文件显得更加活泛。然后的话在提交文件大小的限制上。用git提交的话,可以提交大一点的文件。而你如果直接拖动文件到库里面的话,会有文件大小的限制。如果对一个包进行拆分的话,会比较麻烦。
用git提交大的文件。(或者说是远程提交)
一种提交方式。其实命令还是比较多的。提交方式比较多,但是我感觉这样还是比较简单的。
git工具的人下载不必说了。我只是想记住一下这个远程操作。有些远程提交的话,如果你设置的话,还需要验证邮箱。
目前自己的这种提交方式,感觉这样的几句提交命令还是十分的简单。 如下,我想把这样的一个rar包提交到github。我在github上创建了一个仓库。
data:image/s3,"s3://crabby-images/a5525/a55254535357a3ceb1eeb79cd5d26832168fc9f0" alt="image.png"
data:image/s3,"s3://crabby-images/8776e/8776e3463ad80d183eb3ad844a31f090a52ea7d9" alt="image.png"
如果你要用常规的方式提交的话,当然对于一个学编程的人说,这种提交方式显得不太专业。 这样提交。 data:image/s3,"s3://crabby-images/6896a/6896a12cfa4023728c3046b962b3ca79c037880d" alt="image.png" 点击Upload这边,然后在这里你可以直接将文件拖到这里。
data:image/s3,"s3://crabby-images/09e64/09e649544bce700d808c00d3e69c700ec84fc679" alt="image.png"
data:image/s3,"s3://crabby-images/970de/970de7e002a047b3e9f9d2f23dd100f4c12677a6" alt="image.png" 我托了,但是这里说这个文件太大了。要求必须比25mb小。我的文件的大小 data:image/s3,"s3://crabby-images/ea989/ea98993b438e6478b6a6f3b57b774e6e783b61ac" alt="image.png" 还记得存储容量吗?这个是说存储容量上面的。 1kB=1024B,1MB=1024KB,1GB=1024MB,1TB=1024GB。 25*1024 = 25600 也就是25MB = 25600kB。但是我的rar文件大小是65820KB。比这个还要大好多。所以传不上去。那么如何传上去呢?采用远程提交(git)。
第一步最好在自己的要上传文件的当前目录。不然你还得cd。
data:image/s3,"s3://crabby-images/3dcc3/3dcc3ab5fe0f0ea84572e664246d4cc8cc79fc29" alt="image.png" 打开bash。这里也会显示出你的当前路径。 data:image/s3,"s3://crabby-images/a0d31/a0d311f3078e55db8dea0733332503aff43eac37" alt="image.png"
git init
data:image/s3,"s3://crabby-images/4f8e5/4f8e5213a767057a9de5d72c84225db62dfe5dd1" alt="image.png" 初始化仓库,然后你会发现在你的当前文件路径下面会出现这样一个文件夹。 data:image/s3,"s3://crabby-images/5efa8/5efa8b59434fceb88f4f8ab44cb38a3e4f800c06" alt="image.png" 然后安装这个工具。这个是用来操作大文件上传的Large File Storage
git lfs install
data:image/s3,"s3://crabby-images/3e9e6/3e9e6e5d336f669b1028b784f159d3bc76a27674" alt="image.png" 安装好后,然后你可以进行先跟踪一下你要上传的文件
git lfs track "navicatforever.rar"
data:image/s3,"s3://crabby-images/bae41/bae41463f9c9f401f7b104de2d94e909a8890b85" alt="image.png"
这边我们可以去添加要上传的文件(和参考博文有区别,我是这样做的,成功了。)
git add navicatforever.rar
data:image/s3,"s3://crabby-images/4e4df/4e4df626250dd30fee42e22f10cace0b1a5947d3" alt="image.png"
然后提交(注意这个只是提交到本地)我们需要先这样做。forever是我写的注释。这个可以随便来。
git commit -m "forever"
data:image/s3,"s3://crabby-images/1bbb8/1bbb8ff225a15712b3abb9ad7c77ec9d07bce2c6" alt="image.png"
然后关联远端仓库。需要找到你创建仓库的地址。如果你刚刚创建的话,会马上看见。如果不是的话,可以在这里看一下,复制一下这个地址。
data:image/s3,"s3://crabby-images/2785f/2785fc62ec30ef29010babc8665aa4d8439d7101" alt="image.png" 进行关联
git remote add origin https://github.com/jgdabc/navicat.git
data:image/s3,"s3://crabby-images/2ff58/2ff584d5c577961072cf560f6f823c5e0e1b8313" alt="image.png" 另外如果你之前设置过ssh秘钥的话,就不用操作了。如果没有还需要操作一波。
ssh-keygen -t rsa
然后输入这个命令后,下面的确认回车就完事。然后你需要找到这个秘钥。可以看提示。在c盘用户下面的那个路径。 data:image/s3,"s3://crabby-images/1433f/1433fedf78c76f03ec42b81860263cb7170745af" alt="image.png" 打开第二个文件,然后复制一下那段字符。上面的文件不用管。 data:image/s3,"s3://crabby-images/9412c/9412ca8821d38d294051305fbfb35d8bfe5067f0" alt="image.png" 然后打开github
data:image/s3,"s3://crabby-images/4afec/4afeca5df2907bda8f146d19c03aa8860bfd7ecb" alt="image.png" 点下面的ssh那边 data:image/s3,"s3://crabby-images/715fb/715fb874abd3205f3809127a53211b462689d78a" alt="image.png" 点击那个new
data:image/s3,"s3://crabby-images/1e0af/1e0af1d3d4e410d38bb8da78005e766c06f3a094" alt="image.png" 然后将你复制的字符串粘贴到key下面。上面的title自己随便起个名字就好了。 data:image/s3,"s3://crabby-images/8da14/8da14e526dacf5a26c80f1d6a12e888f737c53b2" alt="image.png"
这样做好后,就可以远程提交了。
git push origin master
data:image/s3,"s3://crabby-images/bad72/bad723e552bb6ae5b650dc159e899a574027da1b" alt="image.png" 就ok了。
解决提交冲突(拉取本地合并提交)
查看github。需要注意的是,据说如果源库有分支的话,还需要进行合并分支的操作,不然可能会出错。 第一次创建仓库的话,如果想要远程简单提交一次文件的话,就最好创建一个空的库。这样提交的话,操作会比较简单。
如果是多人开发的话,最好先将远程分支拉取下来,然后进行提交。 data:image/s3,"s3://crabby-images/9007a/9007a37e3670a0887677df5baac26e5f2c7211ce" alt="image.png"
首先可以自己查看自己目前本地以及远程仓库的分支
git branch --查看本地分支
git branch -r -- 查看远程分支
data:image/s3,"s3://crabby-images/647ed/647ed65673ff20af861b145dc70b71d0e0265676" alt="image.png" 本地的和远程的显示的这个分支都是显示在基于固定的远程关联的远程仓库的地址上进行显示的。
比如我关联的是我的practice的一个仓库,那么显示的分支会在这个基础上显示。远程的分支我显示在这个仓库上的分支。
data:image/s3,"s3://crabby-images/ee259/ee259ee7b6bfe0c59cb4519963452104f98379a4" alt="image.png"
这样的两个分支里面的文件是一样的。因为我在原有仓库(本来只有一个master)的基础上,又在本地创建了一个分支并提交了上去,没有更改的话,那么它的内容会和master一样。当前你可以进行更改,在一个分支上更改,不会影响另一个分支。
如何给你的远程仓库创建一个分支呢?当前也可以直接在远程仓库手动创建。现在我们要用git工具进行操作。
如下,可以现在本地创建一个,然后给他推到远程仓库就完事。
git checkout -b dev
git push origin dev
我们说完这些,就是要说说如何进行一个分支合并以及分支冲突的处理。存在的问题是如果你的远程仓库的当前分支下存在文件的话,如果你直接提交的话,会提交不成功。 来测试一下,现在我的dev仓库里面存在文件。现在我要用git往这个仓库里面提交内容。 data:image/s3,"s3://crabby-images/d998f/d998fca655fcdd345a9babfe216d4959c7324edc" alt="image.png" 现在重写开一个bash。 data:image/s3,"s3://crabby-images/2f760/2f760d1c9aa18cbeeecff6d65a62636f8d4352e2" alt="image.png" 按照常规的步骤
git init
data:image/s3,"s3://crabby-images/db5a0/db5a0cdc95be85d69a814924159964f3da73454a" alt="image.png" 跟踪上传文件
git lfs track "PDF.rar"
data:image/s3,"s3://crabby-images/6fa36/6fa36849e21a4ffd78ff019681d101e8e34bf694" alt="image.png" 添加要上传的文件
git add "PDF.rar"
先提交本地
git commit -m "nsaksnam"
data:image/s3,"s3://crabby-images/870bf/870bfe92dfa8b11c1bfbcc81ddf6e88d412abd17" alt="image.png" 远程关联
git remote add origin https://github.com/jgdabc/pratice.git
data:image/s3,"s3://crabby-images/0df78/0df78a892b217d632a2e2229e866b3480c7ab369" alt="image.png" 进行提交
git push origin dev
但是这样会出现问题 data:image/s3,"s3://crabby-images/4907f/4907f3378534d7a132c5d4fe1c70834168277842" alt="image.png" 其实是不允许进行覆盖
一个暴力的办法就是暴力覆盖
git push -f origin dev
data:image/s3,"s3://crabby-images/05a81/05a81d88c2da243fbbe91b442b52bdfc8743c31e" alt="image.png" 所以这下我的dev分支就被覆盖掉了。 data:image/s3,"s3://crabby-images/e0971/e09711f54615b91f7bd65c33091652b8abd05666" alt="image.png" 如果我不想覆盖原有的文件怎么办? 这是现在我的dev分支下面的文件
data:image/s3,"s3://crabby-images/b090b/b090bc86d11ad19a536ca5c2ce721ca6a23c4eea" alt="image.png" 我现在要提交另外一些文件,但是我不想覆盖掉原有的文件 我要提交一个java文件
data:image/s3,"s3://crabby-images/4c4f3/4c4f3ae26a080e82fe2d14c481fa7fac11cc9e0c" alt="image.png"
git init -- 初始化一个仓库
git remote add origin https://github.com/jgdabc/pratice.git -- 关联远程仓库
git checkout -b dev -- 创建一个dev分支,然后转到dev分支
git pull origin dev -- 从远程分支拉取代码,进行同步
data:image/s3,"s3://crabby-images/0e2c1/0e2c14b46d84a907893f1f8a06a506655dd75efc" alt="image.png" 同步成功 data:image/s3,"s3://crabby-images/dc761/dc761457a555f47f16cd5e2f7251255e1ac0921d" alt="image.png" 添加一个新的文件
git commit -m "pratice"
给远程提交
git push -u origin dev
data:image/s3,"s3://crabby-images/f969e/f969e59328b24e6c27c57649fd874d72e791c1fc" alt="image.png"
实现目的。这样做,源文件不会被覆盖。
data:image/s3,"s3://crabby-images/fe5de/fe5deef50451edfd04c3d85176c37ae932917313" alt="image.png" 是一个版本控制非常方便的工具。多用用,就明白了。
分支合并
如果希望分支进行合并的话,也是可以的。 现在我的远程仓库下面有两个分支,现在有两个分支。并且有一个重复得文件,现在要进行分支合并。 data:image/s3,"s3://crabby-images/95c9d/95c9d45143fe76fcd7990ad8a71a1925463b576a" alt="image.png"
data:image/s3,"s3://crabby-images/ccf8c/ccf8ce13d039ff8d1d6ee40203be6395abae098a" alt="image.png" 我现在要合并到主分支。那么我就需要先切换到主分支。 如果你关闭刚刚重新打开一个bash的话,会默认在master的。
data:image/s3,"s3://crabby-images/cdf93/cdf939cea99a6b8e715507ee9230968aee12b619" alt="image.png" 那就合并
$ git merge dev
但是这里我报了一个错
data:image/s3,"s3://crabby-images/87f1d/87f1d1aa8d53f19a9506c9169229ee91fdfdcbce" alt="image.png" 简单翻译就是拒绝合并并不相关的历史。意思就是本地和远程的两个库的两个分支是不一样的版本。 但是我们不管这些,强制合并就完事。
git merge dev --allow-unrelated-histories
data:image/s3,"s3://crabby-images/981c0/981c0bb11b07e38e6d5e0608079b9ffe222cd56e" alt="image.png" 合并完就push
$ git push origin master
data:image/s3,"s3://crabby-images/5e833/5e83359c3cb5b3423eea16d430cca5bdbc09cdbf" alt="image.png" 100%完事,然后再哪个分支上操作,切换就行了。 去远程库看看 data:image/s3,"s3://crabby-images/7960b/7960b5d833a65e0e4ee386d6ca4670f4ea55c6cf" alt="image.png" 可以看到提交成功。没有重复的文件。
保险的建议就是=如果有文件的话,最好先pull下来,然后合并自己的。然后再提交。
idea配置操作git和github
打开idea,在这边搜索去找 data:image/s3,"s3://crabby-images/59586/59586cc29233553b9066587c47764574406c7aca" alt="在这里插入图片描述" 将idea右边配置好就可以。不同idea版本这边的面板是不一样的,基本的功能配置还是一样的。
配置一下github,我选的第一个选项,授权登录。 data:image/s3,"s3://crabby-images/f23d4/f23d42a94ef0eaec8f90b2601a56a886e13a1f12" alt="在这里插入图片描述" 进入网站你授权点击就好,然后这边会要求你填入密码。 data:image/s3,"s3://crabby-images/87156/87156e753f7de84ebc2495cec27a5900a33f914b" alt="在这里插入图片描述" 登录 data:image/s3,"s3://crabby-images/61406/6140625ea892eb11a46531c164810bc2975a1df3" alt="在这里插入图片描述" 这个idea会检测安全,我之前破解过,今天等不上去了,所以又去吧那个host文件修改了一波。离谱的是这个idea刚刚还弹出提示,说我使用了fastgithub。这也可以检车出来,你是真nb啊! data:image/s3,"s3://crabby-images/2bc86/2bc861f53c053c5f6fb7a83751d4de802ca1db94" alt="在这里插入图片描述" 顺便把终端安排一下,改为bash data:image/s3,"s3://crabby-images/2584b/2584bb720103b8185f6cd2388ae5955900157570" alt="在这里插入图片描述"
然后在idea里面来看一下 data:image/s3,"s3://crabby-images/801c8/801c8b3abe808fe203385d1ea26a1a769b103676" alt="在这里插入图片描述" 初始化仓库后,项目会变红。 data:image/s3,"s3://crabby-images/e82ec/e82ec7d09e792a0b16be8b931e206636205cb532" alt="在这里插入图片描述" 配置好后这边也会出现git相关的按钮 data:image/s3,"s3://crabby-images/31272/3127271ebc7d986bc57cf9668bbfdd6075859b62" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/49afa/49afa4bb5e499d868f3d757f5d4f175bdae3ba55" alt="在这里插入图片描述" 建库 data:image/s3,"s3://crabby-images/e65b5/e65b56bc16bc5d3c9dfa7345265cecdde2b86b79" alt="在这里插入图片描述" 推送 data:image/s3,"s3://crabby-images/24d68/24d68e18de6beadfc772cef1c8d9a44189fbbb7d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/49491/494919d4be8aec08955e3d4a004b71f3c88f1cf0" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ba6d9/ba6d997a9c57470d454b796a0708b6665779e44c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/2d1e9/2d1e93d6b011b6c984014c654404ad1e7bb164aa" alt="在这里插入图片描述" 可以说非常方便。 自己比较习惯使用命令的话,也可以在terminal下面像之前一样进行操作。
|