inux下Git和gitosis的安装与配置

1、增加git用户

1
2
3
4
root@stu-system:/#useradd git
root@stu-system:/#vim /etc/passwd
git:x:501:501::/home/git:/bin/bash/git-shell
root@stu-system:/sudo passwd git

2、安装git和gitosis

依次运行一下命令进行安装,其中gitosis是git的权限管理工具

1
2
3
4
5
sudo apt-get install git
sudo apt-get install openssh-server
sudo apt-get install python2.6
sudo apt-get install python-setuptools
apt-get install gitosis

3、git和gitosis配置

修改gitweb.conf

1
2
3
vim /etc/gitweb.conf
# path to git projects (<project>.git)
$projectroot = "/home/git/repositories/";

依次运行以下命令,使用ssh-keygen生成密钥对SSH_KEY和SSH_KEY.pub,并初始化gitosis-admin.git库

1
2
ssh-keygen -t rsa
sudo -H -u git gitosis-init <SSH_KEY.pub

为/home/git/repositories/gitosis-admin.git/hook/post-update增加执行权限

1
chmod +x /home/git/repositories/gitosis-admin.git/hook/post-update

4、创建git新库的脚本

写了个脚本create-repo.sh方便创建新库,并解决了最后提到的一些问题;在给脚本文件加上执行权限后,只要执行“/home/git/create-repo.sh repo-name.git”即可完成新库创建,其中repo-name替换为新库名称。

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
root@stu-system:/home/git# cat create-repo.sh
 
#!/bin/bash
 
