update and gitignore

This commit is contained in:
2025-10-05 03:55:18 +00:00
commit 97572905bb
13 changed files with 415 additions and 0 deletions

6
.gitignore vendored Normal file
View File

@@ -0,0 +1,6 @@
tandoor/postgresql
tandoor/staticfiles
tandoor/mediafiles
immich-app/library
immich-app/postgres
gitea/gitea

24
caddy/compose.yml Normal file
View File

@@ -0,0 +1,24 @@
services:
caddy:
image: caddy:alpine
restart: always
ports:
- "80:80"
- "443:443"
- "443:443/udp"
volumes:
- ./conf:/etc/caddy
- ./site:/srv
- caddy_data:/data
- caddy_config:/config
networks:
- web
volumes:
caddy_data:
caddy_config:
networks:
web:
driver: bridge

15
caddy/conf/Caddyfile Normal file
View File

@@ -0,0 +1,15 @@
img.01v0.com:443 {
reverse_proxy 74.208.164.239:2283
}
tea.01v0.com:443 {
reverse_proxy 74.208.164.239:3000
}
algo.01v0.com:443 {
redir http://ionos.tailfc84fe.ts.net:8080/
}
cook.01v0.com:443 {
reverse_proxy 74.208.164.239:2295
}

23
crontab.txt Normal file
View File

@@ -0,0 +1,23 @@
GNU nano 7.2 /tmp/crontab.x8yt7o/crontab
# indicating with different fields when the task will be run
# and what command to run for the task
#
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').
#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
#
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
#
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
#
# For more information see the manual pages of crontab(5) and cron(8)
#
# m h dom mon dow command
0 20 * * * root /root/docker/Sandbox_1/cron_scripts/data_pull_binance_us_naked.sh >> /root/docker/Sandbox_1/cron_scripts/data_pull_binance_us_naked.log 2>&1
0 21 * * * root /root/docker/Sandbox_1/cron_scripts/data_transfer_to_nas.sh >> /root/docker/Sandbox_1/cron_scripts/data_transfer_to_nas.log 2>&1 && echo "$(date '+%Y-%m-%d %H:%M:%S') - Cron job fin>

27
gitea/docker-compose.yml Normal file
View File

@@ -0,0 +1,27 @@
networks:
web:
driver: bridge
services:
server:
image: docker.gitea.com/gitea:latest
container_name: gitea
environment:
- USER_UID=1000
- USER_GID=1000
restart: unless-stopped
networks:
- web
volumes:
- ./gitea:/data
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
ports:
- "3000:3000"
- "9229:9229"
deploy:
resources:
limits:
cpus: '0.5'
memory: 500M

22
immich-app/.env Normal file
View File

@@ -0,0 +1,22 @@
# You can find documentation for all the supported env variables at https://immich.app/docs/install/environment-variables
# The location where your uploaded files are stored
UPLOAD_LOCATION=./library
# The location where your database files are stored. Network shares are not supported for the database
DB_DATA_LOCATION=./postgres
# To set a timezone, uncomment the next line and change Etc/UTC to a TZ identifier from this list: https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List
# TZ=Etc/UTC
# The Immich version to use. You can pin this to a specific version like "v1.71.0"
IMMICH_VERSION=release
# Connection secret for postgres. You should change it to a random password
# Please use only the characters `A-Za-z0-9`, without special characters or spaces
DB_PASSWORD=postgres
# The values below this line do not need to be changed
###################################################################################
DB_USERNAME=postgres
DB_DATABASE_NAME=immich

View File

