Linux下安装git插件
1. 下载git网址:
2. 放入usr/src/下 3. tar -zxvf git-*** 4. cd git--- 5. //yum groupinstall 'Development Tools' -y yum -y install openssl-devel curl-devel expat-devel gettext-devel zlib-devel gcc perl-ExtUtils-MakeMaker 6. make prefix=/usr/local/git all make prefix=/usr/local/git install echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/bashrc source /etc/bashrc git --version
***服务器端设置git用户
useradd gitpasswd git***创建git仓库
mkdir -p data/git/swportal.gitgit init --bare data/git/swportal.gitcd data/git/chown -R git:git swportal.git/***禁用shell登录:
vi /etc/passwd:将git:x:1001:1001:,,,:/home/git:/bin/bash 改成git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell***服务器git打开RSA认证
vi /etc/ssh/sshd_config,打开以下三个配置的注释:RSAAuthentication yesPubkeyAuthentication yesAuthorizedKeysFile .ssh/authorized_keys保存并重启 sshd 服务:/etc/rc.d/init.d/sshd restartserver存放公钥的路径是 /home/git/.ssh/authorized_keyscd /home/gitmkdir .sshchown -R git:git .ssh回到 Git Bash 下,导入文件: ssh root@109.110.100.56 'cat >>/home/git/.ssh/authorized_keys' < ~/.ssh/id_rsa.pub回到服务器端查看.ssh下是否存在authorized_keys 文件:***添加远程git仓库链接并push本地库内容给远程库
git remote add origin2 root@109.110.100.56:/usr/src/git-2.1.2/data/git/swportal.gitgit push -u origin master***git远程命令
1. git remote2. git clone3. git fetch4. git pull5. git push
1. git remote: 列出所有远程主机
git remote -v //可以参看远程主机的网址 git clone -o jQuery https://github.com/jquery/jquery.git //-o指定远程主机的名字, 否则默认origin git remote show <主机名> //查看该主机的详细信息 git remote add <主机名> <网址> //用于添加远程主机 git remote rm <主机名> //用于删除远程主机 git remote rename <原主机名> <新主机名> //用于远程主机的改名2. git clone: 从远程主机克隆一个版本库
格式:git clone <版本库的网址> git clone https://github.com/jquery/jquery.git git clone root@109.110.100.56:/usr/src/git-2.1.2/data/git/swportal.git git clone <版本库的网址> <本地目录名> //该命令会在本地主机生成一个目录,与远程主机的版本库同名。如果要指定不同的目录名,可以将目录名作为git clone命令的第二个参数3. git fetch // 一旦远程主机的版本库有了更新(Git术语叫做commit),需要将这些更新取回本地
格式:git fetch <远程主机名> <分支名>git fetch <远程主机名> //取回所有分支(branch)的更新
git fetch <远程主机名> <分支名> //如果只想取回特定分支的更新,可以指定分支名 git fetch origin master //取回origin主机的master分支,在本地主机上要用"远程主机名/分支名"的形式读取。比如origin主机的master,就要用origin/master读取 读取查看远程分支: git branch -r 查看所有分支: git branch -a 结果:* master //本地主机的当前分支是master remotes/origin/master //远程分支是origin/master 取回远程主机的更新以后,可以在它的基础上,使用git checkout命令创建一个新的分支 git checkout -b newBrach origin/master //创建一个新的分支 git merge origin/master //在当前分支合并远程的分支4. git pull: 取回远程主机某个分支的更新,再与本地的指定分支合并
格式:git pull <远程主机名> <远程分支名>:<本地分支名> git pull origin next:master //取回origin主机的next分支,与本地的master分支合并 等同于 git fetch origin git merge origin/next // git pull origin next 如果远程分支是与当前分支合并,则冒号后面的部分可以省略git branch --set-upstream master origin/next // 手动建立追踪关系
git pull origin //就可以省略远程分支名如果远程主机删除了某个分支,默认情况下,git pull 不会在拉取远程分支的时候,删除对应的本地分支
git pull -p //可以在本地删除远程已经删除的分支5. git push:将本地分支的更新,推送到远程主机
格式:git push <远程主机名> <本地分支名>:<远程分支名> //切记, 如果不输入本地分致命, 就表示删除远程分支 ,因为等同于推送一个空的本地分支到远程分支 git push origin master // 将本地的master分支推送到origin主机的master分支 git push -u origin master // 如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push