1:安装,安装其实非常简单
测试是否安装成功 如果显示了版本信息则表示安装成功 2:配置 svn配置建立svn版本库目录可建多个: 新建一个版本库目录 名字为repos #mkdir -p /opt/svndata/repos 建立svn版本库: #svnadmin create /opt/svndata/repos 修改svn版本库配置文件版本库: # vim /opt/svndata/repos/conf/svnserve.conf 内容修改为:
注重:对用户配置文件的修改立即生效,不必重启svn。
这里是配置用户名与密码 配置svn用户访问权限: # vim /opt/svn/conf/authz.conf 注重: * 权限配置文件中出现的用户名必须已在用户配置文件中定义。 * 对权限配置文件的修改立即生效,不必重启svn。 用户组格式: [groups] = , 其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。 版本库目录格式: [:/项目/目录] @ = = 其中,方框号内部分可以有多种写法: [/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/opt/svndata,[/]就是表示对全部版本库设置权限。 [repos:/] 表示对版本库repos设置权限 [repos2:/abc] 表示对版本库repos2中的abc项目设置权限 [repos2:/abc/aaa] 表示对版本库repos2中的abc项目的aaa目录设置权限 权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。 权限可以是w、r、wr和空,空表示没有任何权限。 示例:
启动svn建立启动svn的用户
好SVN已经启动了,你可以通过svn://ip地址:端口/repos 这种方式来访问了
另外一个要说的是,有时候发现你的SVN连不上,也许是因为端口被防火墙墙掉的缘故 可以看到有一个post-commit.tmpl文件,这是一个模板文件, 复制一份放在此目录下,命名为post-commit,并将其用户组设为apache,这样就有了访问apache目录的权限。 里面原有的代码全部注释掉.这里可以执行shell命令,每次commit完成后都会调用此文件. 我的文件内容为
#!/bin/sh 另外还需要修改apache目录下.subversion文件夹下的servers文件将其中一项改为store-plaintext-passwords = no,主要的原因是:执行脚本的时候会提示是否保存密码,root用户在交互状态下可以回答yes或no,而apache用户没有这个机会,所以要在apache目录下的.subversion/servers中预先配置好 说明: #!/bin/sh 说明是执行shell命令 export LANG=zh_CN.UTF-8 是为了解决svn post commit 中文乱码。
如果你是GBK编码可能会提示:Error output could not be translated from the native locale to UTF-8 svn export --username 你版本库的用户名 --password 用户名的密码 svn://你的IP地址:端口/dev/trunk/source/main/kBase /home/phpcms/public_html/kBase --force 执行更新操作 --force 是覆盖文件 另外还需要将写入的目录/home/phpcms/public_html/kBase添加svn的权限,不然会提示权限不够。 如果提示:post-commit hook failed (exit code 255) with no output赋予post-commit文件可执行权限 如果您的默认编码就是UTF-8的,要上传中文文件,先将文件另存为UTF-8格式在提交 (责任编辑:IT) |