Browse Source

Enable Ansible ssh pipelining to speedup deployment

https://docs.ansible.com/ansible/intro_configuration.html#pipelining
Lénaïc Huard 9 years ago
parent
commit
51b2ebf466

+ 15 - 0
bin/cluster

@@ -34,6 +34,8 @@ class Cluster(object):
             os.environ['ANSIBLE_HOST_KEY_CHECKING'] = 'False'
             os.environ['ANSIBLE_HOST_KEY_CHECKING'] = 'False'
             # TODO: A more secure way to proceed would consist in dynamically
             # TODO: A more secure way to proceed would consist in dynamically
             # retrieving the ssh host public keys from the IaaS interface
             # retrieving the ssh host public keys from the IaaS interface
+        if 'ANSIBLE_SSH_PIPELINING' not in os.environ:
+            os.environ['ANSIBLE_SSH_PIPELINING'] = 'True'
 
 
     def get_deployment_type(self, args):
     def get_deployment_type(self, args):
         """
         """
@@ -284,7 +286,20 @@ if __name__ == '__main__':
     cluster = Cluster()
     cluster = Cluster()
 
 
     parser = argparse.ArgumentParser(
     parser = argparse.ArgumentParser(
+        formatter_class=argparse.RawDescriptionHelpFormatter,
         description='Python wrapper to ensure proper configuration for OpenShift ansible playbooks',
         description='Python wrapper to ensure proper configuration for OpenShift ansible playbooks',
+        epilog='''\
+This wrapper is overriding the following ansible variables:
+
+  * ANSIBLE_SSH_ARGS:
+      If not set in the environment, this wrapper will use the following value:
+      `-o ForwardAgent=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ControlMaster=auto -o ControlPersist=600s`
+      If set in the environment, the environment variable value is left untouched and used.
+
+  * ANSIBLE_SSH_PIPELINING:
+      If not set in the environment, this wrapper will set it to `True`.
+      If you experience issue with Ansible ssh pipelining, you can disable it by explicitely set this environment variable to `False`.
+'''
     )
     )
     parser.add_argument('-v', '--verbose', action='count',
     parser.add_argument('-v', '--verbose', action='count',
                         help='Multiple -v options increase the verbosity')
                         help='Multiple -v options increase the verbosity')

+ 4 - 0
playbooks/openstack/openshift-cluster/files/heat_stack.yaml

@@ -598,6 +598,10 @@ resources:
               template: |
               template: |
                 #cloud-config
                 #cloud-config
                 write_files:
                 write_files:
+                  - path: /etc/sudoers.d/00-openshift-no-requiretty
+                    permissions: 440
+                    content: |
+                      Defaults:openshift !requiretty
                   - path: /etc/sysconfig/network-scripts/ifcfg-eth0
                   - path: /etc/sysconfig/network-scripts/ifcfg-eth0
                     content: |
                     content: |
                       DEVICE="eth0"
                       DEVICE="eth0"

+ 6 - 0
playbooks/openstack/openshift-cluster/files/user-data

@@ -5,3 +5,9 @@ system_info:
   default_user:
   default_user:
     name: openshift
     name: openshift
     sudo: ["ALL=(ALL) NOPASSWD: ALL"]
     sudo: ["ALL=(ALL) NOPASSWD: ALL"]
+
+write_files:
+  - path: /etc/sudoers.d/00-openshift-no-requiretty
+    permissions: 440
+    content: |
+      Defaults:openshift !requiretty