Current location - Quotes Website - Collection of slogans - How to Install Deployment Settings SVN Server on windows
How to Install Deployment Settings SVN Server on windows
Tools/raw materials

Operating system: Windows2003, 32-bit

SVN server version: svn-win32- 1.6. 16.

SVN client version: Tortoisesvn-1.6.16.5438+0511.

Methods/steps

I. Preparatory work

1, SVN server: decompression package, you can download the latest version from official website.

2.SVN client: TortoiseSVN, commonly known as Little Tortoise, is a client program used to communicate with the server.

Secondly, install the server and client programs.

1, SVN server: just unzip it to a folder. Sample path: c:\svn\

Note: If you download the msi program, just run it and follow the prompts to install it.

2.SVN client: run it directly and install it according to the prompts. Example path: C:\Program Files\Subversion.

Third, build a version library: sample path: e:\svnroot. There are two ways to build a version library:

Method 1: create an empty directory e:\svnroot\repos 1, enter the repos 1 folder, right-click in the blank space and select "Tortoisesvn->; Create a warehouse here ... ",

Method 2: Create an empty directory e:\svnroot\repos2, enter the DOS command line and enter the following command:

svnadmin create e:\ SVN root \ repos 2

Fourth, run the SVN server and start the service. There are two ways to start the service:

Method 1: Start the service temporarily and enter the following command under DOS:

Svnserver-d-r e: \ svnroot \ repos1-listen-host IP address-listen-port= = port number.

Description: "Listening Host" and "Listening Port" are optional. The default port is 3690. If the port is already occupied, you can specify the port number through the option listen-port.

Note: Please do not close the command line window. Closing the window will stop the svn service.

Method 2, start the SVN service to run the program in the background:

sc create SVN server bin path = " c:\ SVN \ bin \ SVN server . exe-service-r e:\ SVN root \ repos 1 " display name = " Subversion " depend = Tcpip start = auto

Description 1:

(1)sc is a service configurator that comes with windows. Svnserve is the name of the service, which can be named according to the requirements.

(2) The parameter binPath indicates the installation path of the svnserve executable file.

(3)-service means running as a windows service, -r means the location of svnrepository, and both the service parameter and the r parameter are part of binPath, so they are enclosed with the path of svnserve.exe in a pair of double quotation marks.

(4)displayname indicates the name displayed in the windows service list, dependent = tcpip indicates that the operation of svnserve service requires tcpip service, and start=auto indicates that it will run automatically after startup. After installing the service, svnserve will not run automatically until the next boot.

Note 2:

(1)binPath has no spaces before the equal sign and spaces after it. The same is true for displayname, dependent and start. Service is preceded by-,not-,and R is preceded by-.

(2) To uninstall the svn service, just execute sc delete svnserve.

(3) From "sc" to "auto" in the same command sc, they must be written on the same line.

(4) Start service command: net start svnserve, and stop service command: net start svnserve. You can also enter the interface provided by Windows to operate SVNService, that is, Control Panel > Services.

(5) If the path contains spaces, the "\" symbol must be used to deal with "\". For example, in the above example, if svnserve.exe is in "c:\programfiles\svn", the command should be written as "bin path =" \ "c: \ program files \ SVN \ bin \ svnserve.exe." .

Verb (abbreviation for verb) configures users and permissions.

(1) modify svnserve.conf, and open svnserve.conf with a text editor in the e:\svn\repos 1\conf directory:

Will:

# Anonymous Access = Read

# Grant Access = Write

# password-db = password

replace

Anonymous access = read

Authorized access = write

Password -db = passwd

note:

There is no space in front of the column, such as anon-access.

Anon-access = read means that access without user name and password has only read permission. If you change it to None, you can't access it without a username and password.

Auth-access = write means that you have write permission to log in by user name and password (of course, you have read permission).

Password-db = passwd means that users can be added to the passwd file through username = password.

(2) Modify the passwd file in the same directory and add a user account:

Will:

[user]

# harry = harryssecret

# sally = sallyssecret

Add account:

[user]

# harry = harryssecret

# sally = sallyssecret

Management = management

Add an administrator account with the password admin.

