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

86 строки
2.9 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. - name: Generate Postgres database import command
  45. set_fact:
  46. matrix_postgres_import_command: >-
  47. /usr/bin/docker run --rm --name matrix-postgres-import
  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. -v {{ server_path_postgres_dump }}:/{{ server_path_postgres_dump|basename }}:ro
  53. --entrypoint=/bin/sh
  54. {{ matrix_postgres_docker_image_latest }}
  55. -c 'cat /{{ server_path_postgres_dump|basename }} |
  56. {{ 'gunzip |' if server_path_postgres_dump.endswith('.gz') else '' }}
  57. psql -v ON_ERROR_STOP=1 -h matrix-postgres'
  58. - name: Note about Postgres importing alternative
  59. debug:
  60. msg: >-
  61. Importing Postgres database using the following command: `{{ matrix_postgres_import_command }}`.
  62. If this crashes, you can stop Postgres (`systemctl stop matrix-postgres`),
  63. delete its existing data (`rm -rf {{ matrix_postgres_data_path }}/*`), start it again (`systemctl start matrix-postgres`)
  64. and manually run the above import command directly on the server.
  65. - name: Perform Postgres database import
  66. command: "{{ matrix_postgres_import_command }}"
  67. async: "{{ postgres_import_wait_time }}"
  68. poll: 10