linux下svn服务器搭建及使用

1. 安装svn客户端

若需要使用svn服务,首先本地需要安装svn客户端。
svn客户端下载地址为:http://tortoisesvn.net/downloads.html
安装过程此处略过。

2. 安装svn服务器

安装svn服务器:

yum install subversion

查看下载后的信息,安装位置及详细信息:

rpm -ql subversion

3. 在svn目录下创建版本库

可以在版本库目录下放置多个项目,不必为每个项目创建一个版本库。下面是我的版本库:

# 创建版本库目录
mkdir /home/svn/groupRepos
# 创建版本库
svnadmin /home/svn/groupRepos

查看并分析生成的文件:

ls /home/svn/groupRepos

可以看到如下文件:

  • conf目录:版本库的配置文件,包含用户访问账号、权限等
  • db目录:存放数据
  • format文件:是一个文本文件,里面只放了一个整数,表示当前文件库配置的版本号(可以用vi打开看一下)
  • hooks目录:放置hook脚本文件的目录
  • locks目录:用来放置subversion的db锁文件和db_logs锁文件的目录,用来追踪存取文件库的客户端
  • README.txt文件:说明文档

注:这里生成文件可能有一定的滞后,如果未看到文件可以稍微等一会再查看。

4. 修改版本库配置文件

版本库的配置文件位于 /home/svn/groupRepos/conf/ 路径下,包含有以下几个文件:

  • authz:负责账号权限的管理,控制账号是否读写权限
  • passwd:负责账号和密码的用户名单管理
  • svnserve.conf:svn服务器配置文件

4.1 修改 authz 文件

vim /home/svn/groupRepos/conf/authz

添加账号及权限后的 authz 文件如下:

### This file is an example authorization file for svnserve.
### Its format is identical to that of mod_authz_svn authorization
### files.
### As shown below each section defines authorizations for the path and
### (optional) repository specified by the section name.
### The authorizations follow. An authorization line can refer to:
###  - a single user,
###  - a group of users defined in a special [groups] section,
###  - an alias defined in a special [aliases] section,
###  - all authenticated users, using the '$authenticated' token,
###  - only anonymous users, using the '$anonymous' token,
###  - anyone, using the '*' wildcard.
###
### A match can be inverted by prefixing the rule with '~'. Rules can
### grant read ('r') access, read-write ('rw') access, or no access
### ('').

[aliases]
# joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average

[groups]
# harry_and_sally = harry,sally
# harry_sally_and_joe = harry,sally,&joe

# [/foo/bar]
# harry = rw
# &joe = r
# * =

# [repository:/baz/fuz]
# @harry_and_sally = rw
# * = r
[/]
Jack = rw

只需在末尾添加,无需在文件其他部分修改和添加任何东西末尾内容如下:

[\]
然后设置 账号 = 权限
r:读
w:写
:wq 保存退出即可

4.2 设置密码 passwd

### This file is an example password file for svnserve.
### Its format is similar to that of svnserve.conf. As shown in the
### example below it contains one section labelled [users].
### The name and password for each user follow, one account per line.

[users]
# harry = harryssecret
# sally = sallyssecret
Jack = 123456

4.3 修改 svnserve.conf 文件(重要)

vi /home/svn/groupRepos/conf/svnserve.conf

修改后的文件如下:
在这里插入图片描述
注:

  • 大多数网络资料,都会让大家将authz-db = authz这条给去掉注释,经过我本人多次被坑经验,此条去掉后,虽然svn服务器可以连接,但一直会提示“认证失败”,注释掉即可正常。
  • 还有多数资料会让大家在realm = My First Repository处填写服务器ip,经过测试,填写后并无什么用处,所以大家去掉注释即可,无需做任何修改到此,配置已经全部完成,账号信息已经添加成功

【注意】:开启防火墙的状态下需要开放 svn 端口:3690,Linux下添加对外端口可参考博客:Linux下防火墙开启外网端口

5. 启动svn服务器

启动svn服务器:

svnserve -d -r /home/svn/groupRepos

启动成功后,可用ps -aux查看服务启动是否成功,这个是显示所有的运行进程:

ps -ef |grep svn
# xxx      22052     1  0 15:59 ?        00:00:00 svnserve -d -r /home/svn/groupRepos
# xxx      28962 20465  0 16:19 pts/1    00:00:00 grep --color=auto svn

pid=22052 就是svn服务器对应的进程id,若要关闭该进程可使用 kill -9 pid 命令。

6. 客户端访问svn服务器

在svn客户端,输入地址:svn://ip地址:3690/groupRepos
(iP地址为你的svn服务器ip,groupRepos为前文创建的版本库名称,3690为svn默认端口)

svn://xxx.xxx.xxx.xxx:3690/groupRepos

弹出输入用户名和密码,输入即可访问。

7. SVN CheckOut

SVN Cheout Depth有四个选项:

  • Fully recursive:全递归。检出完整的目录树,包含所有的文件或子目录,换句话说就是把所有文件和文件夹都按照原来的结构检出。
  • Immediate children,including folders:直接子节点,包括文件夹和文件。检出目录,包含其中的文件或子目录,但是不递归展开子目录。如图二所示,只检出上框的文件夹和下框的文件,上框中文件夹里的内容不检出。
  • Only file chlidren:仅文件子节点。检出指定目录,包含所有文件,但是不检出任何子目录。若文件结构如图二所示,则只检出下框内容。
  • Only this item:仅此项。只检出目录,不包含其中的文件或子目录。

在这里插入图片描述

7.1 SVN CheckOut:Fully recursive

