Matrix Docker Ansible eploy
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 

124 wiersze
6.1 KiB

  1. ---
  2. # Pre-checks
  3. - name: Fail if Postgres not enabled
  4. fail:
  5. msg: "Postgres via the matrix-postgres role is not enabled (`matrix_postgres_enabled`). Cannot use rust-synapse-compress-state."
  6. when: "not matrix_postgres_enabled|bool"
  7. # Defaults
  8. - name: Set matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time, if not provided
  9. set_fact:
  10. matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time: 1800
  11. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time|default('') == ''"
  12. - name: Set matrix_synapse_rust_synapse_compress_state_compress_room_time, if not provided
  13. set_fact:
  14. matrix_synapse_rust_synapse_compress_state_compress_room_time: 3600
  15. when: "matrix_synapse_rust_synapse_compress_state_compress_room_time|default('') == ''"
  16. - name: Set matrix_synapse_rust_synapse_compress_state_psql_import_time, if not provided
  17. set_fact:
  18. matrix_synapse_rust_synapse_compress_state_psql_import_time: 3600
  19. when: "matrix_synapse_rust_synapse_compress_state_psql_import_time|default('') == ''"
  20. - name: Set matrix_synapse_rust_synapse_compress_state_min_state_groups_required, if not provided
  21. set_fact:
  22. # The minimum number of state groups we're looking for before we consider a room eligible for compression.
  23. # Rooms with a smaller state groups count will not be compressed.
  24. matrix_synapse_rust_synapse_compress_state_min_state_groups_required: 100000
  25. when: "matrix_synapse_rust_synapse_compress_state_min_state_groups_required|default('') == ''"
  26. # Actual compression work
  27. - name: Ensure rust-synapse-compress-state paths exist
  28. file:
  29. path: "{{ matrix_synapse_rust_synapse_compress_state_base_path }}"
  30. state: directory
  31. mode: 0750
  32. owner: "{{ matrix_user_username }}"
  33. group: "{{ matrix_user_groupname }}"
  34. - name: Ensure rust-synapse-compress-state image is pulled
  35. docker_image:
  36. name: "{{ matrix_synapse_rust_synapse_compress_state_docker_image }}"
  37. source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
  38. force_source: "{{ matrix_synapse_rust_synapse_compress_state_docker_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
  39. force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_synapse_rust_synapse_compress_state_docker_image_force_pull }}"
  40. register: result
  41. retries: "{{ matrix_container_retries_count }}"
  42. delay: "{{ matrix_container_retries_delay }}"
  43. until: result is not failed
  44. - name: Generate rust-synapse-compress-state room find command
  45. set_fact:
  46. matrix_synapse_rust_synapse_compress_state_find_rooms_command: >-
  47. {{ matrix_host_command_docker }} run --rm --name matrix-rust-synapse-compress-state-find-rooms
  48. --user={{ matrix_user_uid }}:{{ matrix_user_gid }}
  49. --cap-drop=ALL
  50. --network={{ matrix_docker_network }}
  51. --env-file={{ matrix_postgres_base_path }}/env-postgres-psql
  52. {{ matrix_postgres_docker_image_latest }}
  53. psql -v ON_ERROR_STOP=1 -h matrix-postgres {{ matrix_synapse_database_database }} -c
  54. '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;'
  55. - name: Find rooms eligible for compression with rust-synapse-compress-state
  56. command: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command }}"
  57. async: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time }}"
  58. poll: 10
  59. register: matrix_synapse_rust_synapse_compress_state_find_rooms_command_result
  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. - block:
  73. - debug: var="matrix_synapse_rust_synapse_compress_state_find_rooms_command_result"
  74. - name: Fail if room find result is not what we expect
  75. fail:
  76. msg: >-
  77. Expecting 4 lines in the "find rooms" result.
  78. 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"
  79. - block:
  80. # matrix_synapse_rust_synapse_compress_state_eligible_rooms is a list
  81. # of dictionaries like this: {'room_id': '!some-id', 'count': 2461329}
  82. - set_fact:
  83. matrix_synapse_rust_synapse_compress_state_eligible_rooms: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] | from_json }}"
  84. - name: Display rooms that will be compressed
  85. debug:
  86. msg: >-
  87. The following rooms contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  88. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`)
  89. and will be compressed:
  90. {{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}
  91. - name: Compress room state
  92. include_tasks: "{{ role_path }}/tasks/rust-synapse-compress-state/compress_room.yml"
  93. with_items: "{{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}"
  94. loop_control:
  95. loop_var: room_details
  96. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] != ' '"
  97. - name: Show notice about lack of rooms to compress
  98. debug:
  99. msg: >-
  100. No rooms were found to contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  101. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`),
  102. so there's nothing to compress.
  103. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] == ' '"