当前位置:首页> 正文

git权限设置|git用户权限

git权限设置|git用户权限

1. git用户权限

1、从服务器上克隆完整的Git仓库(包括代码和版本信息)到单机上。也就是说自己机器上有一个git仓库。这和svn是不同的,svn是没有本地的仓库的。所以git是先提交到本地仓库,然后推送到服务器。而svn是直接提交到服务器。这里说一下几个含义:拉取:将服务器中git仓库的数据拉取到本地git仓库,同时修改(更新)当前分支的文件获取:仅仅将服务器中git仓库的数据拉取到本地git仓库提交:将修改的文件提交到本地git仓库。推送:将本地git仓库上的数据推送到服务器。

2、在自己的机器上根据不同的开发目的,创建分支,修改代码。git和svn的一点不同在于svn是通过目录结构来区分不同的分支的。而git你可以点击切换/检出来切换不同的分支。在svn上右键点击RepositoryBrowser可以看见整个工程的目录结构在git上可以点击版本分支图查看整个工程的分支解构。

3、在单机上自己创建的分支上提交代码。

4、在单机上合并分支。

5、把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。

6、生成补丁(patch),把补丁发送给主开发者。git分支保护:自己并没有权限推送到当前分支:1自己创建一个分支,2将自己创建的分支推送上去,3登录git,发送MergeRequests(合并分支的请求)给相关人员。4通知相关人员,并由相关人员将你的代码合并到主分支

2. git用户权限管理

  首先要有 ssh远程登陆的工具,比如secureCRT等  方案一 基于SSH直接搭建  Git支持的协议主要是四种:  本地: 需要文件共享系统,权限不好控制  HTTP:速度慢  SSH:同时支持读写操作,不支持匿名的读取(Git默认协议)  GIT:最快  从搭建的难易程度和特点综合筛选,最合适的还是ssh,并且大部分服务器上基本都有ssh服务,所以省去了不少麻烦。一个最基本的思路是给每一个人一个ssh帐号,这样大家就可以通过用户名和口令来访问了,但是显然这不是一个好的选择,这个做法有些多余,并且对于repo的权限很难管理。  在使用Github的时候,会利用rsa.pub公钥/私钥的方式,这样在服务端拥有用户的公钥(*.pub)之后就可以,跨过繁琐的口令,直接认证提交了,而服务端也会根据不同的用户身份,对其权限有着更加灵活的管理。因此我们也采用这种方式。  服务端  为了使远程库访问更加直观,先在服务器上创建一个名为git的账户,这样以后clone的时候就如下面的格式了:git clone git@server:some.git  创建新的用户,创建repo等目录$sudo adduser git$su git$cd ~$mkdir repos  在HOME下的.ssh目录,如果没有则创建,创建一个authorized_keys文件,这个文件就是用来管理所有git用户的公钥的,也就是这里面的用户对于项目有着R+W的权限。  客户端  对于每一个客户端,我们需要生成一对密钥和公钥,如果是Github用户,那么.ssh目录下,一定有id_rsa.pub和id_rsa两个文件,其中第一个是系统生成的公钥,另一个是自己要保存好的密钥。如果没有的话,可以在终端执行:ssh-keygen来生成,完成后,将自己的公钥提交给管理员,这就是一个注册的行为。  完成  最后一步,管理员将团队成员的公钥添加到authorized_keys中,比如将同学susie加入:$ cat susie.pub >> authorized_keys  至此,大家可以通过git@server:repos/some.git来访问公共的版本库了。  问题  安全问题,成员可以登录git用户的shell,细节权限如分支等不好控制  管理麻烦,新建repo,或者增加成员比较麻烦,尤其是修改的时候  方案二 使用Gitolite服务  Gitolite 也是基于SSH协议构建的方便管理git repo的应用,可以通过其源码安装.  安装  安装按照官方给定的文档就可以轻易的实现:$ git clone git://github.com/sitaramc/gitolite$ mkdir -p $HOME/bin$ gitolite/install -to $HOME/bin$ gitolite setup -pk YourName.pub  如果执行最后一条命令的时候,gitolite不识别,则可以通过下面两种方式解决:  将gitolite添加到PATH里面  通过$HOME/bin/gitolite setup -pk YourName.pub 执行  至此,gitolite在服务端,搭建完毕,会发现此时HOME目录下增加了一个文件projects.list和一个目录repositories,后者就是我们的版本仓库了,每当新建repo的时候,就会在其中创建。  使用  是时候说一下gitolite的管理模式了,他会创建一个gitolite-admin的repo,管理员就是通过像这个repo提交配置文件而实现对git服务器的控制的。  首先,将这个repo导入到我们的workspace:在此之前,需要配置本地的ssh,gitolite要求管理员的本地密钥和其注册公钥的名字一致,比如我们安装的时候指定 -pk后面为 admin.pub 则管理员本地需要由admin对应的私钥。我们可以通过~/.ssh/config来进行配置(注:有些系统可以用conf,Mac OSX 下无效,只能用config). host gitolite user git hostname yourhostname.com port 22 identityfile ~/.ssh/admin  这样,当我们访问gitolite的时候就会自动根据配置文件执行,配置完成后可以根据下面的命令,将gitolite-admin转移到本地。 git clone gitolite:gitolite-admin.git  克隆完成后,可以发现,gitolite-admin下面有两个目录,其中conf保存配置文件,我们可以通过编辑里面的gitolite.conf文件,管理git服务器,keydir目录保存用户的公钥pub文件。  当我们讲修改后的repo 提交的时候,gitolite就会自动的应用这些配置,管理过程就方便了很多。  配置规则  打开gitolite.conf文件可以看到其中的示例:  To add new users alice, bob, and carol, obtain their public keys and add them to 'keydir' as alice.pub, bob.pub, and carol.pub respectively.  To add a new repo 'foo' and give different levels of access to these users, edit the file 'conf/gitolite.conf' and add lines like this: repo foo RW+ = alice RW = bob R = carol  上面的配置文件就是新建了一个repo foo,并且添加了三位项目成员,每一个人的权限不同。提交push后,管理便生效了。

