git+gitolite如何实现权限控制
前言
首先说明一下,这还是本人第一次写这类文章,如有不妥,多多见谅。
基本情况
因为现在公司的人不是很多,但是还对代码有着严格的管控,所以采用了gitolite的管理方式
其实正常来讲,这种权限的把控在我看来没什么必要。
我在之前没有接触过这个插件的时候,对它可以说是一头雾水,现在搞懂了以后也想分享给大家
好了,废话不多说,咱们开始吧。
一、安装git
首先咱们要弄清楚,git是分本地以及远端的,这里以我使用的windows电脑为例(Mac不需要安装),
现在Git服务端安装好Git,大部分的是系统自带的
[root@uat1 admin]# rpm -qa|grep git
libpcap-1.4.0-4.20130826git2dbcaa1.el6.x86_64
git-1.7.1-9.el6_9.x86_64
然后需要安装windows本地的git(这里自行百度,很简单),出现我的画面就说明你成功了

二、获取本地公钥
在git客户端(也就是你的windows电脑,以下使用名词客户端),执行下面的命令:
ssh-keygen -t rsa
紧接着连续回车三次,你的公钥就会自动生成,下面是查找公钥的方法
Murry@Savior MINGW64 ~
$ cd ~/.ssh/ Murry@Savior MINGW64 ~/.ssh
$ ls
id_rsa.pub id_rsa known_hosts
你会生成两个文件,一个带.pub的就是公钥,另一个不带的就是私钥
三、在服务端安装gitolite
然后开始安装gitolite
首先咱们需要安装一个git用户,用这个用户来进行安装
[root@uat1 ~]# useradd git (增加用户)
[root@uat1 ~]# su - git (切换用户)
[git@uat1 ~]$ pwd (查看位置)
/home/git
开始下载gitolite
[git@uat1 ~]$ git clone https://github.com/sitaramc/gitolite
紧接着,开始安装gitolite
[git@uat1 ~]$ mkdir /home/git/bin (创建bin目录)
[git@uat1 ~]$ gitolite/install -to /home/git/bin (将gitolite安装到目录下)
[git@uat1 ~]$ cd bin/ (进到目录)
[git@uat1 bin]$ ls (查看内容)
commands gitolite gitolite-shell lib syntactic-sugar triggers VERSION VREF
这样咱们就可以看到gitolite相关的命令了
四、配置gitolite的管理员
这里提一下,gitolite的管理员可以是自己的一台电脑也可以是一台服务器,这里咱们配置为自己的电脑
首先将之前获取到的公钥,也就是id_rsa.pub发送到git的服务端(也就是服务器上)
scp id_rsa.pub user@ip地址:/tmp (这里会需要输入服务器密码)
服务器接收到以后,将文件名改为admin.pub
[git@uat1 tmp]$ mv id_rsa.pub admin.pub
接着就开始用管理员的公钥来进行安装gitolite
[git@uat1 ~]$ /home/git/bin/gitolite setup -pk admin.pub
紧接着你就可以看到生成了两个文件
/home/git/repositories/gitolite-admin.git
/home/git/repositories/testing.git
第一行的是管理者的git仓库,第二行的就是测试仓库
五、如何进行权限的管控
然后咱们开始生成管理员的管理仓库
[git@uat1 ~]$ git clone user@ip地址:gitolite-admin
然后咱们进入目录下就可以看到两个文件
Murry@Savior MINGW64 ~/.ssh/gitolite-admin (master)
$ ls
conf/ keydir/
这两个目录咱们分别来看
进入conf/了解一下
Murry@Savior MINGW64 ~/.ssh/gitolite-admin (master)
$ cd conf/ Murry@Savior MINGW64 ~/.ssh/gitolite-admin/conf (master)
$ ls
gitolite.conf
可以看到gitolite.conf这个文件,它就是用来管理git的权限文件,来打开看一下内容
Murry@Savior MINGW64 ~/.ssh/gitolite-admin/conf (master)
$ cat gitolite.conf
repo gitolite-admin
RW+ = gitadmin
repo testing
在这里我们就可以清楚地看到gitolite是怎么管理权限的 ,repo作为仓库的名字,而下面就是
拥有权限的人,这里RW就是可读可写
那么问题就来了,仓库和权限者他是怎么定义的呢
这里仓库其实只要你写了名字他就会自动生成,而拥有权限者的名字,就用到了keydir/目录
这个目录下的文件就是拥有者的公钥,.pub前面的名字就是这里的名字
六、更改后如何从本地提交到远端
关于这个问题只需要几个git基本命令即可
$ git add . $ git commit -m "注释内容" $ git push
只需要这三步操作,如果对git命令不了解建议先了解一下
到这里,我们就实现了gitolite的权限管控
git+gitolite如何实现权限控制的更多相关文章
- 再谈git的http服务-权限控制gitweb版(未成功)
截至目前,对gitweb的掌握还没达到最终目标,仅仅实现了通过浏览器来浏览项目,通过git命令仍然未能clone项目.但仍然要记录下来,主要是因为打算暂时放弃这条路,而所收获的一些经验还是要记录下来. ...
- 再谈git的http服务-权限控制hooks版
通过git-http-backend方法提供的http服务基本上可以做到认证用户才能使用,但只能控制到服务器路径访问,而且无法区分读写.经过不懈努力,找到了方法,相关脚本及配置见后. 基本思路就是利用 ...
- Gitolite 权限控制
官网 http://gitolite.com/gitolite/index.html 安装配置 http://gitolite.com/gitolite/install/ 傻瓜安装教程 http:// ...
- 建立多人协作git仓库/git 仓库权限控制(SSH)
转载文章请保留出处 http://blog.csdn.net/defeattroy/article/details/13775499 git仓库是多人协作使用的,可以基于很多种协议,例如http.g ...
- Git 权限控制
除了 Git 命令,权限控制也是 Git 中极为重要的组成部分,本文主要介绍 GitLab 系统提供的最常用的权限控制功能. 一.分配成员角色 首先来了解下,Git 中的五种角色: 每一种角色所拥有的 ...
- centos+git+gitolite 安装和部署
一.部署环境 系统:CentOS 6.4x64 最小化安装 IP:192.168.52.131 git默认使用SSH协议,在服务器上基本上不用怎么配置就能直接使用.但是如果面向团队服务,需要控制权限的 ...
- 使用nginx和iptables做访问权限控制(IP和MAC)
之前配置的服务器,相当于对整个内网都是公开的 而且,除了可以通过80端口的nginx来间接访问各项服务,也可以绕过nginx,直接ip地址加端口访问对应服务 这是不对的啊,所以我们要做一些限制 因为只 ...
- yii2搭建完美后台并实现rbac权限控制案例教程
作者:白狼 出处:www.manks.top/article/yii2_frame_rbac_template 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连 ...
- yii2搭建完美后台并实现rbac权限控制实例教程
1.安装yii2 未安装的请参考yii2史上最简单式安装教程,没有之一 或者参考yii2实战教程之详细安装步骤 已安装的请继续看下一步操作 2.配置数据库 2.1 配置数据库 修改common/con ...
随机推荐
- Kubernetes图形化归纳总结基础介绍整理
今天了解了下k8s,看了很多资料,自己归纳总结下,如果需要测试集群的话需要准备三台Linux服务器,一台做Master,其余两台作为Node仆从(MINION)节点, 先说下Node节点,就是宿主机器 ...
- poj 1789 每个字符串不同的字母数代表两个结点间的权值 (MST)
题目大意是就是给出n个长度为7的字符串,每个字符串代表一个车,定义车的距离是两个字符串间不同字母的个数,题目要求的数不同的车的距离的最小值,即所求的就是最小生成树 Sample Input 4aaaa ...
- mybatis中的查询语句in用法的相关问题
在开发的时候,mybatisl中使用in的时候会遇到一些问题,如果我们传的参数是String类型,以“,”来进行隔开的,例如:参数是0,1,2字符串,mybatis中的语句如下 <select ...
- [转] equals和==的区别小结
==: == 比较的是变量(栈)内存中存放的对象的(堆)内存地址,用来判断两个对象的地址是否相同,即是否是指相同一个对象.比较的是真正意义上的指针操作. 1.比较的是操作符两端的操作数是否是同一个对象 ...
- day8--socket回顾
后面学习了线程.协成和异步,它们的框架都是基于socket的协议,基本原理都是一样的,现在把这几个模块重温一下,尽量掌握这些知识更全面一些. 动态导入模块,知道知道模块名,可以像反射一样,使用字符串来 ...
- python:a += b 和 a = a + b
在python中,不同的情况下,这两个表达式有着很大的区别: 如果a,b都是可变对象,例如list,a+=b实际是对a指向的地址上的值进行修改,即运算前后id(a)的值是不变的. 而a=a+b是不同的 ...
- Clion 常用快捷键
clion 快捷键 CTRL+ALT+I 自动缩进 查询快捷键CTRL+N 查找类CTRL+SHIFT+N 查找文件CTRL+SHIFT+ALT+N 查 找类中的方法或变量CIRL+B 找 ...
- symmfony
安装:http://symfony.cn/docs/book/installation.html 1先检查php版本是否符合你要下载的symfony的最低版本: php -version 系统安装完成 ...
- Python开发之日志记录模块:logging
1 引言 最近在开发一个应用软件,为方便调试和后期维护,在代码中添加了日志,用的是Python内置的logging模块,看了许多博主的博文,颇有所得.不得不说,有许多博主大牛总结得确实很好.似乎我再写 ...
- POJ.2774.Long Long Message/SPOJ.1811.LCS(后缀数组 倍增)
题目链接 POJ2774 SPOJ1811 LCS - Longest Common Substring 比后缀自动机慢好多(废话→_→). \(Description\) 求两个字符串最长公共子串 ...