Git服务器使用:
1:安装git:
sudo apt-get install git
2. 产生公钥:命令执行过程中密码啥的默认就行,最后id_rsa.pub公钥文件产生在~/.ssh/id_rsa.pub中。
ssh-keygen -t rsa
3. 把id_rsa.pub中新产生的公钥内容复制到git服务器上/home/git/.ssh/authorized_keys里。
4. 回到本地git仓库,开始克隆:
git clone [email protected]:/mnt/code/server_code/ftPOS_android.git
git push origin master
Git服务器安装:
环境说明:
本地:ubuntu 14.04/Win7 IP:192.168.29.71
服务器:Ubuntu 14.04 IP:192.168.29.122
服务器上:
#安装git,如果有权限问题,记得再以下命令前面加上 sudo
apt-get install git
#新增用户(用户名为git),用于运行git服务
sudo useradd -m git
sudo passwd git
#初始化git仓库,这里我放到/mnt/code/server_code目录下面(专门存放代码用)
cd /mnt/code/server_code
git init --bare ftPOS_android.git #注意:加上--bare参数后,服务端是初始化的[裸仓库]一般服务器上的Git仓库都是以.git结尾的裸仓库
裸仓库没有工作区,因为服务器上的git仓库是为了共享用,不能让用户直接登录到服务器上去修改工作区中的代码,用裸仓库更加安全
修改仓库权限,否则后面提交不上代码:
chown -R git:git server_code
注:git 仓库所在目录均为git用户权限。R为递进,全部文件,一定要
cd /home/git/
mkdir .ssh
#将本地用户的公钥添加到认证文件中
cat id_rsa.pub >> .ssh/authorized_keys (按道理可以先创建空authorized_keys 后面非服务器的公钥)
#修改所有者为git用户
chown -R git:git /home/git
#修改以下目录权限
# 1. 用户home目录755权限
# 2. .ssh目录700权限
# 3. authorized_keys 600权限
chmod 755 /home/git
chmod 700 .ssh
chmod 600 .ssh/authorized_keys
#修改ssh配置文件/etc/ssh/sshd_config,取消这行 AuthorizedKeysFile %h/.ssh/authorized_keys 前面的注释
#重启ssh
Sudo service ssh restart
2. 在本地(IP:192.168.29.71)操作:
(1). 产生公钥:命令执行过程中密码啥的默认就行,最后id_rsa.pub公钥文件产生在~/.ssh/id_rsa.pub中。
ssh-keygen -t rsa
全部复制像我的:
3. 回到本地git仓库,开始克隆:
git clone [email protected]:/mnt/code/server_code/ftPOS_android.git
git add . 或者git add --all #会将所有改动、新增或者删除的文件进行add
git commit -am “***” #a可把子目录下的也commit
git push origin master
注意:所放工程目录下不要有.git .gitignore文件,可能源码里面文件push不上去。
以上绝大部分参考如下,备份http://blog.csdn.net/ice520301/article/details/6142503,不是下面的网址:
环境说明:
本地:Win7 IP:192.168.111.1
服务器:Ubuntu 14.04 IP:192.168.111.222
服务器上:
#安装git,如果有权限问题,记得再以下命令前面加上 sudo
apt-get install git
#新增用户(用户名为git),用于运行git服务,回车后会提示输入密码
adduser git
#初始化git仓库,这里我放到/home/git/code目录下面(专门存放代码用)
mkdir /home/git/code
cd /home/git/code
git init --bare test.git #注意:加上--bare参数后,服务端是初始化的[裸仓库]一般服务器上的Git仓库都是以.git结尾的裸仓库
裸仓库没有工作区,因为服务器上的git仓库是为了共享用,不能让用户直接登录到服务器上去修改工作区中的代码,用裸仓库更加安全
现在 服务器 上面的git仓库已经初始化完成,那接下来配置哪些用户可以登录到git服务器,进行git相关操作。
code目录结构:
本地:
#以下创建证书登录
#本地生成公钥,位于~/.ssh/id_rsa.pub
ssh-keygen -t rsa ls ~/.ssh/
将用户的公钥(即id_rsa.pub)添加到 服务器上/home/git/.ssh/authorized_keys 文件中,
我这里用scp把本地的公钥(id_rsa.pub)上传到服务器上,然后用命令追加到authorized_keys中
#scp命令 将文件复制到远程服务器上,回车后输入git用户的密码
scp ~/.ssh/id_rsa.pub [email protected]:/home/git/
#如果ssh端口不是默认的22,则使用以下命令代替上面那条命令(22222为ssh端口号)
scp -P 22222 ~/.ssh/id_rsa.pub [email protected]:/home/git/
#然后服务器的/home/git/目录下面就多了我们刚才上传的id_rsa.pub
继续回到服务器上:
cd /home/git/
mkdir .ssh
#将本地用户的公钥添加到认证文件中
cat id_rsa.pub >> .ssh/authorized_keys
#修改所有者为git用户
chown -R git:git /home/git
#修改以下目录权限
# 1. 用户home目录755权限
# 2. .ssh目录700权限
# 3. authorized_keys 600权限
chmod 755 /home/git
chmod 700 .ssh
chmod 600 .ssh/authorized_keys
#修改ssh配置文件/etc/ssh/sshd_config,取消这行 AuthorizedKeysFile %h/.ssh/authorized_keys 前面的注释
#重启ssh
Sudo service ssh restart
#为了安全 禁止git用户shell登录,需要修改/etc/passwd
#将 git:x:1001:1001:,,,:/home/git:/bin/bash
#改为 git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
最后回到本地,见证奇迹:
#在本地clone刚才创建的test.git
git clone [email protected]:/home/git/code/test.git
#或者使用相对路径
git clone [email protected]:code/test.git
#如果ssh端口不是默认的22(如22222),则用下面这条命令
git clone ssh://[email protected]:22222/home/git/code/test.git
如果出现这种提示,就是搭建成功了!!!
接下来就可以自由发挥了!!!
本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2017-01/139457.htm
本篇文章来源于 Linux公社网站(www.linuxidc.com) 原文链接:http://www.linuxidc.com/Linux/2017-01/139457.htm
git clone [email protected]:/home/git/code/test.git