mirror of
https://github.com/yanhao98/docker-example.git
synced 2025-07-12 23:50:49 +08:00
This commit is contained in:
89
.github/workflows/build-docker-image.yaml
vendored
Normal file
89
.github/workflows/build-docker-image.yaml
vendored
Normal file
@ -0,0 +1,89 @@
|
||||
name: Build Docker Image
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
push:
|
||||
|
||||
env:
|
||||
DOCKER_IMAGE_NAME: yanhao98/docker-example
|
||||
GHCR_IMAGE_NAME: ${{ github.repository }}
|
||||
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
|
||||
DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
|
||||
GHCR_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
GHCR_USERNAME: ${{ github.repository_owner }}
|
||||
|
||||
jobs:
|
||||
docker:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
# - name: Login to DockerHub
|
||||
# uses: docker/login-action@v3
|
||||
# with:
|
||||
# registry: docker.io
|
||||
# username: ${{ env.DOCKER_USERNAME }}
|
||||
# password: ${{ env.DOCKER_PASSWORD }}
|
||||
|
||||
- name: Login to GHCR
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
registry: ghcr.io
|
||||
username: ${{ env.GHCR_USERNAME }}
|
||||
password: ${{ env.GHCR_TOKEN }}
|
||||
|
||||
- name: Set up QEMU
|
||||
uses: docker/setup-qemu-action@v3
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Cache Docker layers
|
||||
uses: actions/cache@v4
|
||||
with:
|
||||
path: |
|
||||
/tmp/.buildx-cache
|
||||
key: ${{ runner.os }}-buildx-${{ github.sha }}
|
||||
restore-keys: |
|
||||
${{ runner.os }}-buildx-
|
||||
|
||||
- name: Extract metadata
|
||||
id: meta
|
||||
uses: docker/metadata-action@v5
|
||||
with:
|
||||
images: |
|
||||
# docker.io/${{ env.DOCKER_IMAGE_NAME }}
|
||||
ghcr.io/${{ env.GHCR_IMAGE_NAME }}
|
||||
tags: |
|
||||
type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') }}
|
||||
type=semver,pattern={{major}}
|
||||
type=raw,value=dev,enable=${{ github.ref == 'refs/heads/dev' }}
|
||||
|
||||
# type=pep440,pattern={{raw}},enable=${{ startsWith(github.ref, 'refs/tags/') }}
|
||||
|
||||
# type=schedule,pattern={{date 'YYYYMMDD-HHmmss' tz='UTC'}}
|
||||
# type=ref,event=branch
|
||||
# type=ref,event=pr
|
||||
# type=semver,pattern={{version}}
|
||||
# type=semver,pattern={{major}}.{{minor}}.{{patch}}
|
||||
# type=sha
|
||||
|
||||
- name: Print metadata
|
||||
run: |
|
||||
echo "tags: ${{ steps.meta.outputs.tags }}"
|
||||
echo "labels: ${{ steps.meta.outputs.labels }}"
|
||||
|
||||
- name: Build and push
|
||||
uses: docker/build-push-action@v6
|
||||
with:
|
||||
context: .
|
||||
platforms: linux/amd64, linux/arm64
|
||||
push: true
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
||||
file: ./Dockerfile
|
||||
# cache-from: type=gha
|
||||
# cache-to: type=gha,mode=max
|
||||
cache-from: type=local,src=/tmp/.buildx-cache
|
||||
cache-to: type=local,dest=/tmp/.buildx-cache
|
5
Dockerfile
Normal file
5
Dockerfile
Normal file
@ -0,0 +1,5 @@
|
||||
FROM alpine
|
||||
|
||||
RUN set -ex \
|
||||
&& apk add --no-cache \
|
||||
bash
|
15
docker-swarm/01_global-nginx.md
Normal file
15
docker-swarm/01_global-nginx.md
Normal file
@ -0,0 +1,15 @@
|
||||
```bash
|
||||
docker run --rm -p 8092:80 \
|
||||
--name getting-started \
|
||||
docker/getting-started:latest
|
||||
```
|
||||
|
||||
```bash
|
||||
docker service create --name global-nginx --mode global --publish 45679:80 nginx:latest
|
||||
docker service ls
|
||||
docker service ps global-nginx
|
||||
docker service ps global-nginx --format "table {{.Name}}\t{{.Node}}\t{{.DesiredState}}\t{{.CurrentState}}\t{{.Ports}}"
|
||||
docker service logs -f global-nginx -n 10
|
||||
docker service inspect global-nginx
|
||||
docker service rm global-nginx
|
||||
```
|
110
docker-swarm/README.md
Normal file
110
docker-swarm/README.md
Normal file
@ -0,0 +1,110 @@
|
||||
Docker Stack 是 Docker 中用于部署和管理一组相关服务的工具,主要用于在 Docker Swarm 模式下进行应用编排。以下是关于 Docker Stack 的必备知识点和常用命令:
|
||||
|
||||
### 必备知识点
|
||||
|
||||
1. **Docker Swarm 模式**:
|
||||
- Docker Stack 依赖于 Docker Swarm 模式,Swarm 是 Docker 自带的集群管理工具,允许你将多个 Docker 主机聚合成一个虚拟的 Docker 主机。
|
||||
- Swarm 模式下,可以将一组节点(Node)组织在一起,并将服务(Service)分配到这些节点上。
|
||||
|
||||
#### 节点管理
|
||||
|
||||
- 在 Swarm 集群中,节点分为管理节点(Manager Node)和工作节点(Worker Node)。管理节点负责集群的管理和服务的编排,工作节点负责运行实际的服务实例。
|
||||
|
||||
- 添加节点到 Swarm 集群时,需要使用特定的加入 token:
|
||||
|
||||
**获取工作节点加入 token**:
|
||||
|
||||
```bash
|
||||
docker swarm join-token worker
|
||||
```
|
||||
|
||||
**获取管理节点加入 token**:
|
||||
|
||||
```bash
|
||||
docker swarm join-token manager
|
||||
```
|
||||
|
||||
通过上述命令获取的 token 可以用于将新的 Docker 主机加入到 Swarm 集群中。例如,要将一个节点作为工作节点加入 Swarm,可以使用以下命令:
|
||||
|
||||
```bash
|
||||
docker swarm join --token <worker-token> <manager-ip>:<port>
|
||||
```
|
||||
|
||||
2. **Stack**:
|
||||
|
||||
- Stack 是一组相关联的服务集合,可以将其视为一个更高级别的应用单元。一个 Stack 通常包含多个服务,这些服务可以互相通信,构成完整的应用。
|
||||
|
||||
3. **Compose 文件**:
|
||||
- Docker Stack 通常使用 Docker Compose 文件 (`docker-compose.yml`) 来定义 Stack 中的服务、网络、卷等。这个文件描述了服务的配置,例如镜像、环境变量、端口映射等。
|
||||
|
||||
4. **服务(Service)**:
|
||||
- 服务是运行在 Swarm 中的一个容器的实例,Stack 中的每一个服务都可以由多个副本(Replica)组成,以实现负载均衡和高可用性。
|
||||
|
||||
5. **网络与存储**:
|
||||
- 在 Stack 中,可以定义多个服务共享的网络和存储卷,以确保不同服务之间的通信和数据持久化。
|
||||
- Overlay 网络:如果你的 Stack 中包含需要跨多个节点通信的服务,例如使用 Caddy 进行反向代理,你需要创建并使用 Docker 的 Overlay 网络。这种网络类型允许在多个 Docker 节点之间安全地连接服务,适用于分布式应用场景。
|
||||
|
||||
|
||||
### 常用命令
|
||||
|
||||
1. **部署一个 Stack**:
|
||||
```bash
|
||||
docker stack deploy -c <compose-file> <stack-name>
|
||||
```
|
||||
- 该命令用于根据指定的 Compose 文件部署一个 Stack。例如:
|
||||
```bash
|
||||
docker stack deploy --with-registry-auth -c docker-compose.yml my_stack
|
||||
```
|
||||
|
||||
2. **查看已部署的 Stack**:
|
||||
```bash
|
||||
docker stack ls
|
||||
```
|
||||
- 列出当前 Swarm 集群中所有已部署的 Stack。
|
||||
|
||||
3. **查看 Stack 中的服务**:
|
||||
```bash
|
||||
docker stack services <stack-name>
|
||||
```
|
||||
- 列出指定 Stack 中的所有服务。例如:
|
||||
```bash
|
||||
docker stack services my_stack
|
||||
```
|
||||
|
||||
4. **查看 Stack 中的任务(Task)**:
|
||||
```bash
|
||||
docker stack ps <stack-name>
|
||||
```
|
||||
- 列出指定 Stack 中所有服务的运行任务,显示服务的实例分布和状态。
|
||||
|
||||
5. **移除一个 Stack**:
|
||||
```bash
|
||||
docker stack rm <stack-name>
|
||||
```
|
||||
- 删除指定的 Stack 及其所有相关服务。
|
||||
|
||||
6. **查看 Stack 中的服务日志**:
|
||||
```bash
|
||||
docker service logs <service-name>
|
||||
```
|
||||
- 查看 Stack 中某个服务的日志输出,例如:
|
||||
```bash
|
||||
docker service logs my_stack_my_service
|
||||
docker service logs -f -n 10 global-nginx
|
||||
```
|
||||
|
||||
7. **更新 Stack 中的服务**:
|
||||
```bash
|
||||
docker service update --image <new-image> <service-name>
|
||||
```
|
||||
- 更新 Stack 中某个服务的镜像版本,例如:
|
||||
```bash
|
||||
docker service update --image my_image:latest my_stack_my_service
|
||||
```
|
||||
|
||||
### 注意事项
|
||||
|
||||
- 部署 Stack 之前,需要确保 Docker 节点已经处于 Swarm 模式(`docker swarm init --advertise-addr <ip>:2377`),否则 Stack 将无法部署。
|
||||
- Stack 中的服务与 Docker Compose 中的服务非常相似,但它们是为 Swarm 环境设计的,可以自动进行服务的伸缩和故障恢复。
|
||||
- 如果你使用私有镜像仓库,记得使用 `--with-registry-auth` 选项,以确保所有 Swarm 节点能够成功拉取私有镜像。
|
||||
- 如果使用 Caddy 作为反向代理,建议在 Stack 中定义一个 Overlay 网络,并确保 Caddy 和其他服务都在同一网络下,以保证跨节点的服务通信和负载均衡。
|
8
docker-swarm/overlay_network/compose.caddy.yml
Normal file
8
docker-swarm/overlay_network/compose.caddy.yml
Normal file
@ -0,0 +1,8 @@
|
||||
services:
|
||||
caddy:
|
||||
image: caddy:<version>
|
||||
networks:
|
||||
- my-overlay-network
|
||||
networks:
|
||||
my-overlay-network:
|
||||
external: true
|
8
docker-swarm/overlay_network/compose.stack.yml
Normal file
8
docker-swarm/overlay_network/compose.stack.yml
Normal file
@ -0,0 +1,8 @@
|
||||
services:
|
||||
my-backend:
|
||||
image: <backend_image>
|
||||
networks:
|
||||
# docker network create --attachable --driver overlay my-overlay-network
|
||||
default:
|
||||
name: my-overlay-network
|
||||
external: true
|
6
renovate.json
Normal file
6
renovate.json
Normal file
@ -0,0 +1,6 @@
|
||||
{
|
||||
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||
"extends": [
|
||||
"https://git.1-h.cc/examples/renovate-example/raw/branch/main/default.json5"
|
||||
]
|
||||
}
|
Reference in New Issue
Block a user