# 添加用户
# 设定密码
创建放置密钥的文件,进入文件git bash,输入下列命令
按照提示 *** 作,成功后会出现两个密钥,私钥和公钥。
将生成的私钥和公钥放在工作目录下,在服务器端,找到上面创建的git用户,即:
然后创建文件夹ssh,在ssh文件下创建文件authorized_keys,用来放置所有所有公钥
进入粘贴公钥
上面的server需要改为你自己的服务器的IP地址
clone成功之后你会在你的工作目录看到服务器上面的sample文件
完成。。。。。。。。。。。。。。。。。。。如何在windows上架设Git服务器
翻译自google(或者googlecode),自己加了一段关于ssh密钥的 *** 作。
TortoiseGit + msysgit + CopSSH + WindowsXP as server
1需要软件
msysgit (服务器和客户端)
CopSSH (服务器)
TortoiseGit (客户端)
Junction Link Magic (服务器,可选)
版本就不写了,找最新的就是
2服务器上
安装msysgit
选择plink, 不是OpenSSH
选择将Git加入path (第二个选项)
安装CopSSH
使用默认设置安装
CopSSH默认安装在C:\Program Files\ICW\
修改CopSSH设置
在C:\Program Files\ICW\etc\sshd_config中, 下面一行取消注释并设为"no"
PasswordAuthentication no
建立一个windows账户
Control Panel > User Accounts > Create new account
在CopSSH中激活这个账户
Start > Programs > Copssh > "Activate a user"
选择一个账户,其他的用默认(/bin/bash, 等)
输入密码,这个密码必须记住,将用来激活私钥。
在C:\Program Files\ICW\home, 每个账户有一个子目录。将其中的<user>key和<user>keypub和刚刚输入的密码发给用户。
安装一个空的git仓库
如准备将D:\project1作为Git仓库
在cmd中输入如下命令
d:
md \project1git
cd \project1git
git --bare init
这样,d:/project1就成为一个git仓库
赋予用户修改权限
在D:\project1上右键 > 安全,允许刚建立的windows账户"写"和"修改"
服务器上打开22端口
由于ssh服务器不能找到git命令,需要如下 *** 作:
Start > CopSSH > Start a unix bash shell
cd /Bin
建立符号链接到gitexe, git-receive-packexe, git-upload-archiveexe, git-upload-packexe:
$ ln -s /cygdrive/c/Program\ Files/Git/bin/gitexe gitexe
$ ln -s /cygdrive/c/Program\ Files/Git/libexec/git-core/git-receive-packexe git-receive-packexe
$ ln -s /cygdrive/c/Program\ Files/Git/libexec/git-core/git-upload-archiveexe git-upload-archiveexe
$ ln -s /cygdrive/c/Program\ Files/Git/libexec/git-core/git-upload-packexe git-upload-packexe
(按自己的安装git的路径改,空格要转为"\ ")
可选步骤:安装Junction Link Magic
在C:\Program Files\ICW\home\用户的目录下建立一个空目录,名称为pro1
启动Junction Link Magic,将git仓库的目录D:\project1 junction到C:\Program Files\ICW\home\用户\pro1
服务器设置结束
3 客户端上
对于用户,要有
私钥文件如<user>key
私钥文件的密码
服务器地址
服务器上用户的ID
安装 msysgit
选择plink
选择将git放入windows path
安装TortoiseGit
安装后,在Settings > Network > SSH设置:
SSH Client = C:\Program Files\TortoiseGit\bin\TortoisePlinkexe
(下面的 *** 作很可能不成功,需要另外的方式配置密钥)
运行C:\Program Files\TortoiseGit\bin\puttygenexe:
CopSSH中生成的密钥是OpenSSH keys, 但这里需要putty keys。将私钥转成putty格式的。
按 "Load" > 选择文件 <user>key
找个地方保存私钥 <user>ppk
运行C:\Program Files\TortoiseGit\bin\Pageantexe
加入新生成的<user>ppk,在询问密码时输入密码
注意: 每次启动后,都需要运行Pageantexe, 加入<user>ppk, 并输入密码
在我的机器上,TortoiseGit自带的puttygen不认CopSSH生成的OpenSSH keys,需要下载最新的puttygen
来生成ppk私钥。
或另外一种方法是:使用puttygen生成ppk格式的私钥,并将生成时上部显示的公钥替换OpenSSH的authorized_kyes中的内容。
不过这样会导致无法交互式登入OpenSSH服务器,但仍可继续下面的 *** 作。
4开始使用
在用户的机器上clone git仓库
URL = <user>@<server>:d:/project1
或使用junction后的路径
URL = <user>@<server>:pro1
如不使用Pageantexe,就要设置"Load Putty Key" (yes) = (path to <user>ppk)并且每次和服务器的 *** 作都要求输入密码。
注意:第一次连接服务器时,会要求保存服务器的公钥,选择yes。
(这里有个问题:git客户端会报服务器某个dll没有找到,这时把git安装目录下的那个dll文件复制到CopSSH的bin下就好)
如果服务器上的git仓库和CopSSH安装在同一个盘符上,则可以省略盘符,如
URL = ssh://<user>@<server>/project1 转载,仅供参考,祝你愉快,。你这不是还没跟踪吗 提交啥了
先执行
git add
注意后面有个点
然后
git commit -m'提交说明'
最后再push
当然 add 命令不一定非要是点, 根据需要自己去添加需要跟踪的文件一台共用服务器上多人共同使用,多个git工程每个工程的地址和账号密码又是不一样。
使用global 此时在/home/usrname下gitconfig 会生成设置全局的git用户名及邮箱账号
如下命令可谓单个工程设置用户名及邮箱账号,存放在工程目录下git/config文件中
1首先为不同的工程配置不同的Git账号
注意:这里git config命令没有带—global,表示这是一个局部的设置,也就是这个用户是当前项目的,而不是全局的。
2为不同的用户生成SSH密钥
一般的Git服务器为了安全,都会需要我们提供一个安全的SSH密钥,默认情况下,生成密钥的文件名都是一样的,但是不同的用户,必须设置不同文件名的密钥文件,否则会发生覆盖。密钥生成后,添加到服务端(如Github)
密钥存放在用户目录下ssh路径下。
//B账户的私钥
添加完后,可以使用ssh-add来查看密钥列表
其中的remore地址是url = git@githubcom :samplegit,这时候,我们需要修改跟密钥对应的地址,上面在配置ssh时,为每个Hostname配置了一个host的别名,这时候,我们就不能使用原来的Hostname来提交了,要用别名来代替Hostname。
###############Git没有客户端服务器端的概念,但是要共享Git仓库,就需要用到SSH协议(FTP , >GitLab是GitHub的免费私有库替代方案,并且安装与配置都很方便。
GitLab要求最少4GB内存,支持小团队使用没问题,实测2GB内存的VPS基本没法用,开swapfile也不行,动不动就60秒超时。因此4GB内存是必须的。
关于这一点,内存大户主要是Unicorn,基于ruby的>
Git服务的管理工具,主要有如下几种。
Gitolite 使用perl语言编写,维护和更新比较积极,下面测试使用Gitolite搭建Git服务器。
一般新建用户 ~/ssh/ 目录是不存在的。
生成路径会在ssh-kengen执行后给出,也可修改。windows下生成路径默认位于 C:/user/用户名/ssh 下。
此时, gitolite 会初始化两个仓库,同时创建 authorized_keys 文件
管理库中有两个目录, conf/ 和 keydir/ 。
仓库的创建通过编辑 gitolite-admin/conf/gitoliteconf 即可,然后将配置后的文件上传服务器。
若本地已有仓库repo2,将其添加到服务器
gitolite可以通过用户组的方式进行管理
如上提示,需要输入密码。
需要安装 openssh ,并将 gitolite 用户添加在 sshusers 组中,有的服务器可能是 ssh 组。
计算机领域的Cookbook指的是实用经典案例的意思,是对一些普遍性问题的解决方案的总结和整理。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)