@@ -0,0 +1,97 @@
#
# WARNING: To install Immich, follow our guide: https://immich.app/docs/install/docker-compose
#
# Make sure to use the docker-compose.yml of the current release:
#
# https://github.com/immich-app/immich/releases/latest/download/docker-compose.yml
#
# The compose file on main may not be compatible with the latest release.
name: immich
services:
immich-server:
container_name: immich_server
image: ghcr.io/immich-app/immich-server:${IMMICH_VERSION:-release}
# extends:
# file: hwaccel.transcoding.yml
# service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding
volumes:
# Do not edit the next line. If you want to change the media storage location on your system, edit the value of UPLOAD_LOCATION in the .env file
- ${UPLOAD_LOCATION}:/usr/src/app/upload
- /etc/localtime:/etc/localtime:ro
env_file:
- .env
ports:
- '2283:2283'
depends_on:
- redis
- database
restart: unless-stopped
healthcheck:
disable: false
deploy:
resources:
limits:
cpus: '1.0'
memory: 1000M
immich-machine-learning:
container_name: immich_machine_learning
# For hardware acceleration, add one of -[armnn, cuda, rocm, openvino, rknn] to the image tag.
# Example tag: ${IMMICH_VERSION:-release}-cuda
image: ghcr.io/immich-app/immich-machine-learning:${IMMICH_VERSION:-release}
# extends: # uncomment this section for hardware acceleration - see https://immich.app/docs/features/ml-hardware-acceleration
# file: hwaccel.ml.yml
# service: cpu # set to one of [armnn, cuda, rocm, openvino, openvino-wsl, rknn] for accelerated inference - use the `-wsl` version for WSL2 where applicable
volumes:
- model-cache:/cache
env_file:
- .env
restart: unless-stopped
healthcheck:
disable: false
deploy:
resources:
limits:
cpus: '1.0'
memory: 1000M
redis:
container_name: immich_redis
image: docker.io/valkey/valkey:8-bookworm@sha256:fec42f399876eb6faf9e008570597741c87ff7662a54185593e74b09ce83d177
healthcheck:
test: redis-cli ping || exit 1
restart: always
deploy:
resources:
limits:
cpus: '1.0'
memory: 500M
database:
container_name: immich_postgres
image: ghcr.io/immich-app/postgres:14-vectorchord0.4.3-pgvectors0.2.0
environment:
POSTGRES_PASSWORD: ${DB_PASSWORD}
POSTGRES_USER: ${DB_USERNAME}
POSTGRES_DB: ${DB_DATABASE_NAME}
POSTGRES_INITDB_ARGS: '--data-checksums'
# Uncomment the DB_STORAGE_TYPE: 'HDD' var if your database isn't stored on SSDs
# DB_STORAGE_TYPE: 'HDD'
volumes:
# Do not edit the next line. If you want to change the database storage location on your system, edit the value of DB_DATA_LOCATION in the .env file
- ${DB_DATA_LOCATION}:/var/lib/postgresql/data
restart: unless-stopped
deploy:
resources:
limits:
cpus: '1.0'
memory: 500M
volumes:
model-cache:
networks:
web:
driver: bridge

24
mysql/docker-compose.yml Normal file
View File

@@ -0,0 +1,24 @@
networks:
web:
driver: bridge
external: true
services:
db:
image: mysql:latest
container_name: mysql_mkt_maker
ports:
- "3306:3306"
environment:
- MYSQL_ROOT_PASSWORD=pwd
- MYSQL_DATABASE=mkt_maker
volumes:
- /root/dbs/mysql:/var/lib/mysql
restart: unless-stopped
networks:
- web
deploy:
resources:
limits:
cpus: '1.0'
memory: 1000M

81
setup.sh Normal file
View File

@@ -0,0 +1,81 @@
### Install Docker ###
# Function to check if Docker is installed
check_docker_installed() {
if command -v docker &> /dev/null; then
return 0 # Docker is installed
else
return 1 # Docker is not installed
fi
}
check_tailscale_installed() {
if command -v tailscale &> /dev/null; then
return 0 # Tailscale is installed
else
return 1 # Tailscale is not installed
fi
}
if check_docker_installed; then
echo "Docker is already installed. moving onto container start up."
else
# Add Docker's official GPG key:
echo updating docker repository
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc
# Add the repository to Apt sources:
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
$(. /etc/os-release && echo "${UBUNTU_CODENAME:-$VERSION_CODENAME}") stable" | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
# Install
echo install docker
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
echo adding current user to docker usermod
sudo usermod -aG docker $USER
fi
### Install Tailscale Locally and Mount HomeNAS ###
if check_tailscale_installed; then
echo "Tailscale is already installed. connecting server."
else
echo installing tailscale
curl -fsSL https://tailscale.com/install.sh | sh
fi
sudo tailscale up --auth-key=tskey-auth-koHiorB8cj11CNTRL-dLaNRmukCWL5BurtnvU2WLDbrv4SDhVDX --hostname=IONOS
### Docker Containers to Compose ###
declare -a arr=(
# caddy
# tailscale
# immich-app
# mysql
# gitea
)
for i in "${arr[@]}"
do
echo docker composing: "$i"
cd ./$i
docker compose up -d --build
cd ..
done
### Install Conda ###
# echo installing mini conda
# wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
# bash ./Miniconda3-latest-Linux-x86_64.sh
# rm ./Miniconda3-latest-Linux-x86_64.sh
echo setup complete, adios!

