mirror of
https://github.com/StepanovPlaton/HomeServerServices.git
synced 2026-04-03 12:20:43 +04:00
Update readme
This commit is contained in:
168
Services.md
Normal file
168
Services.md
Normal file
@@ -0,0 +1,168 @@
|
||||
# Настройка сервисов
|
||||
|
||||
## 1. [Portainer](./portainer/) - WebUI для управления контейнерами
|
||||
> Для запуска Portainer требуется активный Docker сокет. В Podman по-умолчанию его нет, так как это является потенциальным вектором атаки. Запускайте сокет только для конкретного пользователя (не root!)
|
||||
```bash
|
||||
cd portainer
|
||||
cp .env.example .env && vim .env
|
||||
systemctl --user enable --now podman.socket
|
||||
podman-compose up -d
|
||||
podman generate systemd --new --files --name portainer
|
||||
systemctl --user enable ./container-portainer.service
|
||||
```
|
||||
|
||||
## 2. [Grafana](./grafana/) - Dashboard со статистикой загруженности сервера
|
||||
> Proxmox предоставляет достаточно информации об использовании ресурсов системы, но если вы ставите Debian как контейнеров сервисов отдельно, вам может потребоваться Grafana
|
||||
```bash
|
||||
cd grafana
|
||||
cp .env.example .env && vim .env
|
||||
podman-compose up -d
|
||||
podman generate systemd --new --files --name portainer
|
||||
systemctl --user enable ./container-portainer.service
|
||||
```
|
||||
|
||||
### 3. [AutoSSH](./autossh/) - SSH тунель, проброс портов
|
||||
|
||||
```bash
|
||||
cd autossh
|
||||
cp .env.example .env && vim .env
|
||||
podman-compose up -d --build
|
||||
```
|
||||
|
||||
### 4. [Samba](./samba/) - сетевой диск в локальной сети
|
||||
|
||||
|
||||
```bash
|
||||
cd samba
|
||||
cp .env.example .env && vim .env
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
> Samba работает на 139 и 445 порту, для доступа к ним нужны root права. Чтобы не запускать контейнер от имени root пробросим порты из контейнера на 1139 и 1445 порты соответственно, и добавим правила в iptables для переадресации трафика
|
||||
|
||||
```bash
|
||||
sudo iptables -t nat -A PREROUTING -p tcp --dport 139 -j REDIRECT --to-ports 1139
|
||||
sudo iptables -t nat -A PREROUTING -p tcp --dport 445 -j REDIRECT --to-ports 1445
|
||||
sudo iptables -t nat -L -n -v # Посмотреть список правил
|
||||
|
||||
# Для сохранения правил iptables после перезагрузки
|
||||
sudo apt install iptables-persistent
|
||||
sudo netfilter-persistent save # сохранить текущие iptables
|
||||
```
|
||||
|
||||
### 5. [Transmission](./transmission/) - qBitTorrent клиент
|
||||
|
||||
```bash
|
||||
cd transmission
|
||||
cp .env.example .env && vim .env
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
В настройках клиента указанная в `.env` папка доступна по пути `/downloads`. Можно подключиться с помощью [Transmission Remote GUI](https://github.com/transmission-remote-gui/transgui) или [Transmission Qt](https://transmissionbt.com/download.html)
|
||||
|
||||
### 6. [Syncthing](./syncthing/) - синхронизация файлов между устройствами
|
||||
|
||||
```bash
|
||||
cd syncthing
|
||||
cp .env.example .env && vim .env
|
||||
mkdir config && podman unshare chown -R 1000:1000 config
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
### 7. [Gitea](./gitea/)
|
||||
|
||||
```bash
|
||||
cd gitea
|
||||
cp .env.example .env && vim .env
|
||||
mkdir config && podman unshare chown -R 1000:1000 config
|
||||
mkdir data && podman unshare chown -R 1000:1000 data
|
||||
mkdir db && podman unshare chown -R 1000:1000 db
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
Gitea конфигурируется позже, уже в веб-форме. Обязательно **отключаем самостоятельную регистрацию** и создаём администратора (пользователя по умолчанию). Остальное не трогаем, уже сконфигурировано в `.env`
|
||||
|
||||
### 8. [Cloud (FileBrowser)](./cloud/)
|
||||
|
||||
```bash
|
||||
cd cloud
|
||||
cp .env.example .env && vim .env
|
||||
touch filebrowser.db && podman unshare chown -R 1000:1000 filebrowser.db
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
### 9. [Matrix](./matrix/)
|
||||
|
||||
```bash
|
||||
cd matrix
|
||||
mkdir data && podman unshare chown -R 1000:1000 data
|
||||
podman run -it --rm -v "$(pwd)/data:/data" -e SYNAPSE_SERVER_NAME=MATRIX.DOMAIN.ru -e SYNAPSE_REPORT_STATS=no docker.io/matrixdotorg/synapse:latest generate
|
||||
```
|
||||
Меняем базу данных на PostgreSQL и прописываем БД, пользователя, пароль:
|
||||
|
||||
```yaml
|
||||
database:
|
||||
name: psycopg2
|
||||
args:
|
||||
user: user
|
||||
password: passw0rd
|
||||
database: db
|
||||
host: matrix-db
|
||||
cp_min: 5
|
||||
cp_max: 10
|
||||
```
|
||||
```bash
|
||||
mkdir db && podman unshare chown -R 1000:1000 db
|
||||
cp .env.example .env && vim .env
|
||||
podman-compose up -d
|
||||
```
|
||||
|
||||
Создаём пользователя
|
||||
```bash
|
||||
podman exec -it matrix-synapse register_new_matrix_user -c /data/homeserver.yaml http://localhost:8008
|
||||
```
|
||||
|
||||
### 10. [Nginx Reverse Proxy (Entrypoint)](./proxy)
|
||||
|
||||
```bash
|
||||
cd proxy
|
||||
cp .env.example .env && vim .env
|
||||
```
|
||||
|
||||
Создаём конфиг для DynDNS:
|
||||
|
||||
```bash
|
||||
cp ddns/domains.txt.example ddns/domains.txt && vim ddns/domains.txt
|
||||
```
|
||||
|
||||
Нужно указать ресурсные записи `@` и `www` для доступа к домену второго уровня напрямую. Также нужно добавить домены 3-го уровня для: gitea, cloud (filebrowser), matrix server (synapse), matrix client (element).
|
||||
|
||||
В первый раз SSL сертификаты нужно создать вручную.
|
||||
|
||||
Запускаем DDNS скрипт и HTTP сервер для Let's Encrypt:
|
||||
|
||||
```bash
|
||||
podman-compose -f init-compose.yml up -d --build
|
||||
```
|
||||
|
||||
Проверяем по логам в portainer и в личном кабинете рег.ру что ресурсные записи обновились. Ожидаем пока DNS обновит информацию о наших поддоменах (занимает от 15 минут до 24 часов).
|
||||
|
||||
Затем создаём SSL сертификаты на каждый домен(-ы) c помощью команды
|
||||
```bash
|
||||
podman-compose run --rm --entrypoint "certbot" certbot certonly --webroot --webroot-path=/var/www/certbot --email your-email@gmail.com --agree-tos --no-eff-email -d domain.com -d domain2.com
|
||||
```
|
||||
|
||||
Настраиваем Nginx:
|
||||
|
||||
```bash
|
||||
cd nginx/conf.d
|
||||
cp default.conf.example default.conf
|
||||
vim default.conf
|
||||
```
|
||||
|
||||
Запускаем основной контейнер:
|
||||
|
||||
```bash
|
||||
podman-compose -f init-compose.yml down
|
||||
podman-compose up -d --build
|
||||
```
|
||||
Reference in New Issue
Block a user