WARNING: This is the _old_ Lustre wiki, and it is in the process of being retired. The information found here is all likely to be out of date. Please search the new wiki for more up to date information.

Accessing Lustre Code: Difference between revisions

From Obsolete Lustre Wiki
Jump to navigationJump to search
 
(68 intermediate revisions by 3 users not shown)
Line 1: Line 1:
We welcome and encourage contributions to the development and testing of a more robust, feature-rich Lustre. Three options are available for accessing Lustre code:
<small>''(Updated: Jan 2010)''</small>
* ''Anonymous access''. You can obtain Lustre source code by [[#Accessing the Open CVS repository|Accessing the Open CVS repository]]. When using this option, you will have read-only access to the code. See [[Contribution Landing Page]] for how to submit code.


* ''Read/write access''. With a password-protected account, you can check out Lustre source code by [[#Accessing the Lustre CVS repository|Accessing the Lustre CVS repository]]. After signing a Contributor Agreement (see our Contribution Policy),  you will be able to submit changes directly to the Lustre code.
'''''NOTICE:'''''  The transition from CVS to Git took place on Monday, December 14. For more information about the transition, see the [[Git Transition Notice]]. For details about how to migrate to Git, see [[Migrating to Git]].


* ''Authorized access''. Obtaining Lustre source code by [[#Accessing the External Lustre CVS repository|Accessing the External Lustre CVS repository]] requires a password-protected account and authorization from Sun Microsystems.
----


For all these options, the Concurrent Versions System (CVS) must be installed on your local system. For more information about CVS, see [http://www.nongnu.org/cvs CVS - Concurrent Versions System].
We welcome and encourage contributions to the development and testing of a more robust, feature-rich Lustre™. You can obtain the latest bleeding-edge Lustre source code by anonymous Git access.


''[[Note]]:'' If you have questions or experience problems with using any of these options, send email to [mailto:cvs-admin@cvs.lustre.org cvs-admin@cvs.lustre.org]
git clone git://git.lustre.org/prime/lustre.git


=== Naming conventions ===
'''''Note:''''' For more information about using Git, including tutorials and guides to help you get started, see the [http://git-scm.com/documentation Git documentation] page. ''For descriptions of the commands you are most likely to need, see the Commands section  at the bottom of this page.''


Stable development branches are named b''{major}''_''{minor}'' (for example, b1_6 and b1_8). Even-numbered minor releases are considered stable releases.  Odd-numbered minor releases correspond to alpha and beta releases and will sometimes be given v''{major}''_''{minor}''_''{patch}'' tags to provide a point of reference for internal and external testing.
See [[Contribute]] for more information about developing, testing, and submitting a patch to the Lustre code.


A release branch is created an official release to isolate it from further development and named b_release_''{major}''_''{minor}''_''{patch}'' (for example, b_release_1_8_0). A final release gets a tag in the form v''{major}''_''{minor}''_''{patch}'' (for example, v1_8_0 or v1_6_7_1).
'''''Note:''''' If you have questions or experience problems, send email to the [mailto:lustre-wiki-feedback@sun.com Admins].


Long-range development is done on the HEAD branch.
For more information about Git, see the [http://git-scm.com/ Git home]


== Accessing the Open CVS repository ==
=== Naming conventions ===
The Open CVS repository allows anonymous, read-only access to the Lustre code. See [[Contribution Landing Page]] for more information about submitting a patch to the Lustre code.


You can check out any of the following Lustre modules from the Open CVS repository:
Stable development branches are named b''{major}''_''{minor}'' (for example, b1_6 and b1_8). Even-numbered minor releases are considered stable releases. Odd-numbered minor releases correspond to alpha and beta releases and will sometimes be given v''{major}''_''{minor}''_''{patch}'' tags to provide a point of reference for internal and external testing.
*lustre
*ldiskfs
*libsysio
*lnet
*lustre-build (as .../build)
*lustre-core (as .../lustre)
*lustre-snmp (as .../snmp)


=== Checking out code from Open CVS ===
A release branch is created an official release to isolate it from further development and named b_release_''{major}''_''{minor}''_''{patch}'' (for example, b_release_1_8_0).  A final release gets a tag in the form v''{major}''_''{minor}''_''{patch}'' (for example, v1_8_0 or v1_6_7_1).
To check out Lustre source code from the Open CVS repository, complete these steps.
 
1.  Set CVSROOT in your environment by entering one of these commands:
:pserver:anonymous@cvs.lustre.org:/lustre
:or
cvs -d :pserver:anonymous@cvs.lustre.org:/lustre login
 
2.  Log in to CVS. If a password is requested, hit <enter> to continue.
cvs login
 
3.  Check out the lustre source.
cvs co lustre
 
4.  Check out lustre modules.
cd lustre
./lustrecvs b1_6
:In this example, modules for Release 1.6 are checked out.
 
=== Example ===
In this example, all sources are checked out into ''~/tmp''.
 
<code>
[[cfaber@atitude]]:~$ '''cd tmp'''
cfaber@atitude:~/tmp$ '''cvs -d :pserver:anonymous@cvs.lustre.org:/lustre login'''
Logging in to :pserver:anonymous@cvs.lustre.org:2401/lustre
CVS password:      <font color="red">''(Leave blank, hit <Enter>)''</font>
</code>
<code>
cfaber@atitude:~/tmp$ '''cvs -d :pserver:anonymous@cvs.lustre.org:/lustre co lustre'''
  cvs checkout: Updating lustre
U lustre/.cvsignore
U lustre/COPYING
U lustre/ChangeLog
U lustre/Makefile.in
U lustre/README
U lustre/README.lustrecvs
U lustre/autoMakefile.am
U lustre/autogen.sh
U lustre/configure.ac
U lustre/lustre.spec.in
U lustre/lustrecvs
</code>
<code>
cfaber@atitude:~/tmp$ '''cd lustre'''
cfaber@atitude:~/tmp/lustre$ '''./lustrecvs b1_6'''
You can also use ''lustrecvs HEAD'' [[for]] '''[[to check out?]]''' the HEAD [[release]]''
lustrecvs: updating lustrecvs
cvs update: Updating .
lustrecvs: Checking out build from b1_6
cvs checkout: Updating build
U build/.cvsignore
U build/Makefile
U build/README.kernel-source
U build/Rules.in
U build/autoMakefile.am
U build/autoMakefile.am.toplevel
.........
</code>
 
== Accessing the Lustre CVS repository ==
 
The Lustre CVS repository allows read/write access to Lustre code.
 
[[This page contains instructions for obtaining CVS versions of Lustre,]] '''[[as well as migrating checkouts from sourceforge to the new CVS server.]]'''
 
 
 
=== Checking out code from Lustre CVS ===
 
To check out Lustre source code from the Lustre CVS repository, complete these steps.
 
1. Test that your account is working by logging into [https://bugzilla.lustre.org/userprefs.cgi bugzilla]. CVS and bugzilla share the same account information. 
 
2. To upload a public ssh key to use in place of typing in a password, go to bugzilla's [http://bugzilla.lustre.org/userprefs.cgi user preferences].  If there is no "Change Public SSH key" field,send email to [mailto:cvs-admin@cvs.lustre.org cvs-admin@cvs.lustre.org]. (''Note:'' Currently, only SSH2 keys are supported.)
 
3. Set the ''CVS_RSH'' environment variable.
 
: For bash users, enter: <pre>export CVS_RSH=ssh</pre> 
: For csh users, enter: <pre>setenv CVS_RSH ssh</pre>
 
: Consider setting ''CVS_RSH'' in your .bashrc or .cshrc.
 
4. Check out lustre by running the following (change ''youraccountname'' to your cvs account name, as specified on the [https://bugzilla.lustre.org/userprefs.cgi user preferences page]):
 
<pre>
$ cvs -d :ext:''youraccountname''@cvs.lustre.org:/cvsroot/cfs co lustre
$ cd lustre
$ ./lustrecvs b1_8
</pre>
 
=== Problems ===
 
Not working as you expected?  Do you think you should have CVS access, but don't?  Send email to cvs-admin@cvs.lustre.org [[Ask Robert Read if email address is still valid - for all three?.]]
 
== Accessing the Lustre External CVS repository ==
 
The Lustre External CVS repository read-only access by authorized users to proprietary Lustre code. This read-only repository is synchronized with the CFS internal CVS every three hours.
 
==== Legal Notice ====
 
: All software obtained from this CVS repository is considered pre-release proprietary software and is therefore confidential information.  You may not redistribute any software obtained from this CVS repository and must destroy all copies upon request.
 
: Unless otherwise authorized, you have a limited license to read, modify, compile, and use [[software obtained from this CVS repository?]] in a non-production test environment.
 
: If you do not agree with these restrictions, ''do not use the CVS repository''. Please email us to have your account disabled.
 
=== Checking out code from Lustre External CVS ===
To check out Lustre source code from the Lustre External CVS repository, complete these steps.
 
1. Check out the top-level lustre directory, where {username} is your Bugzilla account id. When prompted for a password, enter your Bugzilla password.
 
: <pre>
: $ cvs -d {username}@cvs.clusterfs.com:/cvsroot/lustre-external co lustre
</pre>
 
 
2. [[Get the desired CVS tag]]
 
: Download the Lustre source tree [[from the desired CVS tag]] using the lustrecvs script, where ''&lt;tag or branch&gt;'' is a valid Lustre branch or tag name (e.g. b1_8, HEAD)
 
: <pre>
: $ cd /your/cvs/checkout/lustre
: $ ./lustrecvs ''&lt;tag or branch&gt;''
</pre>


Work for the next upcoming version is done on the ''master'' branch.


'''''Note''''': To update the tree or to change branches, run the "lustrecvs &lt;tag&gt;" command again. Do NOT use "cvs update".
The Lustre [[Subsystem Map]] describes each of the subsystems in the Lustre code.

Latest revision as of 12:10, 20 January 2011

(Updated: Jan 2010)

NOTICE: The transition from CVS to Git took place on Monday, December 14. For more information about the transition, see the Git Transition Notice. For details about how to migrate to Git, see Migrating to Git.


We welcome and encourage contributions to the development and testing of a more robust, feature-rich Lustre™. You can obtain the latest bleeding-edge Lustre source code by anonymous Git access.

git clone git://git.lustre.org/prime/lustre.git 

Note: For more information about using Git, including tutorials and guides to help you get started, see the Git documentation page. For descriptions of the commands you are most likely to need, see the Commands section at the bottom of this page.

See Contribute for more information about developing, testing, and submitting a patch to the Lustre code.

Note: If you have questions or experience problems, send email to the Admins.

For more information about Git, see the Git home

Naming conventions

Stable development branches are named b{major}_{minor} (for example, b1_6 and b1_8). Even-numbered minor releases are considered stable releases. Odd-numbered minor releases correspond to alpha and beta releases and will sometimes be given v{major}_{minor}_{patch} tags to provide a point of reference for internal and external testing.

A release branch is created an official release to isolate it from further development and named b_release_{major}_{minor}_{patch} (for example, b_release_1_8_0). A final release gets a tag in the form v{major}_{minor}_{patch} (for example, v1_8_0 or v1_6_7_1).

Work for the next upcoming version is done on the master branch.

The Lustre Subsystem Map describes each of the subsystems in the Lustre code.