仓库Git环境搭建(2)---搭建CS架构的服务器

cs服务器  时间:2021-01-30  阅读:()

北大青鸟中关村

Git环境搭建(2)---搭建C/S架构的服务器

Git支持本地local、 ssh、 git和http s这四种协议进行传输本部分将基于ssh协议搭建(此协议不利于开源适合公司团队使用)。本文操作大部分在Ubuntu服务器端完成。

1、我们在服务器端新增加一个用户本文为gitadmin用于管理git仓库

Ubuntu下启动终端键入命令

$sudouseradd-mgitadmin --首次执行sudo命令需要按提示输入管理员密码

$sudopasswdgitadmin --设置用户gitadmin密码

将gitadmin设置为管理员用户方法很多这里用通过修改sudoers文件实现

$sudo vim/etc/sudoers

接下来进到vim编辑器键入i进入插入模式找到下面这行并添加gitadmin

#User privi legespecificationrootALL=(ALL:ALL) ALLgitadmin ALL=(ALL:ALL) ALL

键盘esc退出插入模式输入冒号 光标出现在底端输入wq回车退出。

$ sugitadmin --输入刚刚设置的密码切换到gitadmin用户

北大青鸟中关村

2、安装配置ssh服务

$sudo apt-get instal l openssh-server openssh-cl ient

按提示输入管理员密码 同意[Y],安装完毕。 OpenSSH为自由软件是ssh的开源实现。

$sudo vim/etc/ssh/sshd_config

找到下面几行去掉前面"#"注释并设置

StrictModes no--在用户名和其公钥文件名不匹配时将通过验证RSAAuthentication yes --使用纯的RSA认证

PubkeyAuthentication yes -- 允 许 Publ ic KeyAuthorizedKeysFi le %h/.ssh/authorized_keys

上面这个配置是设定免密码登陆的账号公钥存储路径ps  如果是小团队 把每个人的公钥收集起来放到/home/git/.ssh/authorized_keys文件里问题不大如果团队较大或是有权限要求这种方式就很不灵活了这时可以用Gitosis来管理公钥我将在后文介绍。

接着重启ssh服务

$sudo service ssh restart 或是 $sudo/etc/init.d/ssh restartssh服务器到这里安装配置完毕。

出于安全考虑可以在本教程配置完毕后设置gitadmin用户不允许登录shel l 可通过用vim打开编辑/etc/passwd文件并找到下面的一行(自行创建的用户名) gitadmin:x:1001:1001:,,, :/home/gitadmin:/bin/bash

北大青鸟中关村

改为gitadmin:x:1001:1001:,,, :/home/gitadmin:/usr/bin/git-shel l

这样 gitadmin用户可以正常通过ssh使用git但无法登录shel l 因为我们为gitadmin用户指定的git-shel l每次一登录就自动退出

3、安装配置git服务器

$sudo apt-get instal lgitgit-core --安装git服务器

$sudomkdir/home/gitadmin/repositories --创建git仓库存储目录$sudochowngitadmin:gitadmin/home/gitadmin/repositories --设定所有者

$sudochmod 755/home/gitadmin/repositories --设置仓库访问权限接下来初始化全局设置

$gitconfig--global user.name“gitadmin”

$gitconfig--global user.emai l “gitadmin@server”

@后的server为本机I P可用ifconfig查看

4、基本的git服务器without gitosis

这里是git本地服务器最基本的实现不使用下文讲解的gitosis进行管理适合人数较少并且没有权限管理要求的小团队。

PC客户端

首先安装git客户端参见后文方法

配置无密码登陆需拷贝pc端公钥至/home/git/.ssh/authorized_keys在git.bash下

$ ssh-keygen -t rsa --生成本机密钥 公钥默认在

北大青鸟中关村

~/.ssh/id_rsa.pub

$ ssh-copy-id gitadmin@host --上传公钥远程主机host为服务器IP

若不用以上命令用下面这条命令则清楚地解释了公钥的保存过程$ sshgitadmin@host 'mkdir -p .ssh&&cat >> .ssh/authorized_keys' <~/.ssh/id_rsa.pub

Ubuntu服务器端

你可以在服务器端自行创建仓库先选定一个目录作为Git仓库假定是/srv/sample.git在/srv目录下输入命令

$sudogitinit--baresample.git

$sudochown-R gitadmin:gitadminsample.git--把owner改为gitadmin这样Git就会创建一个裸仓库裸仓库没有工作区 因为服务器上的Git仓库纯粹是为了共享所以不让用户直接登录到服务器上去改工作区并且服务器上的Git仓库通常都以.git结尾。

至此最基本的git本地服务器已经搭建完毕可以通过git clone命令克隆远程仓库在各自电脑上运行了。

5、安装配置gitosis

简单地说Gitosis就是一套用来管理authorized_keys文件和实现简单连接限制的脚本。有趣的是用来添加用户和设定权限的并非通过网页程序而只是管理一个特殊的Git仓库。你只需要在这个特殊仓库内做好相应的设定然后推送到服务器上 Gitosis就会随之改变运行策略。

北大青鸟中关村

创建管理员公钥和私钥

在默认用户的主目录路径下运行以下命令按照提示创建可直接回车略过 $ss h-keygen-t rsa

