RHEL5 cvs配置和使用简单文档(完结)

2024-02-01 00:32

本文主要是介绍RHEL5 cvs配置和使用简单文档(完结),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[root@imdba ~]# rpm -qa |grep cvs
cvs-1.11.22-5.el5
如果没有就装一下,默认自带。
[root@imdba ~]# ls -ltr cvs*
-rw-r–r– 1 root root 751059 Oct 14 07:23 cvs-1.11.22-5.el5.i386.rpm
[root@imdba ~]#useradd cvs
[root@imdba ~]#passwd cvs
[root@imdba ~]#mkdir /home/cvs/cvsroot
[root@imdba ~]#chown -R cvs.cvs /home/cvs/cvsroot
[root@imdba ~]#cvs -d /home/cvs/cvsroot/ init
[root@imdba ~]# cat /etc/xinetd.d/cvs
# default: off
# description: The CVS service can record the history of your source /
#              files. CVS stores all the versions of a file in a single /
#              file in a clever way that only stores the differences /
#              between versions.
service cvspserver
{
disable                 = no
port                    = 2401
socket_type             = stream
protocol                = tcp
wait                    = no
user                    = root
passenv                 = PATH
server                  = /usr/bin/cvs
env                     = HOME=/home/cvs/cvsroot
server_args             = -f –allow-root=/home/cvs/cvsroot pserver
#       bind                    = 127.0.0.1
}
[root@imdba xinetd.d]# /etc/init.d/xinetd restart
Stopping xinetd:                                               [  OK  ]
Starting xinetd:                                               [  OK  ]
[root@imdba xinetd.d]# ps -ef |grep cvs
root      3915  2864  0 07:29 pts/1    00:00:00 grep cvs
一看没有cvs进程,傻眼了,不要紧,看端口。
[root@imdba xinetd.d]# netstat -antp |grep 2401
tcp        0      0 0.0.0.0:2401                0.0.0.0:*                   LISTEN      3912/xinetd
[root@imdba CVSROOT]#
chmod -R 770 /home/cvs/cvsroot/CVSROOT/config
[root@imdba CVSROOT]#
chmod -R 644 /home/cvs/cvsroot/CVSROOT/config

 

增加用户:
在/home/cvs/cvsroot/CVSROOT/passwd 添加以下字符串

cvs:EIbvpIUkVHbhs :cvs
Nova:EIbvpIUkVHbhs :Nova

,中间的高亮的随机字符串请用以下pl脚本生成。

[root@imdba ~]# more passperl.pl
#!/usr/bin/perl
srand (time());
my $randletter = “(int (rand (26)) + (int (rand (1) + .5) % 2 ? 65 : 97))”;
my $salt = sprintf (”%c%c”, eval $randletter, eval $randletter);
my $plaintext = shift;
my $crypttext = crypt ($plaintext, $salt);
print “${crypttext}
“;
用法为:perl passperl.pl “cvs” 生成密码:EIbvpIUkVHbhs

登陆CVS:

[root@imdba ~]#
IP=`ifconfig eth0 |grep inet |grep Mask |awk ‘{print $2}’|awk -F: ‘{print $2}’`
[root@imdba ~]# exportCVSROOT=:pserver:cvs@$IP:2401/home/cvs/cvsroot
[root@imdba ~]# cvs login
Logging in to :pserver:cvs@192.168.238.128:2401/home/cvs/cvsroot
CVS password: 输入cvs

检查是否已CVS账户登录:echo $CVSROOT
:pserver:cvs @192.168.238.128:2401/home/cvs/cvsroot
项目初始化,创建一个CVS库

[root@imdba Nova]# pwd
/root/Nova
[root@imdba ~]#
cvs import -m “Nova Store” StoreHouse cvs First

N StoreHouse/Nova.grants.sql
N StoreHouse/MySQL-server-community-5.0.83-0.rhel3.i386.rpm
N StoreHouse/cvs-1.11.22-5.el5.i386.rpm
N StoreHouse/MySQL-client-community-5.0.83-0.rhel4.i386.rpm
N StoreHouse/auto-export-user-grants.sql
N StoreHouse/db74293_nova_wp_n20090904_329.sql
N StoreHouse/mysql-revokes.sql
N StoreHouse/innotop-1.7.1.tar.gz
N StoreHouse/MySQL-shared-community-5.0.83-0.rhel3.i386.rpm
No conflicts created by this import

管理方法:签出,提交,更新等
签出项目到本地
cvs checkout StoreHouse
更新项目
cvs update
添加文件后需要提交
cvs add -m “perl for password create” passwd.pl
cvs commit
提交单个文件,如果修改
cvs commit -m “” db_update_20091011.sql
cvs ci -m ‘DB迁移’ dbupdate.txt

简单测试以下,因为我已经提交了StoreHouse项目,所以/root/Nova下的文件,我可以直接删除,然后再从CVS库中checkout,保持最新或者恢复。

[root@imdba Nova]# rm -rf *
[root@imdba Nova]#
[root@imdba Nova]# cvs checkout StoreHouse
cvs checkout: Updating StoreHouse
U StoreHouse/MySQL-client-community-5.0.83-0.rhel4.i386.rpm
U StoreHouse/MySQL-server-community-5.0.83-0.rhel3.i386.rpm
U StoreHouse/MySQL-shared-community-5.0.83-0.rhel3.i386.rpm
U StoreHouse/Nova.grants.sql
U StoreHouse/auto-export-user-grants.sql
U StoreHouse/cvs-1.11.22-5.el5.i386.rpm
U StoreHouse/db74293_nova_wp_n20090904_329.sql
U StoreHouse/innotop-1.7.1.tar.gz
U StoreHouse/mysql-revokes.sql

提交的所有文件都已经恢复,当然还可以做更新,提交单个文件等等操作。

http://www.imdba.cn/2009/10/14/rhel5-cvs-config-and-use-it/

这篇关于RHEL5 cvs配置和使用简单文档(完结)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/665542

相关文章

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

jdk1.8的Jenkins安装配置实践

《jdk1.8的Jenkins安装配置实践》Jenkins是一款流行的开源持续集成工具,支持自动构建、测试和部署,通过Jenkins,开发团队可以实现代码提交后自动进行构建、测试,并将构建结果分发到测... 目录Jenkins介绍Jenkins环境搭建Jenkins安装配置Jenkins插件安装Git安装配

Nginx之https证书配置实现

《Nginx之https证书配置实现》本文主要介绍了Nginx之https证书配置的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录背景介绍为什么不能部署在 IIS 或 NAT 设备上?具体实现证书获取nginx配置扩展结果验证

C#如何在Excel文档中获取分页信息

《C#如何在Excel文档中获取分页信息》在日常工作中,我们经常需要处理大量的Excel数据,本文将深入探讨如何利用Spire.XLSfor.NET,高效准确地获取Excel文档中的分页信息,包括水平... 目录理解Excel中的分页机制借助 Spire.XLS for .NET 获取分页信息为什么选择 S

Java利用Spire.XLS for Java自动化设置Excel的文档属性

《Java利用Spire.XLSforJava自动化设置Excel的文档属性》一个专业的Excel文件,其文档属性往往能大大提升文件的可管理性和可检索性,下面我们就来看看Java如何使用Spire... 目录Spire.XLS for Java 库介绍与安装Java 设置内置的 Excel 文档属性Java

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin