博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux GIT服务器配置
阅读量:6444 次
发布时间:2019-06-23

本文共 3098 字,大约阅读时间需要 10 分钟。

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 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

 

转载于:https://www.cnblogs.com/wujixing/p/6201872.html

你可能感兴趣的文章
.NET Web后台动态加载Css、JS 文件,换肤方案
查看>>
使用开源软件vlc media player 录制桌面视频
查看>>
web前端(2)—— 前端技术介绍
查看>>
ife2018 零基础学院 day 3
查看>>
Kali Linux信息收集之nbtscan-unixwiz
查看>>
hdu 5476 (计算几何)
查看>>
51 nod 1610 路径计数(Moblus+dp)
查看>>
通用报文解析服务的演进之路(基于磁盘目录的分布式消息消费者服务)之三...
查看>>
Js中分号使用总结
查看>>
读《从一到无穷大》
查看>>
zend studio 8 注册 码
查看>>
CentOS LAMP环境 配置详解
查看>>
任正非:华为为什么要坚持工业科学管理
查看>>
实现法线贴图3D模型渲染的脚本代码(附源码)
查看>>
iPhone开发面试题--葵花宝典
查看>>
05-Git
查看>>
Spring quartz 单机、集群+websocket集群实现文本、图片、声音、文件下载及推送、接收及显示...
查看>>
SPOJ104 Highways,跨越数
查看>>
使用rman备份异机恢复数据库
查看>>
Win7-64bit系统下安装mysql的ODBC驱动
查看>>