summaryrefslogtreecommitdiffstats
path: root/src/ceph/doc/install/clone-source.rst
blob: 9ed32c027f34599d6ba85f220e38f92d55846f2d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
=========================================
 Cloning the Ceph Source Code Repository
=========================================

You may clone a Ceph branch of the Ceph source code by going to `github Ceph
Repository`_,  selecting a branch (``master`` by default), and clicking the
**Download ZIP** button.

.. _github Ceph Repository: https://github.com/ceph/ceph


To clone the entire git repository, install and configure ``git``.


Install Git
===========

To install ``git`` on Debian/Ubuntu, execute::

	sudo apt-get install git


To install ``git`` on CentOS/RHEL, execute::

	sudo yum install git


You must also have a ``github`` account. If you do not have a
``github`` account, go to `github.com`_ and register.
Follow the directions for setting up git at 
`Set Up Git`_.

.. _github.com: http://github.com
.. _Set Up Git: http://help.github.com/linux-set-up-git


Add SSH Keys (Optional)
=======================

If you intend to commit code to Ceph or to clone using SSH
(``git@github.com:ceph/ceph.git``), you must generate SSH keys for github. 

.. tip:: If you only intend to clone the repository, you may 
   use ``git clone --recursive https://github.com/ceph/ceph.git`` 
   without generating SSH keys.

To generate SSH keys for ``github``, execute::

	ssh-keygen

Get the key to add to your ``github`` account (the following example
assumes you used the default file path)::

	cat .ssh/id_rsa.pub

Copy the public key.

Go to your ``github`` account, click on "Account Settings" (i.e., the
'tools' icon); then, click "SSH Keys" on the left side navbar.

Click "Add SSH key" in the "SSH Keys" list, enter a name for the key, paste the
key you generated, and press the "Add key" button.


Clone the Source
================

To clone the Ceph source code repository, execute::

	git clone --recursive https://github.com/ceph/ceph.git

Once ``git clone`` executes, you should have a full copy of the Ceph 
repository.

.. tip:: Make sure you maintain the latest copies of the submodules
   included in the repository. Running ``git status`` will tell you if
   the submodules are out of date.

::

	cd ceph
	git status

If your submodules are out of date, run::

	git submodule update --force --init --recursive

Choose a Branch
===============

Once you clone the source code and submodules, your Ceph repository 
will be on the ``master`` branch by default, which is the unstable 
development branch. You may choose other branches too.

- ``master``: The unstable development branch.
- ``stable``: The bugfix branch.
- ``next``: The release candidate branch.

::

	git checkout master