Git01-安装配置git

Git官网:https://git-scm.com/

源码安装git

安装依赖
yum install -y curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker asciidoc xmlto

下载git
https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.27.0.tar.gz

移除已有git
yum remove git
rm -rf /usr/bin/git

解压安装
cd /usr/local/
tar zxf git-2.27.0.tgz
cd git-2.27.0
make prefix=/usr/local/git all
make prefix=/usr/local/git install

设置软连接
ln -s /usr/local/git/bin/git /usr/bin/git

添加环境变量
echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/bashrc
source /etc/bashrc

检查版本号
git --version

git-server配置

useradd git
passwd git
mkdir /root/mygit
cd /root/mygit

初始化工作目录,默认当前目录
git init
git init newrepo   指定目录

git init 和git init --bare的区别
后者不再生成.git目录,而是只生成.git目录下面的版本历史记录文件,这些版本历史记录文件放在版本库的根目录下
后者创建一个裸仓库,不能在仓库中使用git命令,所以远程仓库最好初始化成bare仓库

chown -R git:git newrepo
su - git
ssh-keygen -t rsa
cp id_rsa.pub authorized_keys  # 记录到这里,简写不是覆盖

git-client配置

yum install git git-all git-core

免密登陆git-server端
git clone git@server:/仓库绝对路径
会在当前目录生成一个仓库名的目录

指定这是谁的工作目录,不设置不能提交
git config --global user.name "tom"
git config --global user.email "tom@123.com"

列出配置信息
git config --list

git-client操作

创建一个文件后,添加到暂存区
git add hello.html

撤销添加到暂存区
git rm --cached hello.html

提交至本地版本库,每次提交会在本地版本库内生成40位的commit-id
git commit helllo.html -m '提交的理由'

提交到远程分支
git push <远程主机名> <本地分支名>:<远程分支名>

git push origin master                          省略远程分支,表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
git push origin                  如果当前分支与远程分支存在追踪关系(或者说同名),都可以省略
git push origin:master           省略本地分支,表示删除远程对应分支,但是本地还有
git push                         如果当前分支只有一个远程分支,那么主机名都可以省略
git push origin test:master      提交本地test分支 作为远程的master分支
git push origin test:test        提交本地test分支作为远程的test分支
git push origin master

这几个常见的用法已足以满足我们日常开发的使用了,还有几个扩展的用法,如下:
(1) git push -u origin master 如果当前分支与多个主机存在追踪关系,则可以使用 -u 参数指定一个默认主机,这样后面就可以不加任何参数使用git push,
不带任何参数的git push,默认只推送当前分支,这叫做simple方式,还有一种matching方式,会推送所有有对应的远程分支的本地分支, Git 2.0之前默认使用matching,现在改为simple方式
如果想更改设置,可以使用git config命令。git config --global push.default matching OR git config --global push.default simple;可以使用git config -l 查看配置
(2) git push --all origin 当遇到这种情况就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要 -all 选项
(3) git push --force origin git push的时候需要本地先git pull更新到跟服务器版本一致,如果本地版本库比远程服务器上的低,那么一般会提示你git pull更新,如果一定要提交,那么可以使用这个命令。
(4) git push origin --tags //git push 的时候不会推送分支,如果一定要推送标签的话那么可以使用这个命令

git status 
查看提交日志
git log

全局配置

配置文件
/etc/gitconfig      所有用户生效   git config --system
~/.gitconfig        该用户生效      git config --global
.git/config         该项目生效
每个级别的配置会覆盖上一级的配置

修改分析差异工具
git config --global merge.tool vimdiff

查看配置文件,可能有重复配置,只有一个生效
git config --list
posted @   立勋  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示