View File

@@ -0,0 +1,24 @@
# docker-compose.yml
networks:
web:
driver: bridge
services:
tailscale:
network_mode: host
image: tailscale/tailscale:latest
hostname: linode.tailfc84fe.ts.net
volumes:
- /var/lib/tailscale:/var/lib/tailscale # Persistent data volume
- /dev/net/tun:/dev/net/tun # Required for Tailscale to function
cap_add:
- NET_ADMIN # Required for network administration
- SYS_ADMIN # Required for system administration
environment:
# - TS_AUTHKEY=tskey-auth-kudNt4td4i11CNTRL-GsLa82boyX5pis4EXi4jX5z5brQDX6gnQ
- TS_AUTHKEY=tskey-auth-koHiorB8cj11CNTRL-dLaNRmukCWL5BurtnvU2WLDbrv4SDhVDX
#- TS_ROUTES=192.168.1.0/24 # Optional: Specify subnet routes to advertise
#- TS_EXTRA_ARGS=--exit-node-allow-lan-access # Optional: Allow LAN access when used as an exit node
restart: unless-stopped
ports:
- "8050:8050"

25
tandoor/.env Normal file
View File

@@ -0,0 +1,25 @@
# ---------------------------------------------------------------------------
# This template contains only required options.
# Visit the docs to find more https://docs.tandoor.dev/system/configuration/
# ---------------------------------------------------------------------------
# random secret key, use for example `base64 /dev/urandom | head -c50` to generate one
SECRET_KEY=2upOGCars1jUqN+TZ5l1ossqYeN9DztGj1uJ+H8QAskPmfxZFz
# your default timezone See https://timezonedb.com/time-zones for a list of timezones
TZ=America/New_York
# allowed hosts (see documentation), should be set to your hostname(s) but might be * (default) for some proxies/providers
# ALLOWED_HOSTS=*
# add only a database password if you want to run with the default postgres, otherwise change settings accordingly
DB_ENGINE=django.db.backends.postgresql
POSTGRES_HOST=db_recipes
POSTGRES_DB=djangodb
POSTGRES_PORT=5432
POSTGRES_USER=djangouser
POSTGRES_PASSWORD=password
TANDOOR_PORT=2295
GUNICORN_MEDIA=1

View File

@@ -0,0 +1,40 @@
services:
db_recipes:
restart: always
image: postgres:16-alpine
volumes:
- postgresql:/var/lib/postgresql/data
env_file:
- .env
deploy:
resources:
limits:
cpus: '1.0'
memory: 500M
web_recipes:
restart: always
image: vabene1111/recipes
ports:
- "2295:2295"
# - "5432:5432"
env_file:
- .env
volumes:
- ./staticfiles:/opt/recipes/staticfiles
- ./mediafiles:/opt/recipes/mediafiles
depends_on:
- db_recipes
deploy:
resources:
limits:
cpus: '1.0'
memory: 1000M
volumes:
staticfiles:
postgresql:
networks:
web:
driver: bridge

7
utils.sh Normal file
View File

@@ -0,0 +1,7 @@
### Copy Folder from Remote to Local ###
# scp -r root@45.79.204.92:/root/docker/gitea /root/setup/VPS_Setup/
### Activate Conda Shell ###
# eval "$(/root/miniconda3/bin/conda shell.bash hook)"