本地新建一个目录,鼠标右键点击 SVN CheckOut选项,输入用户名及密码,即可CherkOut版本库中已有的资源。
在这里插入图片描述
CherkOut 后可看到本地文件中新增一个 .svn 的文件。

7.2 SVN CheckOut:Immediate children, including folders

如果有以下应用场景:SVN项目仓库中包含有各种文档及代码。我想看一下项目的某个需求文档,但是暂时不想下载代码,因为下载量太大了!为方便以后版本控制和管理文件,我没有直接把文档检出来,而是在保留原来目录结构的情况下把文档检出,而代码目录留空。

这种情况下,我们可以 鼠标右键 -> TortoiseSVN -> Update to revision,然后在 Update Depth 选项处选择“Immediate children, including folders”。基于这种方法,导出直接子节点。导出完成后,可以看到所有的目录都检出,但都是空的。

在这里插入图片描述

8. SVN Commit

本地新增文件上传,选择 SVN Commit。

9. 设置SVN开机自启动

本机系统版本为Ubuntu 18.04,设置SVN服务开机自启动步骤如下:

(1)在目录 /etc/init.d/ 下添加svn启动脚本startsvn.sh

cd /etc/init.d
vim startsvn.sh

脚本内容如下(脚本中前面那段说明必须加上):

#!/bin/sh
### BEGIN INIT INFO
# Provides:          startsvn.sh
# Required-Start:
# Required-Stop:
# Default-Start:     2 3 4 5
# Default-Stop:
# Short-Description: start svn service
### END INIT INFO

svnserve -d -r /home/svn/groupRepos

(2)修改脚本权限:

sudo chmod 755 startsvn.sh

(3)将脚本添加到自启动项目中:

sudo update-rc.d startsvn.sh defaults 100

(4)重启机器:

shutdown -r now

(5)重启后查看svn服务是否自动启动了:

ps -aux|grep svnserve

如果还是没有启动, 运行: runlevel

查看当前启动level, 会打印一个数字, 把这个数字加到脚本 startsvn.sh 的 Default-Start 后面, 然后从步骤 3再执行一遍试试.

【参考博客】:

<think>好的,用户想了解在SAP系统中如何配置和执行定时任务的方法或指南,具体是“SAP 后台定时任务配置教程”或“SAP 定时作业调度方法”。我需要先回忆SAP的相关知识,确保步骤准确。 首先,SAP中的定时任务通常是通过事务码SM36来创建的,可能需要结合作业类和时间安排。我记得配置步骤大概分为定义作业、指定执行程序、设置时间参数等。用户可能需要详细的步骤,比如如何填写作业名称、选择作业类型,还有如何设置周期性运行。 另外,用户可能关心的是如何监控这些任务,比如使用SM37查看作业日志,或者处理失败的任务。这部分也需要包含在回答中,因为配置之后维护也很重要。 还要注意权限问题,执行定时任务可能需要特定的授权,比如S_BTCH_ADM和S_BTCH_JOB,需要提醒用户检查权限设置,避免配置后无法执行。 可能还需要提到一些高级配置,比如外部作业调用或使用程序RSBDCSUB进行批量输入,但用户的问题主要是基础配置,所以这部分可以作为扩展稍微提一下。 用户提供的引用中有关于压力测试和自旋锁的内容,但这些可能与当前问题无关,所以应忽略,除非有相关点可以结合,但看起来没有直接联系,因此不引用。 需要确保回答结构清晰,分步骤说明,使用中文,并按照要求用行内公式和独立公式,但SAP配置可能涉及较少数学公式,所以可能不需要太多LaTeX,但如果有涉及变量或参数的地方,比如时间间隔,可以用$...$表示。 最后,生成相关问题时要围绕SAP定时任务的扩展,比如优化方法、日志分析、权限设置等,确保问题相关且有助于用户进一步学习。</think>### SAP系统定时任务配置指南 #### 一、基础配置步骤 1. **创建作业** 使用事务码`SM36`进入作业定义界面,按以下步骤操作: - 输入作业名称(格式建议:`Z<自定义标识>_<日期>`) - 选择作业类(默认`C`类为普通后台任务) - 指定目标服务器(若需负载均衡则留空) 2. **定义执行程序** - 点击"步骤"标签页 ➔ 添加ABAP程序/外部命令 - 示例配置: ```abap 程序名称:ZJOB_EXAMPLE 变量参数:P_DATE=$date$ //使用$符号定义动态变量[^2] ``` 3. **设置时间计划** - 在"开始条件"标签页选择: - **立即执行**:单次任务 - **周期性作业**:按规则重复,例如: $$每日间隔 = 24小时 \pm \Delta t \quad (\Delta t \leq 1小时)$$ - **特定日期/事件触发**:如月末结算 #### 二、高级配置方法 1. **外部作业调用** 通过`SM49/SM69`定义操作系统级命令,可调用服务器脚本: ```shell sapcontrol -nr 00 -function StartSystem ALL ``` 2. **批量输入配置** 使用程序`RSBDCSUB`创建批量输入会话,适用于需交互的任务自动化。 #### 三、监控与维护 1. **作业监控(SM37)** - 按状态筛选:已完成/已取消/运行中 - 查看日志:双击作业记录 ➔ 分析ABAP dump或性能数据 2. **异常处理** - 自动重试配置:在SM36设置"如果作业崩溃重新启动" - 邮件通知:通过`SBWP`配置作业状态提醒 #### 四、权限控制 - 必需权限对象: - `S_BTCH_ADM`(后台管理) - `S_BTCH_JOB`(作业操作) - 建议角色:`SAP_BC_BTC_DEVELOPER` ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值