summaryrefslogtreecommitdiffstats
path: root/bin/ansible-connection
diff options
context:
space:
mode:
authorGanesh Nalawade <ganesh634@gmail.com>2017-12-15 05:51:56 +0100
committerGitHub <noreply@github.com>2017-12-15 05:51:56 +0100
commit2f932d8767d3e2c509eda1aa132bc4851c8d6da7 (patch)
tree6618687c1e2687bd97eaa90e724816408d65857d /bin/ansible-connection
parentAdd idempotency in snapshot creation (#28466) (diff)
downloadansible-2f932d8767d3e2c509eda1aa132bc4851c8d6da7.tar.xz
ansible-2f932d8767d3e2c509eda1aa132bc4851c8d6da7.zip
Add parent pid to persistent connection socket path hash (#33518)
* Add parent pid to persistent connection socket path hash Fixes #33192 * Add parent pid in persistent connection socket path hash to avoid using same socket path for multiple simultaneous connection to same remote host. * Ensure unique persistent socket path for each ansible-playbook run * Fix CI failures
Diffstat (limited to 'bin/ansible-connection')
-rwxr-xr-xbin/ansible-connection12
1 files changed, 7 insertions, 5 deletions
diff --git a/bin/ansible-connection b/bin/ansible-connection
index 5a1221715f..703352e49f 100755
--- a/bin/ansible-connection
+++ b/bin/ansible-connection
@@ -40,7 +40,7 @@ class ConnectionProcess(object):
The connection process wraps around a Connection object that manages
the connection to a remote device that persists over the playbook
'''
- def __init__(self, fd, play_context, socket_path, original_path):
+ def __init__(self, fd, play_context, socket_path, original_path, ansible_playbook_pid=None):
self.play_context = play_context
self.socket_path = socket_path
self.original_path = original_path
@@ -52,6 +52,7 @@ class ConnectionProcess(object):
self.sock = None
self.connection = None
+ self._ansible_playbook_pid = ansible_playbook_pid
def start(self):
try:
@@ -65,8 +66,8 @@ class ConnectionProcess(object):
# find it now that our cwd is /
if self.play_context.private_key_file and self.play_context.private_key_file[0] not in '~/':
self.play_context.private_key_file = os.path.join(self.original_path, self.play_context.private_key_file)
-
- self.connection = connection_loader.get(self.play_context.connection, self.play_context, '/dev/null')
+ self.connection = connection_loader.get(self.play_context.connection, self.play_context, '/dev/null',
+ ansible_playbook_pid=self._ansible_playbook_pid)
self.connection.set_options()
self.connection._connect()
self.connection._socket_path = self.socket_path
@@ -244,7 +245,8 @@ def main():
if rc == 0:
ssh = connection_loader.get('ssh', class_only=True)
- cp = ssh._create_control_path(play_context.remote_addr, play_context.port, play_context.remote_user, play_context.connection)
+ ansible_playbook_pid = sys.argv[1]
+ cp = ssh._create_control_path(play_context.remote_addr, play_context.port, play_context.remote_user, play_context.connection, ansible_playbook_pid)
# create the persistent connection dir if need be and create the paths
# which we will be using later
@@ -268,7 +270,7 @@ def main():
try:
os.close(r)
wfd = os.fdopen(w, 'w')
- process = ConnectionProcess(wfd, play_context, socket_path, original_path)
+ process = ConnectionProcess(wfd, play_context, socket_path, original_path, ansible_playbook_pid)
process.start()
except Exception:
messages.append(traceback.format_exc())