6. Initialize SVN and import data.

Select the folder to upload SVN, and right click-> TortoiseSVN-& gt; Import ... "and enter" SVN://localhost/project1/"in the URL of the resource library in the pop-up dialog box. Enter comments in "Importmessage", click OK, and ask for the account number, account administrator and password administrator.

Seven, test SVN

Local test: create an empty folder test 1, right-click, select "SVN Check Out", and enter "SVN://localhost/project1"in "Resource Library URL".

Other machine tests: if the IP address of the host running svnserve is 1.2.3.4, then the content of URL input is "SVN:/1.2.3.4/project1".

Linux SVN server configuration and client use

20 10-09-23 1 1:32:07

Label: Linux server SVN leisure client

Introduction to SVN

SVN is a version management system, formerly CVS, which is the cornerstone of open source software. Even in the case of adequate communication, many people will be confused when maintaining the same source code. Version management system is to solve these problems.

Some concepts of SVN:

A. repository (source code repository)

Wherein the source code is stored in a unified way.

B. Inspection (extraction)

When you don't have the source code, you need a copy of checked out from the repository.

C. Submit (submit)

When you modify the code, you need to submit it to the repository.

D. Update (update)

When you check out a source code, you can synchronize it with the source code in the repository by updating, and the code in your hand will have the latest changes.

The daily development process is actually like this (assuming you have checked out for a few days): update (get the latest code)-> Make your own modifications and debug successfully-> Submit (everyone can see your changes)

What if two programmers modify the same file at the same time? SVN can merge the changes of these two programmers, yes, merge. In fact, SVN manages the source code as a unit of action, which means that as long as two programmers don't modify the same line of programs, SVN will automatically merge the two modifications. If it is the same line, SVN will prompt that the file conflicts and needs to be confirmed manually.

Introduction of tortoise

TortoiseSVN is a free and open source client of Subversion version version control system, which can manage files and directories over time. Files are stored in the central version library, which is very similar to ordinary file servers except that it can remember every modification of files and directories. You can restore files to previous versions, and you can see what changes have been made to the data and who made them by looking at the history. This is why many people regard subversion and version control system as a "time machine".

Configuration of SVN

1, configure yum, and check subversion installation package.

[root @ SVN ~]# yum list | grep subversion

subversion . i386 1 . 4 . 2-4 . el5 _ 3. 1 base

subversion-devel . i386 1 . 4 . 2-4 . el5 _ 3. 1 base

subversion-javahl . i386 1 . 4 . 2-4 . el5 _ 3. 1 base

subversion-perl . i386 1 . 4 . 2-4 . el5 _ 3. 1 base

subversion-ruby . i386 1 . 4 . 2-4 . el5 _ 3. 1 base

[root@svn ~]# yum -y Install subversion

Test whether the installation was successful:

# svnserver-versionEnter to display the version description. Installation succeeded.

[root@svn ~]# netstat -nat to see if the default TCP 3690 port is listening.

2. Create svn version library

[root @ SVN/]# mkdir-p/data/SVN data

[root @ svn/] # svnadmincreate/data/svndata/winnewanne is the name of the version library.

3.3. Overview of svnserve Configuration File

The SVN server. conf-SVN service configuration file is located in the conf directory of the version library directory.

Passwd-user name and password files, specified in the file svnserve.conf, are located in the same directory by default.

The Authz-permission configuration file, which is also specified in the svnserve.conf file by default, is located in the same directory.

Conf/SVN server. conf file

Configuration items are divided into the following five items:

Anon-access controls the access rights of unauthenticated users to the version library.

Auth-access controls the access rights of authenticated users to the version library.

Password-db specifies the user name, password and file name.

Authz-db specifies the file name of permission configuration, through which path-based access control can be realized.

Realm specifies the authentication domain of the version library, that is, the authentication domain name prompted at login. If these two versions of the library

The authentication domains are the same, so it is recommended to use the same user name and password data file.

Note: bug of anon-access = read parameter in 1.4 version.

When anonymous access = read

When the client checks out, the error "No right to open the root directory of editing operation" will appear, and the parameter "None" will be normal.

