Matrix Docker Ansible eploy
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

120 строки
6.0 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: 300
  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: 1800
  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: 1800
  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. - name: Generate rust-synapse-compress-state room find command
  41. set_fact:
  42. matrix_synapse_rust_synapse_compress_state_find_rooms_command: >-
  43. {{ matrix_host_command_docker }} run --rm --name matrix-rust-synapse-compress-state-find-rooms
  44. --user={{ matrix_user_uid }}:{{ matrix_user_gid }}
  45. --cap-drop=ALL
  46. --network={{ matrix_docker_network }}
  47. --env-file={{ matrix_postgres_base_path }}/env-postgres-psql
  48. {{ matrix_postgres_docker_image_latest }}
  49. psql -v ON_ERROR_STOP=1 -h matrix-postgres {{ matrix_synapse_database_database }} -c
  50. '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;'
  51. - name: Find rooms eligible for compression with rust-synapse-compress-state
  52. command: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command }}"
  53. async: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_wait_time }}"
  54. poll: 10
  55. register: matrix_synapse_rust_synapse_compress_state_find_rooms_command_result
  56. # We expect the output to be like this:
  57. #
  58. # "stdout_lines": [
  59. # " array_to_json ",
  60. # "----------------------------------------------------------------------------------------------------------------------------",
  61. # " [{\"room_id\":\"!some-id\",\"count\":2461329},{\"room_id\":\"!another-id\",\"count\":512017}]",
  62. # "(1 row)"
  63. # ]
  64. #
  65. # Row 3 (out of 4) contains the actual result.
  66. #
  67. # Row 3 contains a space when there's no result.
  68. - block:
  69. - debug: var="matrix_synapse_rust_synapse_compress_state_find_rooms_command_result"
  70. - name: Fail if room find result is not what we expect
  71. fail:
  72. msg: >-
  73. Expecting 4 lines in the "find rooms" result.
  74. 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"
  75. - block:
  76. # matrix_synapse_rust_synapse_compress_state_eligible_rooms is a list
  77. # of dictionaries like this: {'room_id': '!some-id', 'count': 2461329}
  78. - set_fact:
  79. matrix_synapse_rust_synapse_compress_state_eligible_rooms: "{{ matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] | from_json }}"
  80. - name: Display rooms that will be compressed
  81. debug:
  82. msg: >-
  83. The following rooms contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  84. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`)
  85. and will be compressed:
  86. {{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}
  87. - name: Compress room state
  88. include_tasks: "{{ role_path }}/tasks/rust-synapse-compress-state/compress_room.yml"
  89. with_items: "{{ matrix_synapse_rust_synapse_compress_state_eligible_rooms }}"
  90. loop_control:
  91. loop_var: room_details
  92. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] != ' '"
  93. - name: Show notice about lack of rooms to compress
  94. debug:
  95. msg: >-
  96. No rooms were found to contain more than {{ matrix_synapse_rust_synapse_compress_state_min_state_groups_required }} state group rows
  97. (configurable via `matrix_synapse_rust_synapse_compress_state_min_state_groups_required`),
  98. so there's nothing to compress.
  99. when: "matrix_synapse_rust_synapse_compress_state_find_rooms_command_result.stdout_lines[2] == ' '"