IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Git服务器搭建简明教程 -> 正文阅读

[系统运维]Git服务器搭建简明教程

1前言

本文详解在Ubantu 16下搭建Git服务器,力求让读者知其所以然,仅需安装Git和ssh,而无需其他软件。

2服务器搭建

在真实服务器或虚拟机里操作均可。另外,如果用VMware Workstation 16 Player的话,默认不用配置虚拟机网卡,本地机就能Ping通。教程使用普通用户操作,如果是root用户,就不用加sudo了,命令将更加简洁。

2.1安装Git和SSH

已安装过的最好也再来一遍,以更新到最新,除非自己很清楚。

sudo apt-get install git
sudo apt-get install ssh
service ssh start

2.2新建用户

方便管理仓库,这里新建一个叫git的用户,名字可以任意,但推荐取名为git。建议以后Git的相关的东西,都放到这个用户目录下。

注意,中途输入的密码是给新建的git用户设置的密码,其他直接回车使用默认信息即可。

sudo adduser git

注意,以上只是创建了叫git的用户,后续的操作并没有切换到该用户进行。

2.3创建登录证书

创建路径.ssh,然后创建authorized_keys文件,这里路径和文件名不能任取,该文件用于存放各个git客户端的RSA公钥,只有在这个列表里的客户端才能连接git服务。公钥在下一步创建。

cd /home/git/
sudo mkdir .ssh
sudo touch .ssh/authorized_keys

2.4本地端创建密钥

注意,这一步在本地端进行。不同的本地用户有不同的KEY。

ssh-keygen -t rsa

这里在windows下进行,这个命令可以在CMD、PowerShell或Git bash里执行。这里选Git bash,任意空白处右键点击Git bash here,然后右键粘贴执行,中途全默认按回车即可。

?如上图就已经生成,在用户根目录的.ssh文件夹内,id_rsa.pub就是我们要的公钥:

2.5本地端公钥上传

这里只是方法之一,只要能把id_rsa.pub传到服务器就行。scp是ssh的文件复制命令。

scp id_rsa.pub git@103.66.218.190:/home/git/

注意,使用你自己的ip地址。

我们来到上边.ssh文件夹内右键点击Git bash here,右键粘贴执行,中途输入yes,然后输入刚才创建git账号的密码,成功后如图:

?2.6服务器添加用户公钥

?注意,在服务器端进行。使用cat指令将公钥追加到authorized_keys文件。

sudo sh -c "cat id_rsa.pub >> .ssh/authorized_keys"

注意,如果不是root用户,使用如下方式则会报权限错误:

sudo cat id_rsa.pub >> .ssh/authorized_keys

如果想确认是否成功,可以输入命令查看:

head -n 5 authorized_keys

命令的意思是查看authorized_keys文件前5行的内容。

2.7创建仓库存放路径并设置所属用户为git

路径可任意起名,这里叫gitrepo。

sudo mkdir gitrepo
sudo chown git:git gitrepo

2.8初始化仓库并设置所属用户为git

这里建了一个叫test的仓库。

cd /home/git/gitrepo
sudo git init --bare test.git
sudo chown -R git:git test.git

因为这里的test.git路径下有多个文件,所以加-R参数递归。

到此,git服务器就算搭建完成,URL地址如下:

git@103.66.218.190:/home/git/gitrepo/test.git

安全选项

公钥列表里的客户端都可以无需密码直接可以使用git用户登录shell,如:

ssh git@103.66.218.190

下面通过修改/etc/passwd实现限制:

sudo nano /etc/passwd

按pagedown翻到最下面:

?找到git用户,一般都在最后,按键盘方向键移动光标到最后,将

git:x:1001:1001:,,,:/home/git:/bin/bash

改成:

git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell

改完之后按照提示,分别按ctrl+X,y,回车,实现保存退出,这样就OK了。

3测试

以下简单测试Clone和Push,如果你之前用过git,那么得到上边的仓库地址后应该就非常熟悉了。

3.1 Clone

在本地电脑上新建一个文件夹A,右键打开Git bash here,试试克隆,会得到一个空的test文件夹。

git clone git@103.66.218.190:/home/gitrepo/test.git

注意,ip地址请改成自己的。?还有,这里并不需要输入上边创建git用户的密码,如果需要输入密码,说明公钥添加有误,请重新检查。

?3.2 Push

进入test文件夹内,右键新建文本文档,内容任意。

右键打开Git bash here,添加所有文件,然后提交。

git add -A
git commit

在弹出的文本中填入本次更改日志,测试用就随意写,然后保存关闭。

通过克隆来的远程仓库,默认有个别名叫origin,所以推送可以直接这样:

git push origin master

?3.3再次克隆

新建一个文件夹B,并进入,右键打开Git bash here克隆,和之前一样:

git clone git@103.66.218.190:/home/git/gitrepo/test.git

可以看到这个就是刚才提交的文本文档:

?4使用TortoiseGit的密码弹窗问题

TortoiseGit是一个图形界面的Git,不用打“繁琐”的命令了。

4.1 尝试Clone

建一个新建文件夹C,右键Git Clone,在URL中填入:

git@103.66.218.190:/home/git/gitrepo/test.git

?如果这时直接点击OK,那么会有输入远端git用户密码的提示框,因为远端已经有本地机的公钥了,这显然不符合常理。这一点TortoiseGit和Git bash不一样,需要另外加载私钥。

当然,这里要是输入了上边创建的git用户的密码,也能克隆,这个密码只有管理员知道,自己现在就是管理员,多个git客户端的情况下别人就不知道了,除非你把密码告诉世界上所有人咯。

4.2创建PPK私钥

?找到开始菜单TortoiseGit文件夹下的PuTTYgen打开:

?按图中步骤操作,中间会有弹窗提示,默认即可。加载2.4步骤创建密钥生成的私钥id_rsa,然后另存为putty_rsa.ppk。

?4.3 Clone

回到新建文件夹C下,右键Git Clone,Load Putty Key 中加载刚才生成的putty_rsa.ppk

?可以看到,已经能正常Clone了。

END

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-04-27 11:41:37  更:2022-04-27 11:41:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 20:26:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码