Configuration/password file

User 1 = user 1

User 2 = User 2

Conf /authz file

[Group] Set up a group

admin = user 1

[/] root permission setting (i.e. folder "svndata")

The permissions of User 1 = rw User 1 are: read and write.

User 2 = user 2 permissions are: readable, not writable.

@admin = rw Set group permissions

[svndata:/winne] Set the permissions of the "winne" folder under the root directory.

user 1 = rw

User 2 = r

... and so on

4. Start and stop the SVN service.

Start SVN service:

[root @ SVN ~]# SVN serve-d-r/data/SVN data/

-d stands for background operation.

-r specifies that the root directory is /data/svndata/

Stop SVN service:

Ps -aux |grep service

Kill -9 process kills

Client use

Using Windows client TortoiseSVN

1, install the Tortoisesvn client.

TortoiseSVN 1.6.5 client payment Chinese localization package was selected for the test.

2. The file of the client is updated to the server (user 1 operation)

Create a new empty directory, and then right-click Checkout.

SVN:// 192. 168. 103.26/winne

Just enter an authorized user account in the passwd file.

Add some file tests to the directory. Then right-click Tortoisesvn->; ADD adds the list to the server. At this point, it is not actually copied to the server, and it will only be copied after submitting the operation.

You can see the file just submitted in the version library browser. The submitted version is 1.

3. The client pulls and reads data on the server (user2 operation).

User2 creates an empty directory on the machine and right-clicks Checkout.

Fill in the address: SVN:/192.168.103.26/Winne and output it to G:\user2 for confirmation.

Add a new.txt file, and then you will be prompted with permission error after submission. User2 has no permission to write, and it can only be submitted successfully if it is changed to user 1.

Use of Linux client

The client operation process is generally:

User a: checkout->; Add (add new file)-> Submit (submit)

User B: SVN log (view updates)->; Update (updated version)

Installation of SVN 1

Y install subversion

2. Common commands of 2.Linux SVN

This command is abbreviated in ().

Checkout (total) withdrawal

Submit (ci) submit

Update (up)

List list

3. checkout (co) to extract the files on the svn server.

(user 1) operation flow

[root @ TEST ~]# SVN co SVN:// 192. 168. 103.26/winne

Authentication domain:< SVN:/192.168.103.26: 3690 > My first warehouse.

Password for "root":

Authentication domain:< SVN:/192.168.103.26: 3690 > My first warehouse.

User name: user 1/ Enter the user name.

Password of "User 1"::/Enter the password.

Victory/a trip to the universe

a winne/200707 16 17 1657 126 . pdf

winne/svnbook.pdf

Revised version 1. /checkout (co) was successfully extracted, and the checked-out version is 1.

Note: User name and password can be used for access:

Svn common username user 1-password user1SVN:/192.168.103.26/Winne

[root@TEST ~]# ll

Drwxr-xr-x3rootrout 4096 sep23 09: 02 Winne/Winne directory is automatically generated by SVN.

Drwxr-xr-x2root root 4096 jul 30 02: 06 task

[root@TEST ~]# cd winne

[root@TEST winne]# ll

Total 2868

-rw-r-r- 1 root root 1566968 Sep 23 08:53 200707 16 17 1657 126 . pdf

-rw-r-r-1rootroot2397sepa23 08: 53 Cosmic Journey-BeFour.lrc

-rw-r-r-1rootroot1354300 September 23, 08: 53 svnbook.pdf.

4. The user 1 modifies the file and submits it.

[root@TEST winne]# vi testsvn.txt

Add testsvn.txt/Add testsvn.txt to the library.

A testsvn.txt

[root @ testwinne] # svncommit-m "test" testsvn.txt/comments is testing.

Add testsvn.txt

Transfer file data.

Revision 2 has been submitted. The/version has been updated to 2.

5. User 2 updated the version of the window client.

Go back to the Windows client and check the log. Version has been updated to 2. Note that tests and client updates can be updated to the new version.

6. Version rollback of 6.Windows client.

Select Update to Version from the menu, and then select version 1.

7.Linux version rollback operation:

[root @ TEST winne]# SVN up-r 1