diff --git a/ansible/roles/designate/tasks/bootstrap.yml b/ansible/roles/designate/tasks/bootstrap.yml
index 09bc6ceafb24de8b402245d215d8404a6781d8c6..30d52840fe0d59d59708a8b59a3a59a621f21dd7 100644
--- a/ansible/roles/designate/tasks/bootstrap.yml
+++ b/ansible/roles/designate/tasks/bootstrap.yml
@@ -1,79 +1,40 @@
 ---
-- name: Creating Designate database
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_db
-    -a "login_host='{{ database_address }}'
-        login_port='{{ database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ designate_database_name }}'"
+- name: Creating Designate databases
+  kolla_toolbox:
+    module_name: mysql_db
+    module_args:
+      login_host: "{{ database_address }}"
+      login_port: "{{ database_port }}"
+      login_user: "{{ database_user }}"
+      login_password: "{{ database_password }}"
+      name: "{{ item }}"
   register: database
-  changed_when: "{{ database.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: database.stdout.split()[2] != 'SUCCESS'
   run_once: True
   delegate_to: "{{ groups['designate-central'][0] }}"
+  with_items:
+    - "{{ designate_database_name }}"
+    - "{{ designate_pool_manager_database_name }}"
 
-- name: Reading json from variable
-  set_fact:
-    database_created: "{{ (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-
-- name: Creating Designate Pool Manager database
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_db
-    -a "login_host='{{ database_address }}'
-        login_port='{{ database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ designate_pool_manager_database_name }}'"
-  register: database_pool_manager
-  changed_when: "{{ database.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: database.stdout.split()[2] != 'SUCCESS'
-  run_once: True
-  delegate_to: "{{ groups['designate-central'][0] }}"
-
-- name: Reading json from variable
-  set_fact:
-    database_pool_manager_created: "{{ (database_pool_manager.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-
-- name: Creating Designate database user and setting permissions
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_user
-    -a "login_host='{{ database_address }}'
-        login_port='{{ database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ designate_database_name }}'
-        password='{{ designate_database_password }}'
-        host='%'
-        priv='{{ designate_database_name }}.*:ALL'
-        append_privs='yes'"
-  register: database_user_create
-  changed_when: "{{ database_user_create.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (database_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: database_user_create.stdout.split()[2] != 'SUCCESS'
-  run_once: True
-  delegate_to: "{{ groups['designate-central'][0] }}"
-
-- name: Creating Designate Pool Manager database user and setting permissions
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_user
-    -a "login_host='{{ database_address }}'
-        login_port='{{ database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ designate_pool_manager_database_name }}'
-        password='{{ designate_pool_manager_database_password }}'
-        host='%'
-        priv='{{ designate_pool_manager_database_name }}.*:ALL'
-        append_privs='yes'"
-  register: database_pool_manager_user_create
-  changed_when: "{{ database_pool_manager_user_create.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (database_pool_manager_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: database_pool_manager_user_create.stdout.split()[2] != 'SUCCESS'
+- name: Creating Designate databases user and setting permissions
+  kolla_toolbox:
+    module_name: mysql_user
+    module_args:
+      login_host: "{{ database_address }}"
+      login_port: "{{ database_port }}"
+      login_user: "{{ database_user }}"
+      login_password: "{{ database_password }}"
+      name: "{{ item.database_name }}"
+      password: "{{ item.database_password }}"
+      host: "%"
+      priv: "{{ item.database_name }}.*:ALL"
+      append_privs: "yes"
   run_once: True
   delegate_to: "{{ groups['designate-central'][0] }}"
+  with_items:
+    - database_name: "{{ designate_database_name }}"
+      database_password: "{{ designate_database_password }}"
+    - database_name: "{{ designate_pool_manager_database_name }}"
+      database_password: "{{ designate_pool_manager_database_password }}"
 
 - include: bootstrap_service.yml
-  when: database_created
+  when: database.changed
diff --git a/ansible/roles/panko/tasks/bootstrap.yml b/ansible/roles/panko/tasks/bootstrap.yml
index 8412c333a2311d5600ae9506192f003003a88fd8..7870011ba3066344b5dfdb65fb760534e959b11e 100644
--- a/ansible/roles/panko/tasks/bootstrap.yml
+++ b/ansible/roles/panko/tasks/bootstrap.yml
@@ -10,60 +10,38 @@
   when:
     - panko_database_type == "mongodb"
 
-- name: Checking Panko mysql database
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_db
-    -a "login_host='{{ panko_database_mysql_address }}'
-        login_port='{{ panko_database_port }}'
-        login_user='{{ panko_database_user }}'
-        login_password='{{ panko_database_password }}'
-        name='{{ panko_database_name }}'"
-  register: mysql_access
-  failed_when: False
-  changed_when: False
-  run_once: True
-  when:
-    - panko_database_type == "mysql"
-
-- name: Creating panko mysql database
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_db
-    -a "login_host='{{ panko_database_mysql_address }}'
-        login_port='{{ panko_database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ panko_database_name }}'"
+- name: Creating Panko mysql database
+  kolla_toolbox:
+    module_name: mysql_db
+    module_args:
+      login_host: "{{ panko_database_mysql_address }}"
+      login_port: "{{ panko_database_port }}"
+      login_user: "{{ database_user }}"
+      login_password: "{{ database_password }}"
+      name: "{{ panko_database_name }}"
   register: mysql_panko_database
-  changed_when: "{{ mysql_panko_database.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (mysql_panko_database.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: mysql_panko_database.stdout.split()[2] != 'SUCCESS'
   run_once: True
   delegate_to: "{{ groups['panko-api'][0] }}"
   when:
     - panko_database_type == "mysql"
-    - "'FAILED' in mysql_access.stdout"
 
-- name: Creating panko database user and setting permissions
-  command: docker exec -t kolla_toolbox /usr/bin/ansible localhost
-    -m mysql_user
-    -a "login_host='{{ panko_database_mysql_address }}'
-        login_port='{{ panko_database_port }}'
-        login_user='{{ database_user }}'
-        login_password='{{ database_password }}'
-        name='{{ panko_database_name }}'
-        password='{{ panko_database_password }}'
-        host='%'
-        priv='{{ panko_database_name }}.*:ALL'
-        append_privs='yes'"
-  register: database_user_create
-  changed_when: "{{ database_user_create.stdout.find('localhost | SUCCESS => ') != -1 and
-                    (database_user_create.stdout.split('localhost | SUCCESS => ')[1]|from_json).changed }}"
-  failed_when: database_user_create.stdout.split()[2] != 'SUCCESS'
+- name: Creating Panko mysql database user and setting permissions
+  kolla_toolbox:
+    module_name: mysql_user
+    module_args:
+      login_host: "{{ panko_database_mysql_address }}"
+      login_port: "{{ panko_database_port }}"
+      login_user: "{{ database_user }}"
+      login_password: "{{ database_password }}"
+      name: "{{ panko_database_name }}"
+      password: "{{ panko_database_password }}"
+      host: "%"
+      priv: "{{ panko_database_name }}.*:ALL"
+      append_privs: "yes"
   run_once: True
   delegate_to: "{{ groups['panko-api'][0] }}"
   when:
     - panko_database_type == "mysql"
-    - "'FAILED' in mysql_access.stdout"
 
  - include: bootstrap_service.yml
    when: ((panko_database_type == "mongodb" and mongodb_panko_database.changed)