Linux GIT服务器配置

发布时间:2016-12-31 7:43:21编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"Linux GIT服务器配置 ",主要涉及到Linux GIT服务器配置 方面的内容,对于Linux GIT服务器配置 感兴趣的同学可以参考一下。

***服务器端设置git用户
useradd git
passwd git

***创建git仓库
mkdir -p data/git/swportal.git
git init --bare data/git/swportal.git
cd 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 yes
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys
保存并重启 sshd 服务:
/etc/rc.d/init.d/sshd restart
server存放公钥的路径是 /home/git/.ssh/authorized_keys
cd /home/git
mkdir .ssh
chown -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.git
git push -u origin master

***git远程命令
1. git remote
2. git clone
3. git fetch
4. git pull
5. 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


上一篇:阿里云产品介绍(一):云服务器ECS
下一篇:Java多线程有哪几种实现方式? Java中的类如何保证线程安全? 请说明ThreadLocal的用法和适用场景

相关文章

相关评论

本站评论功能暂时取消,后续此功能例行通知。

一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!

二、互相尊重,对自己的言论和行为负责。

好贷网好贷款