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.
 
 

99 wiersze
3.7 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 import."
  6. when: "not matrix_postgres_enabled|bool"
  7. - name: Fail if playbook called incorrectly
  8. fail:
  9. msg: "The `server_path_postgres_dump` variable needs to be provided to this playbook, via --extra-vars"
  10. when: "server_path_postgres_dump is not defined or server_path_postgres_dump.startswith('<')"
  11. - name: Check if the provided Postgres dump file exists
  12. stat:
  13. path: "{{ server_path_postgres_dump }}"
  14. register: result_server_path_postgres_dump_stat
  15. - name: Fail if provided Postgres dump file doesn't exists
  16. fail:
  17. msg: "File cannot be found on the server at {{ server_path_postgres_dump }}"
  18. when: "not result_server_path_postgres_dump_stat.stat.exists"
  19. # Defaults
  20. - name: Set postgres_start_wait_time, if not provided
  21. set_fact:
  22. postgres_start_wait_time: 15
  23. when: "postgres_start_wait_time|default('') == ''"
  24. - name: Set postgres_import_wait_time, if not provided
  25. set_fact:
  26. postgres_import_wait_time: "{{ 7 * 86400 }}"
  27. when: "postgres_import_wait_time|default('') == ''"
  28. # Actual import work
  29. - name: Ensure matrix-postgres is started
  30. service:
  31. name: matrix-postgres
  32. state: started
  33. daemon_reload: yes
  34. - name: Wait a bit, so that Postgres can start
  35. wait_for:
  36. timeout: "{{ postgres_start_wait_time }}"
  37. delegate_to: 127.0.0.1
  38. become: false
  39. - import_tasks: tasks/util/detect_existing_postgres_version.yml
  40. - name: Abort, if no existing Postgres version detected
  41. fail:
  42. msg: "Could not find existing Postgres installation"
  43. when: "not matrix_postgres_detected_existing|bool"
  44. # Starting the database container had automatically created the default
  45. # role (`matrix_postgres_connection_username`) and database (`matrix_postgres_db_name`).
  46. # The dump most likely contains those same entries and would try to re-create them, leading to errors.
  47. # We need to skip over those lines.
  48. - name: Generate Postgres database import command
  49. set_fact:
  50. matrix_postgres_import_command: >-
  51. /usr/bin/docker run --rm --name matrix-postgres-import
  52. --user={{ matrix_user_uid }}:{{ matrix_user_gid }}
  53. --cap-drop=ALL
  54. --network={{ matrix_docker_network }}
  55. --env-file={{ matrix_postgres_base_path }}/env-postgres-psql
  56. -v {{ server_path_postgres_dump }}:/{{ server_path_postgres_dump|basename }}:ro
  57. --entrypoint=/bin/sh
  58. {{ matrix_postgres_docker_image_latest }}
  59. -c "cat /{{ server_path_postgres_dump|basename }} |
  60. {{ 'gunzip |' if server_path_postgres_dump.endswith('.gz') else '' }}
  61. grep -vE '^CREATE ROLE {{ matrix_postgres_connection_username }}' |
  62. grep -vE '^CREATE DATABASE {{ matrix_postgres_db_name }}' |
  63. psql -v ON_ERROR_STOP=1 -h matrix-postgres"
  64. # This is a hack.
  65. # See: https://ansibledaily.com/print-to-standard-output-without-escaping/
  66. #
  67. # We want to run `debug: msg=".."`, but that dumps it as JSON and escapes double quotes within it,
  68. # which ruins the command (`matrix_postgres_import_command`)
  69. - name: Note about Postgres importing alternative
  70. set_fact:
  71. dummy: true
  72. with_items:
  73. - >-
  74. Importing Postgres database using the following command: `{{ matrix_postgres_import_command }}`.
  75. If this crashes, you can stop Postgres (`systemctl stop matrix-postgres`),
  76. delete its existing data (`rm -rf {{ matrix_postgres_data_path }}/*`), start it again (`systemctl start matrix-postgres`)
  77. and manually run the above import command directly on the server.
  78. - name: Perform Postgres database import
  79. command: "{{ matrix_postgres_import_command }}"
  80. async: "{{ postgres_import_wait_time }}"
  81. poll: 10