if [ $# -ne 1 ];
then
    echo "Usage: $0 repo-name"
    exit
fi
 
cd /home/git/repositories/
mkdir $1.git
cd $1.git
git init
git config --bool core.bare true
 
cd ..
chown -R git *
chgrp -R git *

5、使用gitosis进行git权限管理

使用git修改gitosis-admin.git库中的gitosis.conf文件,对应的用户公钥放在keydir文件夹中,公钥文件以“用户名.pub”命名,修改完后push回去就可以。提示:使用ssh key generator在Windows下生成的密钥放到gitosis-admin.git前需要在Linux用以下命令来将密钥转换为Linux下的格式。

1
ssh-keygen -if 公钥文件名>新公钥文件名

实际上push到git主库后,gitosis.conf文件会被更新到/home/git/repositories/gitosis-admin.git/gitosis.conf,这个才是真正生效的权限配置文件,如果通过git库改错了的话,可以在服务器上直接修改这个文件来解决。

01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
#vim  /home/git/repositories/gitosis-admin.git/gitosis.conf
[gitosis]
gitweb=yes
 
[group admin]
members = maple root@stu-system
 
[group tech]
members = @admin
 
[group gitosis-admin]
writable = gitosis-admin
members = @admin
 
[group test]
writable = test
members = @tech
 
[group test-readonly]
readonly = test
members = maple2

6、各种问题

(1)出现’gitosis-admin’ does not appear to be a git repository,短路径无效时替换为全路径

在服务器上使用短路径会取现下面这个问题,原因是没有找到对应匹配的密钥所致,如果正确使用了ssh密钥则不会出现这个问题,这里就不去折腾了

1
2
3
4
5
root@stu-system:/home/git/repositories# git clone git@127.0.0.1:gitosis-admin.git
Cloning into gitosis-admin...
git@127.0.0.1's password:
fatal: 'gitosis-admin' does not appear to be a git repository
fatal: The remote end hung up unexpectedly

使用以下命令解决,只不过每次push和pull的时候都需要输入一遍git用户的密码,略为繁琐

1
git clone git@127.0.0.1:/home/git/repositories/gitosis-admin.git

(2)出现Unable to create temporary file: Permission denied
在Windows上使用TortoiseGit执行Push时出现以下错误

01
02
03
04
05
06
07
08
09
10
git.exe push --force --progress  "origin" master:master
 
Counting objects: 189, done.
Compressing objects: 100% (187/187)
Writing objects:   7% (14/189)
fatal: Unable to create temporary file: Permission denied
fatal: sha1 file '<stdout>' write error: Invalid argument
error: failed to push some refs to 'git@10.73.4.46:channelv.git'
 
git did not exit cleanly (exit code 1)

原来是服务器上是用root账户建立的库目录,导致git账户无权写入,方法就是修改文件夹的所属用户和所属用户组

1
2
root@stu-system:/home/git/repositories# chown -R git *
root@stu-system:/home/git/repositories# chgrp -R git *

(3)出现failed to push some refs to ‘git@10.73.4.46:channelv.git’

在Windows上使用TortoiseGit执行Push时出现以下错误

01
02
03
04
05
06
07
08
09
10
11
12
git.exe push --progress  "origin" master:master
 
Counting objects: 189, done.
Compressing objects: 100% (158/158)
Writing objects: 100% (189/189), 1016.00 KiB | 997 KiB/s
Writing objects: 100% (189/189), 1.12 MiB | 997 KiB/s, done.
remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
To git@10.73.4.46:channelv.git
! [remote rejected] master -> master (branch is currently checked out)
error: failed to push some refs to 'git@10.73.4.46:channelv.git'
 
git did not exit cleanly (exit code 1)

在服务器对应的库目录下执行以下命令增加配置即可

1
git config --bool core.bare true

Git是非常著名的分布式版本控制系统。 Gitosis则是方便通过Gitssh架设中央服务器的软件。这篇文章的安装流程写得很明了,但使用中还是遇到了些许问题,本文算是该流程的补充。如果打算通过Gitosis架设服务器通过本文或许可以少走不少弯路。 一、架设步骤 1. 下载并安装python setuptools sudo apt-get install python-setuptools 2. 下载并安装gitosis cd ~/src git clone git://eagain.net/gitosis.git cd gitosis python setup.py install 3. 添加用户git sudo adduser \ --system \ --shell /bin/sh \ --gecos 'git version control' \ --group \ --disabled-password \ --home /home/git \ git 4. 生成本机密钥 切换到个人机,如果已有~/.ssh/id_rsa.pub略过此步 ssh-keygen -t rsa 5. 上传密钥到服务器临时目录 scp ~/.ssh/id_rsa.pub 用户名@主机:/tmp 6. 初使化gitosis 切回到服务器 sudo -H -u git gitosis-init < /tmp/id_rsa.pub 7. 修改post-update权限 sudo chmod 755 /home/git/repositories/gitosis-admin.git/hooks/post-update 8. clone gitosis管理平台 git clone git@主机名:gitosis-admin.git cd gitosis-admin 9. 安装完成 通过修改gitosis-admin管理gitosis用户权限 添加公密到keydir,添加用户 修改完后commit,push到中服务器即可完成仓库权限的相关操作。 二、实例 目标:添加用户 john 仓库 foo 到gitosis,并管理员miao合作管理 1. 用户john添加并发送id_rsa.pub给miao john:~$ ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/john/.ssh/id_rsa): Created directory '/home/john/.ssh'. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/john/.ssh/id_rsa. Your public key has been saved in /home/john/.ssh/id_rsa.pub. john:~$ cp /home/john/.ssh/id_rsa.pub /tmp
在Linux系统下,MMCV安装失败可能有多种原因,以下是一些常见原因及对应的解决办法: ### PyTorch不兼容 - **原因**:MMCVPyTorch版本不兼容会导致链接失败,出现类似 `ImportError: /root/miniconda3/envs/mmseg/lib/python3.8/site-packages/mmcv/_ext.cpython-38-x86_64-linux-gnu.so: undefined symbol: _ZNK2at6Tensor4add_ERKS0_RKN3c106ScalarE` 的错误。这是因为MMCV依赖于特定版本的PyTorch,版本不匹配时,编译生成的扩展库无法正常链接到所需的符号 [^1]。 - **解决办法**:确保安装的MMCVPyTorch版本相互兼容。可以参考MMCV官方文档来选择合适的版本组合。例如,若使用PyTorch 1.8.0,需安装之兼容的MMCV版本。安装时可以使用指定版本的命令,如 `pip install mmcv-full -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.8.0/index.html` ,这里的 `cu111` 表示CUDA 11.1,`torch1.8.0` 表示PyTorch 1.8.0。 ### 环境配置问题 - **原因**:虚拟环境配置不正确,或者系统缺少必要的依赖库,如CUDA、cuDNN等,会影响MMCV的安装。如果CUDA版本MMCV、PyTorch不匹配,也会导致安装失败。 - **解决办法**:正确配置虚拟环境,按照标准流程创建激活虚拟环境。同时,确保系统安装了正确版本的CUDAcuDNN,并且环境变量配置正确。可以通过 `nvcc --version` 检查CUDA版本,若版本不匹配,需重新安装合适的版本,并更新环境变量。 ### 网络问题 - **原因**:在使用 `pip` 安装MMCV时,网络不稳定或被限制,会导致下载过程中断或失败。 - **解决办法**:可以更换网络环境,或者使用国内的镜像源来加速下载。例如,使用阿里云的镜像源,命令如下: ```bash pip install mmcv-full -i https://mirrors.aliyun.com/pypi/simple/ ``` ### 权限问题 - **原因**:在某些情况下,没有足够的权限在指定目录下安装MMCV,会导致安装失败。 - **解决办法**:检查当前用户是否有足够的权限。可以使用 `sudo` 命令以管理员权限进行安装,或者修改安装目录的权限,使其允许当前用户进行操作。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值