Matrix Docker Ansible eploy
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

127 line
6.1 KiB

  1. # SPDX-FileCopyrightText: 2020 - 2024 Slavi Pantaleev
  2. # SPDX-FileCopyrightText: 2022 MDAD project contributors
  3. # SPDX-FileCopyrightText: 2022 Marko Weltzer
  4. # SPDX-FileCopyrightText: 2022 Nikita Chernyi
  5. # SPDX-FileCopyrightText: 2022 Sebastian Gumprich
  6. #
  7. # SPDX-License-Identifier: AGPL-3.0-or-later
  8. ---
  9. # Pre-checks
  10. - name: Fail if Postgres not enabled
  11. ansible.builtin.fail:
  12. msg: "Postgres via ansible-role-postgres role is not enabled (`postgres_enabled`). Cannot use rust-synapse-compress-state."
  13. when: "not postgres_enabled | bool"
  14. # Defaults
  15. - name: Set matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time, if not provided
  16. ansible.builtin.set_fact:
  17. matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time: 1800
  18. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time | default('') == ''"
  19. - name: Set matrix_synapse_rust_synapse_compress_state_compress_room_time, if not provided
  20. ansible.builtin.set_fact:
  21. matrix_synapse_rust_synapse_compress_state_compress_room_time: 3600
  22. when: "matrix_synapse_rust_synapse_compress_state_compress_room_time | default('') == ''"
  23. - name: Set matrix_synapse_rust_synapse_compress_state_psql_import_time, if not provided
  24. ansible.builtin.set_fact:
  25. matrix_synapse_rust_synapse_compress_state_psql_import_time: 3600
  26. when: "matrix_synapse_rust_synapse_compress_state_psql_import_time | default('') == ''"
  27. - name: Set matrix_synapse_rust_synapse_compress_state_min_state_groups_required, if not provided
  28. ansible.builtin.set_fact:
  29. # The minimum number of state groups we're looking for before we consider a room eligible for compression.
  30. # Rooms with a smaller state groups count will not be compressed.
  31. matrix_synapse_rust_synapse_compress_state_min_state_groups_required: 100000
  32. when: "matrix_synapse_rust_synapse_compress_state_min_state_groups_required | default('') == ''"
  33. # Actual compression work
  34. - name: Ensure rust-synapse-compress-state paths exist
  35. ansible.builtin.file:
  36. path: "{{ matrix_synapse_rust_synapse_compress_state_base_path }}"
  37. state: directory
  38. mode: '0750'
  39. owner: "{{ matrix_synapse_uid }}"
  40. group: "{{ matrix_synapse_gid }}"
  41. - name: Ensure rust-synapse-compress-state image is pulled
  42. community.docker.docker_image_pull:
  43. name: "{{ matrix_synapse_rust_synapse_compress_state_container_image }}"
  44. pull: always
  45. register: result
  46. retries: "{{ devture_playbook_help_container_retries_count }}"
  47. delay: "{{ devture_playbook_help_container_retries_delay }}"
  48. until: result is not failed
  49. - name: Generate rust-synapse-compress-state room find SQL command
  50. ansible.builtin.set_fact:
  51. matrix_synapse_rust_synapse_compress_state_find_rooms_command: >-
  52. {{ postgres_bin_path }}/cli-non-interactive --dbname={{ matrix_synapse_database_database | quote }} -c "SELECT array_to_json(array_agg(row_to_json (r))) FROM (SELECT room_id, count(*) AS count FROM state_groups_state GROUP BY room_id HAVING count(*) > {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} ORDER BY count DESC) r;"
  53. - name: Find rooms eligible for compression with rust-synapse-compress-state
  54. ansible.builtin.command: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command }}"
  55. async: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time }}"
  56. poll: 10
  57. register: matrix_synapse_rust_synapse_compress_state_find_rooms_command_result
  58. failed_when: not matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.finished
  59. changed_when: false
  60. # We expect the output to be like this:
  61. #
  62. # "stdout_lines": [
  63. # " array_to_json ",
  64. # "----------------------------------------------------------------------------------------------------------------------------",
  65. # " [{\"room_id\":\"!some-id\",\"count\":2461329},{\"room_id\":\"!another-id\",\"count\":512017}]",
  66. # "(1 row)"
  67. # ]
  68. #
  69. # Row 3 (out of 4) contains the actual result.
  70. #
  71. # Row 3 contains a space when there's no result.
  72. - when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.failed or matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines | length != 4"
  73. block:
  74. - ansible.builtin.debug:
  75. var: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result"
  76. - name: Fail if room find result is not what we expect
  77. ansible.builtin.fail:
  78. msg: >-
  79. Expecting 4 lines in the "find rooms" result.
  80. - when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] != ' '"
  81. block:
  82. # matrix_synapse_rust_synapse_compress_state_eligible_rooms is a list
  83. # of dictionaries like this: {'room_id': '!some-id', 'count': 2461329}
  84. - ansible.builtin.set_fact:
  85. matrix_synapse_rust_synapse_compress_state_eligible_rooms: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] | from_json }}"
  86. - name: Display rooms that will be compressed
  87. ansible.builtin.debug:
  88. msg: >-
  89. The following rooms contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  90. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`)
  91. and will be compressed:
  92. {{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}
  93. - name: Compress room state
  94. ansible.builtin.include_tasks: "{{ role_path }}/tasks/rust-synapse-compress-state/compress_room.yml"
  95. with_items: "{{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}"
  96. loop_control:
  97. loop_var: room_details
  98. - name: Show notice about lack of rooms to compress
  99. ansible.builtin.debug:
  100. msg: >-
  101. No rooms were found to contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  102. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`),
  103. so there's nothing to compress.
  104. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] == ' '"