草庐IT

Git服务器搭建简明教程

新塘老笨 2023-07-07 原文

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

有关Git服务器搭建简明教程的更多相关文章

  1. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  4. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  5. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

  6. ruby-on-rails - 在 Rails 中调试生产服务器 - 2

    您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除

  7. postman接口测试工具-基础使用教程 - 2

    1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,

  8. 在VMware16虚拟机安装Ubuntu详细教程 - 2

    在VMware16.2.4安装Ubuntu一、安装VMware1.打开VMwareWorkstationPro官网,点击即可进入。2.进入后向下滑动找到Workstation16ProforWindows,点击立即下载。3.下载完成,文件大小615MB,如下图:4.鼠标右击,以管理员身份运行。5.点击下一步6.勾选条款,点击下一步7.先勾选,再点击下一步8.去掉勾选,点击下一步9.点击下一步10.点击安装11.点击许可证12.在百度上搜索VM16许可证,复制填入,然后点击输入即可,亲测有效。13.点击完成14.重启系统,点击是15.双击VMwareWorkstationPro图标,进入虚拟机主

  9. git使用常见问题(提交代码,合并冲突) - 2

    文章目录git常用命令(简介,详细参数往下看)Git提交代码步骤gitpullgitstatusgitaddgitcommitgitpushgit代码冲突合并问题方法一:放弃本地代码方法二:合并代码常用命令以及详细参数gitadd将文件添加到仓库:gitdiff比较文件异同gitlog查看历史记录gitreset代码回滚版本库相关操作远程仓库相关操作分支相关操作创建分支查看分支:gitbranch合并分支:gitmerge删除分支:gitbranch-ddev查看分支合并图:gitlog–graph–pretty=oneline–abbrev-commit撤消某次提交git用户名密码相关配置g

  10. hadoop安装之保姆级教程(二)之YARN的配置 - 2

    1.1.1 YARN的介绍 为克服Hadoop1.0中HDFS和MapReduce存在的各种问题⽽提出的,针对Hadoop1.0中的MapReduce在扩展性和多框架⽀持⽅⾯的不⾜,提出了全新的资源管理框架YARN. ApacheYARN(YetanotherResourceNegotiator的缩写)是Hadoop集群的资源管理系统,负责为计算程序提供服务器计算资源,相当于⼀个分布式的操作系统平台,⽽MapReduce等计算程序则相当于运⾏于操作系统之上的应⽤程序。 YARN被引⼊Hadoop2,最初是为了改善MapReduce的实现,但是因为具有⾜够的通⽤性,同样可以⽀持其他的分布式计算模

随机推荐