Update ssh configuration doc

The main idea of this update is to make the configuration process
easier to read and follow.

Change-Id: I73cf811415900eaf99673de16f83ea7c9da16045
This commit is contained in:
Chen 2018-08-08 19:17:08 +08:00
parent 372f624893
commit d12449a91b

View File

@ -6,7 +6,7 @@ Configure SSH between compute nodes
.. todo:: .. todo::
Consider merging this into a larger "live-migration" document or to the Consider merging this into a larger "migration" document or to the
installation guide installation guide
If you are resizing or migrating an instance between hypervisors, you might If you are resizing or migrating an instance between hypervisors, you might
@ -14,6 +14,12 @@ encounter an SSH (Permission denied) error. Ensure that each node is configured
with SSH key authentication so that the Compute service can use SSH to move with SSH key authentication so that the Compute service can use SSH to move
disks to other nodes. disks to other nodes.
.. note::
It is not necessary that all the compute nodes share the same key pair.
However for the ease of the configuration, this document only utilizes a
single key pair for communication between compute nodes.
To share a key pair between compute nodes, complete the following steps: To share a key pair between compute nodes, complete the following steps:
#. On the first node, obtain a key pair (public key and private key). Use the #. On the first node, obtain a key pair (public key and private key). Use the
@ -28,14 +34,15 @@ To share a key pair between compute nodes, complete the following steps:
# usermod -s /bin/bash nova # usermod -s /bin/bash nova
Switch to the nova account. Ensure you can switch to the nova account:
.. code-block:: console .. code-block:: console
# su nova # su - nova
#. As root, create the folder that is needed by SSH and place the private key #. As root, create the folder that is needed by SSH and place the private key
that you obtained in step 1 into this folder: that you obtained in step 1 into this folder, and add the pub key to the
authorized_keys file:
.. code-block:: console .. code-block:: console
@ -43,29 +50,20 @@ To share a key pair between compute nodes, complete the following steps:
cp <private key> /var/lib/nova/.ssh/id_rsa cp <private key> /var/lib/nova/.ssh/id_rsa
echo 'StrictHostKeyChecking no' >> /var/lib/nova/.ssh/config echo 'StrictHostKeyChecking no' >> /var/lib/nova/.ssh/config
chmod 600 /var/lib/nova/.ssh/id_rsa /var/lib/nova/.ssh/authorized_keys chmod 600 /var/lib/nova/.ssh/id_rsa /var/lib/nova/.ssh/authorized_keys
echo <pub key> >> /var/lib/nova/.ssh/authorized_keys
#. Repeat steps 2-4 on each node. #. Copy the whole folder created in step 4 to the rest of the nodes:
.. note::
The nodes must share the same key pair, so do not generate a new key pair
for any subsequent nodes.
#. From the first node, where you created the SSH key, run:
.. code-block:: console .. code-block:: console
ssh-copy-id -i <pub key> nova@remote-host # scp -r /var/lib/nova/.ssh remote-host:/var/lib/nova/
This command installs your public key in a remote machine's
``authorized_keys`` folder.
#. Ensure that the nova user can now log in to each node without using a #. Ensure that the nova user can now log in to each node without using a
password: password:
.. code-block:: console .. code-block:: console
# su nova # su - nova
$ ssh *computeNodeAddress* $ ssh *computeNodeAddress*
$ exit $ exit