Matrix Docker Ansible eploy
25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 

235 satır
8.3 KiB

  1. - name: Ensure dateutils and curl is installed in AWX
  2. delegate_to: 127.0.0.1
  3. yum:
  4. name: dateutils
  5. state: latest
  6. - name: Ensure dateutils, curl and jq intalled on target machine
  7. apt:
  8. pkg:
  9. - curl
  10. - jq
  11. state: present
  12. - name: Include vars in matrix_vars.yml
  13. include_vars:
  14. file: '/var/lib/awx/projects/clients/{{ member_id }}/{{ subscription_id }}/matrix_vars.yml'
  15. no_log: True
  16. - name: Collect size of Synapse database
  17. shell: du -sh /matrix/postgres/data
  18. register: db_size_before_stat
  19. no_log: True
  20. - name: Print before size of Synapse database
  21. debug:
  22. msg: "{{ db_size_before_stat.stdout.split('\n') }}"
  23. when: db_size_before_stat is defined
  24. - name: Collect the internal IP of the matrix-synapse container
  25. shell: "/usr/bin/docker inspect --format '{''{range.NetworkSettings.Networks}''}{''{.IPAddress}''}{''{end}''}' matrix-synapse"
  26. register: synapse_container_ip
  27. - name: Collect access token for janitor user
  28. shell: |
  29. curl -X POST -d '{"type":"m.login.password", "user":"janitor", "password":"{{ matrix_awx_janitor_user_password }}"}' "{{ synapse_container_ip.stdout }}:8008/_matrix/client/r0/login" | jq '.access_token'
  30. register: janitors_token
  31. no_log: True
  32. - name: Collect total number of rooms
  33. shell: |
  34. curl -X GET --header "Authorization: Bearer {{ janitors_token.stdout[1:-1] }}" '{{ synapse_container_ip.stdout }}:8008/_synapse/admin/v1/rooms' | jq '.total_rooms'
  35. when: purge_rooms|bool
  36. register: rooms_total
  37. - name: Print total number of rooms
  38. debug:
  39. msg: '{{ rooms_total.stdout }}'
  40. when: purge_rooms|bool
  41. - name: Calculate every 100 values for total number of rooms
  42. delegate_to: 127.0.0.1
  43. shell: |
  44. seq 0 100 {{ rooms_total.stdout }}
  45. when: purge_rooms|bool
  46. register: every_100_rooms
  47. - name: Ensure room_list_complete.json file exists
  48. delegate_to: 127.0.0.1
  49. file:
  50. path: /tmp/{{ subscription_id }}_room_list_complete.json
  51. state: touch
  52. when: purge_rooms|bool
  53. - name: Build file with total room list
  54. include_tasks: purge_database_build_list.yml
  55. loop: "{{ every_100_rooms.stdout_lines | flatten(levels=1) }}"
  56. when: purge_rooms|bool
  57. - name: Generate list of rooms with no local users
  58. delegate_to: 127.0.0.1
  59. shell: |
  60. jq 'try .rooms[] | select(.joined_local_members == 0) | .room_id' < /tmp/{{ subscription_id }}_room_list_complete.json > /tmp/{{ subscription_id }}_room_list_no_local_users.txt
  61. when: purge_rooms|bool
  62. - name: Count number of rooms with no local users
  63. delegate_to: 127.0.0.1
  64. shell: |
  65. wc -l /tmp/{{ subscription_id }}_room_list_no_local_users.txt | awk '{ print $1 }'
  66. register: rooms_no_local_total
  67. when: purge_rooms|bool
  68. - name: Setting host fact room_list_no_local_users
  69. set_fact:
  70. room_list_no_local_users: "{{ lookup('file', '/tmp/{{ subscription_id }}_room_list_no_local_users.txt') }}"
  71. no_log: True
  72. when: purge_rooms|bool
  73. - name: Purge all rooms with no local users
  74. include_tasks: purge_database_no_local.yml
  75. loop: "{{ room_list_no_local_users.splitlines() | flatten(levels=1) }}"
  76. when: purge_rooms|bool
  77. - name: Collect epoche time from date
  78. delegate_to: 127.0.0.1
  79. shell: |
  80. date -d '{{ purge_date }}' +"%s"
  81. when: purge_rooms|bool
  82. register: purge_epoche_time
  83. - name: Generate list of rooms with more then N users
  84. delegate_to: 127.0.0.1
  85. shell: |
  86. jq 'try .rooms[] | select(.joined_members > {{ purge_metric_value }}) | .room_id' < /tmp/{{ subscription_id }}_room_list_complete.json > /tmp/{{ subscription_id }}_room_list_joined_members.txt
  87. when: (purge_metric.find("Number of users") != -1) and (purge_rooms|bool)
  88. - name: Count number of rooms with more then N users
  89. delegate_to: 127.0.0.1
  90. shell: |
  91. wc -l /tmp/{{ subscription_id }}_room_list_joined_members.txt | awk '{ print $1 }'
  92. register: rooms_join_members_total
  93. when: (purge_metric.find("Number of users") != -1) and (purge_rooms|bool)
  94. - name: Setting host fact room_list_joined_members
  95. delegate_to: 127.0.0.1
  96. set_fact:
  97. room_list_joined_members: "{{ lookup('file', '/tmp/{{ subscription_id }}_room_list_joined_members.txt') }}"
  98. when: (purge_metric.find("Number of users") != -1) and (purge_rooms|bool)
  99. no_log: True
  100. - name: Purge all rooms with more then N users
  101. include_tasks: purge_database_users.yml
  102. loop: "{{ room_list_joined_members.splitlines() | flatten(levels=1) }}"
  103. when: (purge_metric.find("Number of users") != -1) and (purge_rooms|bool)
  104. - name: Generate list of rooms with more then N events
  105. delegate_to: 127.0.0.1
  106. shell: |
  107. jq 'try .rooms[] | select(.state_events > {{ purge_metric_value }}) | .room_id' < /tmp/{{ subscription_id }}_room_list_complete.json > /tmp/{{ subscription_id }}_room_list_state_events.txt
  108. when: (purge_metric.find("Number of events") != -1) and (purge_rooms|bool)
  109. - name: Count number of rooms with more then N users
  110. delegate_to: 127.0.0.1
  111. shell: |
  112. wc -l /tmp/{{ subscription_id }}_room_list_state_events.txt | awk '{ print $1 }'
  113. register: rooms_state_events_total
  114. when: (purge_metric.find("Number of events") != -1) and (purge_rooms|bool)
  115. - name: Setting host fact room_list_state_events
  116. delegate_to: 127.0.0.1
  117. set_fact:
  118. room_list_state_events: "{{ lookup('file', '/tmp/{{ subscription_id }}_room_list_state_events.txt') }}"
  119. when: (purge_metric.find("Number of events") != -1) and (purge_rooms|bool)
  120. no_log: True
  121. - name: Purge all rooms with more then N events
  122. include_tasks: purge_database_events.yml
  123. loop: "{{ room_list_state_events.splitlines() | flatten(levels=1) }}"
  124. when: (purge_metric.find("Number of events") != -1) and (purge_rooms|bool)
  125. - name: Collect AWX admin token the hard way!
  126. delegate_to: 127.0.0.1
  127. shell: |
  128. curl -sku {{ tower_username }}:{{ tower_password }} -H "Content-Type: application/json" -X POST -d '{"description":"Tower CLI", "application":null, "scope":"write"}' https://{{ tower_host }}/api/v2/users/1/personal_tokens/ | jq '.token' | sed -r 's/\"//g'
  129. register: tower_token
  130. no_log: True
  131. - name: Execute rust-synapse-compress-state job template
  132. delegate_to: 127.0.0.1
  133. awx.awx.tower_job_launch:
  134. job_template: "{{ matrix_domain }} - 0 - Deploy/Update a Server"
  135. tags: "rust-synapse-compress-state"
  136. wait: yes
  137. tower_host: "https://{{ tower_host }}"
  138. tower_oauthtoken: "{{ tower_token.stdout }}"
  139. validate_certs: yes
  140. register: job
  141. - name: Stop Synapse service
  142. shell: systemctl stop matrix-synapse.service
  143. - name: Re-index Synapse database
  144. shell: docker exec -i matrix-postgres psql "host=127.0.0.1 port=5432 dbname=synapse user=synapse password={{ matrix_synapse_connection_password }}" -c 'REINDEX (VERBOSE) DATABASE synapse'
  145. - name: Execute run-postgres-vacuum job template
  146. delegate_to: 127.0.0.1
  147. awx.awx.tower_job_launch:
  148. job_template: "{{ matrix_domain }} - 0 - Deploy/Update a Server"
  149. tags: "run-postgres-vacuum,start"
  150. wait: yes
  151. tower_host: "https://{{ tower_host }}"
  152. tower_oauthtoken: "{{ tower_token.stdout }}"
  153. validate_certs: yes
  154. register: job
  155. - name: Cleanup room_list files
  156. delegate_to: 127.0.0.1
  157. shell: |
  158. rm /tmp/{{ subscription_id }}_room_list*
  159. when: purge_rooms|bool
  160. ignore_errors: yes
  161. - name: Collect size of Synapse database
  162. shell: du -sh /matrix/postgres/data
  163. register: db_size_after_stat
  164. no_log: True
  165. - name: Print total number of rooms processed
  166. debug:
  167. msg: '{{ rooms_total.stdout }}'
  168. when: purge_rooms|bool
  169. - name: Print the number of rooms purged with no local users
  170. debug:
  171. msg: '{{ rooms_no_local_total.stdout }}'
  172. when: purge_rooms|bool
  173. - name: Print the number of rooms purged with more then N users
  174. debug:
  175. msg: '{{ rooms_join_members_total.stdout }}'
  176. when: (purge_metric.find("Number of users") != -1) and (purge_rooms|bool)
  177. - name: Print the number of rooms purged with more then N events
  178. debug:
  179. msg: '{{ rooms_state_events_total.stdout }}'
  180. when: (purge_metric.find("Number of events") != -1) and (purge_rooms|bool)
  181. - name: Print before purge size of Synapse database
  182. debug:
  183. msg: "{{ db_size_before_stat.stdout.split('\n') }}"
  184. when: db_size_before_stat is defined
  185. - name: Print after purge size of Synapse database
  186. debug:
  187. msg: "{{ db_size_after_stat.stdout.split('\n') }}"
  188. when: db_size_after_stat is defined
  189. - name: Set boolean value to exit playbook
  190. set_fact:
  191. end_playbook: true
  192. - name: End playbook early if this task is called.
  193. meta: end_play
  194. when: end_playbook is defined and end_playbook|bool