默认生成2048位如果需要提高安全级别也可以通过下面的命令$ssh-keygen-trsa-b 4096

公钥和私钥默认会保存在~/.ssh目录下如下所示id_rsaid_rsa_pub(公钥) known_hosts

安装gitosis

安装python的setup tool

$sudo apt-get instal l python-setuptools

获取并安装gitosis

$cd/tmp--切换到缓存目录下载安装包在关机时会被系统自动清理$git clone https://github.com/tv42/gitosis.git--下载安装包

$cdgitosis

$sudo python setup.py instal l --到此gitosis安装完成

配置gitosisgitosis会默认将git仓库放在gitadmin主目录下并自动管理authorized_keys文件

$cp~/.ssh/id_rsa.pub/tmp--拷贝出管理员公钥

向gitosis添加公钥并初始化

$sudo-H-u gitadmingitosis-init</tmp/id_rsa.pub

Initial ized empty Git repository in

北大青鸟中关村

/home/gitadmin/repositories/gitosis-admin.git/

Reinitial ized existing Git repository in/home/gitadmin/repositories/gitosis-admin.git/

这样该公钥的拥有者gitadmin就能修改用于配置Gitosis的那个特殊Git仓库了。接下来需要手工对该仓库中的post-update脚本加上可执行权限

$ sudochmod 755/home/gitadmin/repositories/gitosis-admin.git/hooks/post-update到此为止git服务器端的搭建结束管理员为gitadmin。

6、仓库管理员信息

现在在终端下进到用户主目录克隆Gitosis的控制仓库

$gitclonegitadmin@server:gitosis-admin.git

当前目录下将得到一个名为gitosis-admin的工作目录主要由两部分组成

$cdgitosis-admin

$find.

./gitosis.conf

./keyd ir

./keydir/gitadmin.pubgitosis.conf文件是用来设置用户、仓库和权限的控制文件。 keydir 目录则是保存所有具有访问权限用户公钥的地方每人一个。在keydir里的文件名如我gitadmin.pub应该跟你的不一样 Gitosis会自动

北大青鸟中关村

从使用gitosis-init脚本导入的公钥尾部描述中获取该名字。用编辑器gitosis.conf文件的内容只包含与刚刚克隆的gitosis-admin相关的信息

$catgitosis.conf

[gitosis]

[groupgitosis-admin]members=gitadminwritable=gitosis-admin

它显示用户gitadmin是唯一能管理gitosis-admin项目的人。

UCloud:全球大促降价,云服务器全网最低价,1核1G快杰云服务器47元/年

ucloud:全球大促活动降价了!这次云服务器全网最低价,也算是让利用户了,UCloud商家调低了之前的促销活动价格,并且新增了1核1G内存配置快杰型云服务器,价格是47元/年(也可选2元首月),这是全网同配置最便宜的云服务器了!UCloud全球大促活动促销机型有快杰型云服务器和通用型云服务器,促销机房国内海外都有,覆盖全球20个城市,具体有北京、上海、广州、香港、 台北、日本东京、越南胡志明市、...

DMIT:新推出美国cn2 gia线路高性能 AMD EPYC/不限流量VPS(Premium Unmetered)$179.99/月起

DMIT,最近动作频繁,前几天刚刚上架了日本lite版VPS,正在酝酿上线日本高级网络VPS,又差不多在同一时间推出了美国cn2 gia线路不限流量的美国云服务器,不过价格太过昂贵。丐版只有30M带宽,月付179.99 美元 !!目前美国云服务器已经有个4个套餐,分别是,Premium(cn2 gia线路)、Lite(普通直连)、Premium Secure(带高防的cn2 gia线路),Prem...

青果网络-618阿里云,腾讯云特惠优惠折上折!

官方网站:点击访问青果云官方网站活动方案:—————————–活动规则—————————1、选购活动产品并下单(先不要支付)2、联系我司在线客服修改价格或领取赠送时间3、确认价格已按活动政策修改正确后,支付订单,到此产品开设成功4、本活动产品可以升级,升级所需费用按产品原价计算若发生退款,按资源实际使用情况折算为产品原价再退还剩余余额! 美国洛杉矶CN2_GIACPU内存系统盘流量宽带i...

cs服务器为你推荐
马云将从软银董事会辞职马云为什么辞职316不锈钢和304哪个好304跟316的不锈钢材质有什么区别法兰绒和珊瑚绒哪个好法兰绒和珊瑚绒睡衣哪个好?三国游戏哪个好玩三国类的游戏哪些好玩点手机炒股软件哪个好手机炒股软件oppo和vivo哪个好vivo和oppo哪个更耐用东莞电信宽带套餐东莞光纤宽带资费首选dns服务器地址什么是首选DNS服务器,备用DNS服务器?是电脑还是什么?电信dns服务器地址电信宽带的DNS服务地址是多少360云盘同步版网络正常的。 提示360云盘同步版同步失败 ,文件被占用中,无法更新是什么原因
万网域名 未注册域名查询 php主机租用 万网域名管理 greengeeks 漂亮qq空间 cpanel主机 韩国电信 512av 20g硬盘 godaddy域名优惠码 华为云主机 adroit 美国网站服务器 流媒体加速 网购分享 网站加速软件 中国域名 金主 万网注册 更多