Compare commits

...

17 Commits

Author SHA1 Message Date
45f2c61c17 Merge pull request 'docker swarm' (#14) from feat/add-docker into main
All checks were successful
Build, Test & Publish / Build (push) Successful in 23s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 1m13s
Build, Test & Publish / Deploy to Infrastructure (push) Successful in 2m25s
Reviewed-on: #14
2025-10-22 13:13:33 +11:00
dd30ade94b docker swarm
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 26s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-22 13:11:59 +11:00
587287fb82 Merge pull request 'update commands for postgres' (#13) from fix/postgres into main
All checks were successful
Build, Test & Publish / Build (push) Successful in 27s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 29s
Build, Test & Publish / Deploy to Infrastructure (push) Successful in 1m8s
Reviewed-on: #13
2025-10-20 12:23:57 +11:00
78788f05e3 Merge branch 'main' into fix/postgres
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 27s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-20 12:23:45 +11:00
87d81bb447 revert so can deploy
All checks were successful
Build, Test & Publish / Build (push) Successful in 31s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 1m13s
Build, Test & Publish / Deploy to Infrastructure (push) Successful in 1m9s
2025-10-20 12:20:05 +11:00
52427c453e change to use var
Some checks failed
Build, Test & Publish / Build (push) Successful in 24s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 30s
Build, Test & Publish / Deploy to Infrastructure (push) Failing after 8m59s
2025-10-19 21:47:12 +11:00
6e5d4e39e7 try fix job nomad
Some checks failed
Build, Test & Publish / Build (push) Successful in 24s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 29s
Build, Test & Publish / Deploy to Infrastructure (push) Failing after 11s
2025-10-19 21:43:39 +11:00
ea1bc210c6 Merge pull request 'fix var' (#12) from feat/new-infra into main
Some checks failed
Build, Test & Publish / Build (push) Successful in 25s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 30s
Build, Test & Publish / Deploy to Infrastructure (push) Failing after 11s
Reviewed-on: #12
2025-10-19 21:40:24 +11:00
acee9670d0 fix var
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 23s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-19 21:39:32 +11:00
c2cf7bc905 Merge pull request 'added noamad deployment' (#11) from feat/new-infra into main
Some checks failed
Build, Test & Publish / Build (push) Successful in 7m57s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 30s
Build, Test & Publish / Deploy to Infrastructure (push) Failing after 13s
Reviewed-on: #11
2025-10-19 21:27:55 +11:00
aca87e3db1 added noamad deployment
Some checks failed
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been cancelled
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been cancelled
Build, Test & Publish / Build (pull_request) Has been cancelled
2025-10-19 21:26:43 +11:00
54ed8d999f update commands for postgres
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 26s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-16 08:33:38 +11:00
afee68fa90 Merge pull request 'fix' (#10) from fix/postgres into main
All checks were successful
Build, Test & Publish / Build (push) Successful in 25s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 32s
Build, Test & Publish / Deploy to Infrastructure (push) Successful in 2m31s
Reviewed-on: #10
2025-10-15 16:14:30 +11:00
32f943ac34 fix
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 27s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-15 16:14:10 +11:00
50834327da Merge pull request 'feat/postgres' (#9) from feat/postgres into main
All checks were successful
Build, Test & Publish / Build (push) Successful in 23s
Build, Test & Publish / Build and Publish Container Image (push) Successful in 1m11s
Build, Test & Publish / Deploy to Infrastructure (push) Successful in 2m35s
Reviewed-on: #9
2025-10-15 13:17:39 +11:00
79f2ea8d10 Merge branch 'doc/api-key-auth'
All checks were successful
Build, Test & Publish / Build (pull_request) Successful in 31s
Build, Test & Publish / Build and Publish Container Image (pull_request) Has been skipped
Build, Test & Publish / Deploy to Infrastructure (pull_request) Has been skipped
2025-10-15 13:16:42 +11:00
0948d3e768 postgres commands 2025-10-15 13:16:21 +11:00
7 changed files with 149 additions and 2 deletions

View File

@@ -46,6 +46,7 @@ jobs:
images: liamsgit.dev/LiamPietralla/code-snippets images: liamsgit.dev/LiamPietralla/code-snippets
tags: | tags: |
type=raw,value=latest type=raw,value=latest
type=sha,value=${{ github.sha }}
- name: Login to Registry - name: Login to Registry
uses: docker/login-action@v3 uses: docker/login-action@v3
@@ -98,5 +99,16 @@ jobs:
ansible-playbook infra/ansible/deploy-playbook.yml --private-key private.key --inventory hosts.ini ansible-playbook infra/ansible/deploy-playbook.yml --private-key private.key --inventory hosts.ini
env: env:
APP_HOST: ${{ secrets.APP_HOST }} APP_HOST: ${{ secrets.APP_HOST }}
REGISTRY_USERNAME: ${{ secrets.REGISTRY_USERNAME }} REGISTRY_USERNAME: ${{ secrets.DOCKER_USERNAME }}
REGISTRY_PASSWORD: ${{ secrets.REGISTRY_PASSWORD }} REGISTRY_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
# - name: Setup Nomad
# uses: hashicorp/setup-nomad@main
# with:
# nomad_version: '1.10.5'
# - name: Deploy Job to Nomad
# run: |
# nomad job run -var="version=${{ github.sha }}" infra/nomad/code-snippets.nomad.hcl
# env:
# NOMAD_ADDR: ${{ vars.NOMAD_ADDR }}

View File

@@ -76,6 +76,10 @@ export default defineConfig({
{ text: 'Local DB (PostgreSQL)', link: '/docker/local-db-pg' }, { text: 'Local DB (PostgreSQL)', link: '/docker/local-db-pg' },
] ]
}, },
{
text: 'Docker Swarm',
link: '/docker-swarm/',
},
{ {
text: 'EF Core', text: 'EF Core',
link: '/ef-core/', link: '/ef-core/',
@@ -119,6 +123,14 @@ export default defineConfig({
{ text: 'Custom Fetch', link: '/nuxt/custom-fetch' }, { text: 'Custom Fetch', link: '/nuxt/custom-fetch' },
] ]
}, },
{
text: 'Postgres',
link: '/postgres/',
collapsed: true,
items: [
{ text: 'Dump and Restore', link: '/postgres/dump-and-restore' },
]
},
{ {
text: 'PowerShell', text: 'PowerShell',
link: '/powershell/', link: '/powershell/',

View File

@@ -0,0 +1,27 @@
# Docker Swarm Snippets and Musings
## Updating Services
View services:
```bash
docker service ls
```
To scale a service up or down:
```bash
docker service scale <service_name>=<number_of_replicas>
```
Sometimes services get stuck or need to be forcefully updated:
```bash
docker service update --force <service_name>
```
::: tip
Sometimes if you need to force containers to restart use the update force (e.g. after restarting a node).
:::

View File

@@ -26,6 +26,10 @@ hero:
text: Docker text: Docker
link: /docker/ link: /docker/
- theme: alt
text: Docker Swarm
link: /docker-swarm/
- theme: alt - theme: alt
text: EF Core text: EF Core
link: /ef-core/ link: /ef-core/
@@ -46,6 +50,10 @@ hero:
text: Nuxt text: Nuxt
link: /nuxt/ link: /nuxt/
- theme: alt
text: Postgres
link: /postgres/
- theme: alt - theme: alt
text: PowerShell text: PowerShell
link: /powershell/ link: /powershell/

View File

@@ -0,0 +1,39 @@
# Dump and Restore
Handy commands for dumping and restoring Postgres databases.
::: info
Most of these commands are run using Docker as then we don't need to have Postgres installed locally.
If a different version of Postgres is needed, just change the version number in the Docker image tag.
:::
## Setup
Create a pgpass file in the current directory with the following content:
```
<server>:<port>:<database>:<username>:<password>
```
::: tip
Use `*` as a wildcard for any of the fields except for the password.
:::
## Dumping a Database
```bash
docker run --network host --rm -v .:/tmp -v ./pgpass:/root/.pgpass -e PGPASSFILE=/root/.pgpass postgres:16 bash -c "chmod 600 /root/.pgpass && pg_dump -h <server> -p <port> -U <username> <database> -f /tmp/$(date +%Y%m%d_%H%M%S)_<database>_dump.sql -c --if-exists"
```
## Dumping a Cluster
```bash
docker run --network host --rm -v .:/tmp -v ./pgpass:/root/.pgpass -e PGPASSFILE=/root/.pgpass postgres:16 bash -c "chmod 600 /root/.pgpass && pg_dumpall -h <server> -p <port> -U <username> -f /tmp/$(date +%Y%m%d_%H%M%S)_<server>_cluster_dump.sql -c --if-exists"
```
## Restoring from a SQL Dump
```bash
docker run --network host --rm -v .:/tmp -v ./pgpass:/root/.pgpass -e PGPASSFILE=/root/.pgpass postgres:16 bash -c "chmod 600 /root/.pgpass && psql -h <server> -p <port> -U <username> <database> -f /tmp/dump.sql -X"
```

3
docs/postgres/index.md Normal file
View File

@@ -0,0 +1,3 @@
# Postgres Snippets and Musings
#### [Dump and Restore](./dump-and-restore.md)

View File

@@ -0,0 +1,46 @@
variable "version" {
type = string
default = "latest"
}
job "code-snippets" {
datacenters = ["dc1"]
type = "service"
group "code-snippets" {
count = 1
network {
port "http" {
to = 80
}
}
task "code-snippets" {
driver = "docker"
config {
image = "liamsgit.dev/LiamPietralla/code-snippets:${var.version}"
force_pull = true
ports = ["http"]
}
service {
name = "code-snippets"
port = "http"
tags = [
"traefik.enable=true",
"traefik.http.routers.code-snippets.rule=PathPrefix(`/`)",
"traefik.http.routers.code-snippets.entrypoints=p5003"
]
check {
type = "http"
path = "/"
interval = "10s"
timeout = "2s"
}
}
}
}
}