Compare commits
8 Commits
926f4ea135
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
5ce2f1fbd4
|
|||
|
e39981eee2
|
|||
|
83bfba2180
|
|||
|
b42dd429fd
|
|||
|
a056e8662d
|
|||
|
4a693470fc
|
|||
|
ab9ac67b2e
|
|||
|
8728eb0203
|
23
README.md
23
README.md
@@ -7,6 +7,7 @@
|
||||
|
||||
## Требования
|
||||
|
||||
- [uv](https://docs.astral.sh/uv/)
|
||||
- [ansible](https://docs.ansible.com/ansible/latest/getting_started/index.html)
|
||||
- [task](https://taskfile.dev/)
|
||||
- [yq](https://github.com/mikefarah/yq)
|
||||
@@ -14,17 +15,21 @@
|
||||
## Установка
|
||||
|
||||
```bash
|
||||
$ cp ansible-vault-password-file.dist ansible-vault-password-file
|
||||
$ ansible-galaxy install --role-file requirements.yml
|
||||
uv sync
|
||||
|
||||
cp ansible-vault-password-file.dist ansible-vault-password-file
|
||||
|
||||
uv run ansible-galaxy install --role-file requirements.yml
|
||||
```
|
||||
|
||||
## Структура
|
||||
|
||||
- Для каждого приложения создается свой пользователь (опционально).
|
||||
- Для каждого приложения создается свой пользователь.
|
||||
- Для доступа используется ssh-ключ.
|
||||
- Безопасность осуществляется с помощью `ufw` и `fail2ban`.
|
||||
- Докер используется для запуска и изоляции приложений. Для загрузки образов настраивается Yandex Docker Registry.
|
||||
- Выход во внешнюю сеть через proxy server [Caddy](https://caddyserver.com/).
|
||||
- Чувствительные данные в `vars/vars.yaml` зашифрованы с помощью Ansible Vault.
|
||||
- Чувствительные данные в [secrets.yml](vars/secrets.yml) зашифрованы с помощью Ansible Vault.
|
||||
- Для мониторинга за сервером устанавливается [netdata](https://github.com/netdata/netdata).
|
||||
|
||||
## Настройка DNS
|
||||
@@ -33,8 +38,14 @@ $ ansible-galaxy install --role-file requirements.yml
|
||||
|
||||
## Деплой приложений
|
||||
|
||||
Деплой всех приложений через ansible:
|
||||
Деплой приложения через ansible:
|
||||
|
||||
```bash
|
||||
ansible-playbook -i production.yml --diff playbook-gitea.yml
|
||||
uv run ansible-playbook ansible-playbook -i production.yml --diff playbook-gitea.yml
|
||||
```
|
||||
|
||||
## Удаление приложения <name>
|
||||
|
||||
```bash
|
||||
uv run ansible-playbook -i production.yml --diff playbook-remove-user-and-app.yml --extra-vars user_name=<name>
|
||||
```
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
services:
|
||||
|
||||
dozzle_app:
|
||||
image: amir20/dozzle:v9.0.1
|
||||
image: amir20/dozzle:v9.0.3
|
||||
container_name: dozzle_app
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
services:
|
||||
|
||||
gitea_app:
|
||||
image: gitea/gitea:1.25.3
|
||||
image: gitea/gitea:1.25.4
|
||||
restart: unless-stopped
|
||||
container_name: gitea_app
|
||||
ports:
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
services:
|
||||
|
||||
gramps_app: &gramps_app
|
||||
image: ghcr.io/gramps-project/grampsweb:25.12.0
|
||||
image: ghcr.io/gramps-project/grampsweb:26.1.0
|
||||
container_name: gramps_app
|
||||
depends_on:
|
||||
- gramps_redis
|
||||
|
||||
@@ -3,7 +3,7 @@
|
||||
services:
|
||||
|
||||
memos_app:
|
||||
image: neosmemo/memos:0.25.3
|
||||
image: neosmemo/memos:0.26.0
|
||||
container_name: memos_app
|
||||
restart: unless-stopped
|
||||
user: "{{ owner_create_result.uid }}:{{ owner_create_result.group }}"
|
||||
|
||||
@@ -3,7 +3,7 @@ services:
|
||||
# See sample https://github.com/outline/outline/blob/main/.env.sample
|
||||
|
||||
outline_app:
|
||||
image: outlinewiki/outline:1.2.0
|
||||
image: outlinewiki/outline:1.4.0
|
||||
container_name: outline_app
|
||||
user: "{{ owner_create_result.uid }}:{{ owner_create_result.group }}"
|
||||
restart: unless-stopped
|
||||
|
||||
@@ -31,8 +31,8 @@
|
||||
- name: 'Configure wanderer'
|
||||
ansible.builtin.import_playbook: playbook-wanderer.yml
|
||||
|
||||
- name: 'Configure kavita'
|
||||
ansible.builtin.import_playbook: playbook-kavita.yml
|
||||
- name: 'Configure calibre'
|
||||
ansible.builtin.import_playbook: playbook-calibre.yml
|
||||
|
||||
#
|
||||
|
||||
|
||||
@@ -25,6 +25,11 @@
|
||||
path: "/var/www/{{ user_name }}"
|
||||
state: absent
|
||||
|
||||
- name: "Remove application dir"
|
||||
ansible.builtin.file:
|
||||
path: "/mnt/applications/{{ user_name }}"
|
||||
state: absent
|
||||
|
||||
- name: "Remove home dir"
|
||||
ansible.builtin.file:
|
||||
path: "/home/{{ user_name }}"
|
||||
|
||||
Reference in New Issue
Block a user