3. git 权限控制

1、新建用户

将用户的公钥文件 如 **.pub 拷贝到 gitolite-admin\keydir文件夹下,做一次提交,并push到服务器。

2、新建仓库和设置用户权限

修改 gitolite-admin\conf\gitolite.conf 文件,加入权限和需要新建的仓库名,做一次提交,并push到服务器,这时候在服务器上就生成了新建的仓库。

例如:

@group = user1 user2

repo test

RW+C = user3

RW br1 = @group

RW refs/tags/ = user1 user3

2.1 @group = user1 user2 group组有 user1、user2 两个用户

2.2 repo test test 是仓库名

2.3 RW+C = user3 user3 有“读、写、强制更新、创建分支 ”权限

2.4 RW br1 = @group group组对br1分支有读写权限

2.5 RW refs/tags/ = user1 user3 user1和user3有打tag的权限

4. git多用户管理及权限控制

一、首先在服务器上安装git

二、添加git用户,并且限制登录权限

三、创建证书登录

四、初始化Git仓库

五、禁用git用户shell登录

六、克隆远程仓库

七、自动同步到web服务目录下

八、把本地代码自动同步到github和gittee上

5. git的权限管理

我也遇到这个问题,然后做了以下两步修正就OK了:

1:git生成ssh key(ssh-keygen),并将此key上传到profile setting -->ssh keys

2:我系统是centos 6.5的,默认安装的git 版本太低(1.7),将其修正到V 2.2.1。貌似在网上有看到说1.8+的版本就不会有这个问题。

6. git用户权限导出数据库

MacOS Server是苹果电脑公司新一代服务器软件。专为OS和iOS设备、MacOS 提供服务,现在支持Mavericks,能够轻松共享文件,安排会议日程,同步联系人,软件开发,网站发布,WiKi发布,配置Mac远程访问网络。MacOS Server现在可以可以快速、轻松地打运行,甚至不需要专业工程师帮助你就能迅速搭建服务器环境。

一、安装

安装完毕之后,查看服务器状态,可以显示出主机名,服务器运行时间版本,IP地址等信息。接着讲讲她有那些功能。

设置个人信息

二、核心功能介绍

1.文件共享

文件共享:Mac、PC和iPad等之间

基于标准的SMB和WebDAV文件服务

文件权限管理

Spotlight搜索

2.设置服务器提醒功能。

Server部分中的项目全部围绕着服务器监控及一般日常管理工作展开。在这里,大家可以查看运行时间与日志信息、使用情况统计、来自各项服务的日志文件以及服务器已经生成的全部警报内容。

当新的Alerts产生时,推送通知也会被用于向服务器管理员们发出警报,而且任何与该服务器连接且使用Server.app的Mac设备都将在自己的通知中心内收到警报。

3.缓存服务器

加快由苹果公司发布的软件下载本地缓存的应用程序、软件更新和OS X恢复映像等。

4.目录服务器

这里介绍的目录服务Open Directory服务相当于苹果版本的微软Active Directory。Open Directory是OS Server当中的核心服务之一Open Directory是一套基于LDAP的目录系统,允许大家创建并管理用户账户以及用户账户群组。与微软的Active Directory类似,它允许我们的用户利用自己的用户名和密码登入到计算机及服务当中

这里的证书是为OpenDirectory服务,须首先申请。

5.Xcode服务器

使用Xcode可测试运行任何一台MacOS 服务器

自动化测试OS 和iOS的应用程序,执行对多个连接的iOS设备

OS 服务器上托管自己的Git。

6.时间机器

提供网络上的Mac电脑的备份目的地

监控计算机备份,当他们最后一次备份,备份的大小

设置时间机器存储量的限制,用户可以使用

7.日历服务器

共享日历,安排会议和活动,并预定会议室

基于标准的CalDAV服务器访问从Mac , iPad,iPhone和PC

查看可用性空闲/忙碌查找

电子邮件邀请和推送通知

8 .DNS服务器

9.Wiki服务器

点和点击页面编辑更改格式,插入图片,电影和附件

访问控制

标签和注释

修订历史

文件共享

快速查找预览

10 网站设置

11.邮件服务器

基于标准的SMTP , IMAP和POP服务器

推送通知

SSL加密

自适应垃圾邮件过滤

12.查看日志服务器。

13.服务器资源使用统计

14.×××网络

远程访问您的网络服务

加密×××连接:Mac, iPad,iPhone和PC

最后,Server.app还为"高级"服务新增了独立的管理单元,其中囊括了DHCP、DNS、FTP、NetInstall、Open Directory、Software Update以及Xsan等项目。这些服务在默认状态下全部隐藏在View菜单当中,有兴趣可以装一个Server自己再去慢慢发掘。

7. git账号权限

需要在git的服务器上配置账号,如果大公司,配置权限就可以了,服务器地址填写对了就可以,小公司自己去服务器上配置账号和密码

展开全文阅读

相关内容