码迷,mamicode.com
首页 > 系统相关 > 详细

在linux服务器centos上使用svn同步代码到项目中

时间:2017-12-22 13:32:27      阅读:269      评论:0      收藏:0      [点我收藏+]

标签:gre   下载   过多   idc   efault   详细   kill   access   creat   

一.需求

  1.在多人开发过程中代码的管理以及版本的控制是一个很重要的问题,因为在开发过程中我们可能会同时更改过某个文件或者更改过多个文件,

  这会导致我们很容易发生错误。所以我们需要一个方式去管理我们的代码。

二.解决方案

  1.使用svn管理代码

  2.使用git管理代码 

  这两种代码管理方式的差异性我看过的这个文章写的很详细http://blog.csdn.net/jackjia2015/article/details/50607408,有兴趣可以看看,这里就不不

  谈他们的差异性了,毕竟本文章的是讲如何使用svn同步代码到项目中

 

三.详细过程

  1. 安装svn服务器端
    yum install subversion   

    只要照着提示ok下去就行,没有其他问题,安装完毕以后创建svn目录

  2. 创建svn目录
    mkdir /home/svn   //在home目录下创建svn 文件夹
    
    svnadmin create /home/svn/test //创建svn版本仓库 test

    创建完毕以后,在svn目录下你会看到test目录,test目录详细详细如下

    技术分享图片
    下面是这些目录的详细讲解
    技术分享图片

    在本文章主要是配置svn的信息以及如何同步代码,所以涉及的目录只有conf目录以及hooks目录,下面,我们开始讲解如何配置svn

  3.配置svn的基本信息

  1. cd ./conf //进入配置文件夹

  技术分享图片
  authz  文件是创建svn组和组用户的权限
  passwd  设置组中用户的账号和密码 
  svnserve.conf 配置版本库信息和用户文件和用户密码文件的路径、版本库路径
  (如果是多个仓库通过相同权限,账号和密码控制,可以将authz,passwd文件放到svn目录下)

  (1)authz 配置svn组和组用户的权限

[group]
test = user1,user2 //创建test用户组,并添加user1 user2用户

[/]    //指定根目录先的权限
@test = rw  //设置test组的权限为可读可写

  (2)passwd 配置用户密码

[users]

user1 = 12345678   //用户名就是组添加成员是的用户     
user2 = 12345677

  (3)svnserve.conf 配置版本库信息和用户文件和用户密码文件的路径、版本库路径

[general]
anon-access = none        //其他人不可读取
auth-access = write         //设置authz中用户的权限为可写
password-db = passwd     //指向自己passwd文件
authz-db = authz             //指向authz文件
realm = /home/svn/test

  以上就是配置svn的权限,用户账户密码以及仓库路径

  此时,你需要将svn重启,重启方式以下

ps -ax | grep svn    //查出svn进程

kill -9 ******    //通过kill -9方式杀死进程 *****是对应的pid

svnserve -d -r /home/svn //启动svn服务,当然你如果是想启动具体的仓库,可以将路径写的更加详细一点

  4.使用post-commit 实现同步代码

  代码同步需要使用到hooks文件目录下的post-commit勾子文件,在hooks下很多tmpl文件,这些文件都是勾子的模板来的,
  如果需要使用的时候copy 一份去掉.tmpl后缀便可使用

  (1)生成一个新的有效的勾子文件post-commit

cp post-commit.tpml post-commit
chmod 777 post-commit //设置post-commit 文件的权限 切记这步一定不可漏,不然后期运行时会报错

  这样就会生成一个有效的post-commit 文件

  (2)同步代码操作

#!/bin/sh
export LANG=en_US.UTF-8
SVN_PATH=/usr/bin/svn
WEB_PATH=/data/wwwroot/default/test    //test目录就行你的项目的目录
$SVN_PATH update $WEB_PATH --username user1 --password 12345678    //切记--username --password 是两个-

  (3)进入服务器目录,将项目checkout 出来

svn co svn://localhost/test/  /data/wwwroot/default/test --username user1 --password 12345678

 这样子你的代码同步功能已经实现了

 5.客户端使用

  你只需下载个 tortoiseSVN 小乌龟然后将test仓库拉取下来,然后将代码放入仓库文件夹中,通过添加文件方式add 后再commit ,你的项目就会同步到服务器中
  

 6.我遇到的那些错误

  1.首先客户端连接svn服务器错误,之所以会连接失败,是因为我的防火墙并没有开启3690(svn默认端口),你只需开启即可
  不会请看这个链接 http://www.linuxidc.com/Linux/2012-09/70785.htm

  2.同步失败  是因为post-commit文件的权限原因,你只需将权限设置大于755即可

  3.提示**** is a direcitory /usr/bin/svn你把这个搞错了,他不是一个目录,是svn的路径

 

 

 

在linux服务器centos上使用svn同步代码到项目中

标签:gre   下载   过多   idc   efault   详细   kill   access   creat   

原文地址:http://www.cnblogs.com/TzSteady/p/8084941.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!