zoukankan      html  css  js  c++  java
  • Linux GIT服务器配置

    Linux下安装git插件

    1. 下载git网址:
        https://github.com/git/git/releases
    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

  • 相关阅读:
    PHP使用http_build_query()构造URL字符串的方法
    php将一个二维数组按照某个字段值合并成一维数组,如果有重复则将重复的合并成二维数组
    资金管理
    偏爱粉色,我的儿子会不会娘娘腔?
    中文期刊有哪些?
    超声胎儿图像分割
    加州wonders教材扫盲
    美国小学1-5年级教学大纲
    A股回归牛市?
    深入研究股票涨停
  • 原文地址:https://www.cnblogs.com/wujixing/p/6201872.html
Copyright © 2011-2022 走看看