一些常用DockerFile和docker-compose.yml文件

go-zero中的配置用在gin框架中

Dockerfile

FROM golang:alpine AS builder

LABEL stage=gobuilder

ENV CGO_ENABLED 0
ENV GOPROXY https://goproxy.cn,direct
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories

RUN apk update --no-cache && apk add --no-cache tzdata

WORKDIR /build

ADD go.mod .
ADD go.sum .
RUN go mod download
COPY . .
COPY etc/env.yaml /app/etc/env.yaml
RUN go build -ldflags="-s -w" -o /app/{项目名称} main.go


FROM scratch

COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt
COPY --from=builder /usr/share/zoneinfo/Asia/Shanghai /usr/share/zoneinfo/Asia/Shanghai
ENV TZ Asia/Shanghai

WORKDIR /app
COPY --from=builder /app/{项目名称} /app/{项目名称}
COPY --from=builder /app/etc/env.yaml /app/etc/env.yaml
VOLUME /tmp

CMD ["./{项目名称}"]

docker-compose.yml

version: '2'
services:
  web:
    image: {项目名称}:latest
    volumes:
      - ./logs:/app/logs
    ports:
      - "8080:8080"
    restart: unless-stopped

nginx常用docker-compose.yml

version: "2"
services:
  web:
    image: nginx:latest
    ports:
      - 80:80
    volumes:
      - ./html:/usr/share/nginx/html
      - ./conf.d:/etc/nginx/conf.d
    restart: unless-stopped

conf.d/default.conf

server {
    listen       80;
    listen  [::]:80;
    server_name  localhost;
    location /v1/ {
        proxy_pass   http://localhost:8080/v1/;
    }
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html;
    }
}

mysql常用docker-compose.yml

version: '3.1'
services:
  db:
    image: mysql
    restart: always
    container_name: mysql
    environment:
      MYSQL_ROOT_PASSWORD: 123456
    command:
      --default-authentication-plugin=mysql_native_password
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true
      --lower_case_table_names=1
    ports:
      - 3306:3306
    volumes:
      - ./data:/var/lib/mysql
      - ./conf:/etc/mysql/conf.d
      - ./logs:/logs

rabbitmq常用docker-compose.yml

version: "3.7"
services:
  rabbitmq:
    image: rabbitmq:3.11-management-alpine
    container_name: 'rabbitmq'
    ports:
      - 5672:5672
      - 15672:15672
    volumes:
      - rabbitmq_data:/var/lib/rabbitmq/
      - rabbitmq_log:/var/log/rabbitmq/

volumes:
  rabbitmq_data:
  rabbitmq_log:

redis常用docker-compose.yml

需要先写redis.conf文件, 不然会生成redis.conf目录
vi redis.conf
version: '3.1'
 
services:
  redis:
    image: redis:7.0.10
    container_name: 'redis'
    ports: 
      - 6379:6379
    volumes: 
      - ./redis.conf:/etc/redis/redis.conf
    command: 
      redis-server /etc/redis/redis.conf
    restart: always

php项目sendmail配置

项目基于laravel框架搭建
包含redis扩展和composer安装

Dockerfile

FROM php:8.1.18-cli
RUN pecl install redis-5.3.7 \
        && docker-php-ext-enable redis
COPY . /myapp

WORKDIR /mycomposer
RUN apt-get update && apt-get install -y zip
ENV COMPOSER_HOME /root/composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
ENV PATH $COMPOSER_HOME/vendor/bin:$PATH

WORKDIR /myapp
RUN composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/ \
        && COMPOSER_ALLOW_SUPERUSER=1 composer install
CMD [ "php", "/myapp/artisan", "serve", "--host=0.0.0.0", "--port=80"]

docker-compose.myl

version: '2'
services:
  web:
    image: sendmail:1.1
    volumes:
      - ./storage/logs:/myapp/storage/logs
      - ./.env:/myapp/.env
    ports:
      - "0.0.0.0:80:80"
    restart: unless-stopped

alist网盘配置

docker-compose.myl

version: '3.3'
services:
  alist:
    restart: always
    volumes:
      - ./data:/opt/alist/data
      - ./test:/test
    ports:
      - '5244:5244'
    environment:
      - PUID=0
      - PGID=0
      - UMASK=022
    container_name: alist
    image: 'xhofe/alist:latest'

gitea自建代码仓库配置

docker-compose.myl

version: "3"

networks:
  gitea:
    external: false

services:
  server:
    image: gitea/gitea:1.19.0-rc1
    container_name: gitea
    environment:
      - USER_UID=1000
      - USER_GID=1000
      - GITEA__database__DB_TYPE=mysql
      - GITEA__database__HOST=db:3306
      - GITEA__database__NAME=gitea
      - GITEA__database__USER=gitea
      - GITEA__database__PASSWD=gitea
    restart: always
    networks:
      - gitea
    volumes:
      - /home/git/.ssh/:/data/git/.ssh
      - ./gitea:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "3000:3000"
      - "22:22"
    depends_on:
      - db

  db:
    image: mysql:8
    restart: always
    environment:
      - MYSQL_ROOT_PASSWORD=gitea
      - MYSQL_USER=gitea
      - MYSQL_PASSWORD=gitea
      - MYSQL_DATABASE=gitea
    networks:
      - gitea
    volumes:
      - ./mysql:/var/lib/mysql

chatgpt-next-web网页GPT配置

docker-compose.myl

version: '3.3'
services:
    chat:
        restart: always
        ports:
            - '3000:3000'
        environment:
            - OPENAI_API_KEY=sk-XXXXXXXXXXXXXXXXXXXXXXXXX
            - CODE=mimamimamimamima,mimamima
        container_name: chat
        image: 'yidadaa/chatgpt-next-web:latest'

微信自动回复GPT配置,扫码登录

docker-compose.myl

version: '2.0'
services:
  wechat:
    image: zhayujie/chatgpt-on-wechat
    environment:
      OPEN_AI_API_BASE: 'https://openai.com/v1'
      OPEN_AI_API_KEY: 'sk-XXXXXXXXXXXXXXXXXXXXX'
      OPEN_AI_PROXY: ''
      SINGLE_CHAT_PREFIX: '[""]'
      SINGLE_CHAT_REPLY_PREFIX: ''
      GROUP_CHAT_PREFIX: '["@bot"]'
      GROUP_NAME_WHITE_LIST: '["ChatGPT测试群", "ChatGPT测试群2"]'
      IMAGE_CREATE_PREFIX: '["画", "看", "找"]'
      CONVERSATION_MAX_TOKENS: 2000
      SPEECH_RECOGNITION: "True"
      CHARACTER_DESC: '你是ChatGPT, 一个由OpenAI训练的大型语言模型, 你旨在回答并解决人们的任何问题,并且可以使用多种语言与人交流。'
      EXPIRES_IN_SECONDS: 3600
    restart: unless-stopped

远程桌面rustdesk远程控制

docker-compose.myl

version: '3'

networks:
  rustdesk-net:
    external: false

services:
  hbbs:
    container_name: hbbs
    ports:
      - 21115:21115
      - 21116:21116
      - 21116:21116/udp
    image: rustdesk/rustdesk-server:latest
    command: hbbs -r <你的域名>:21117
    volumes:
      - ./data:/root
    networks:
      - rustdesk-net
    depends_on:
      - hbbr
    restart: unless-stopped

  hbbr:
    container_name: hbbr
    ports:
      - 21117:21117
    image: rustdesk/rustdesk-server:latest
    command: hbbr
    volumes:
      - ./data:/root
    networks:
      - rustdesk-net
    restart: unless-stopped