本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com
Lago 是一款用于计量和基于使用量计费的开源软件。对于需要处理复杂计费逻辑的企业而言,它是Chargebee、Recurly或Stripe Billing的最佳替代方案。
!Lago
如果您需要自动化备份、带SSL终止的反向代理、防火墙、自动化操作系统与软件更新,以及由Linux专家和开源爱好者组成的团队确保服务始终安全可用,可在elest.io上部署完全托管的Lago。
![部署]([***]
以下是帮助您开始创建容器的示例代码片段。
version: "3.8" services: db: image: elestio/postgres:15 restart: always environment: POSTGRES_DB: ${POSTGRES_DB} POSTGRES_USER: ${POSTGRES_USER} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} PGDATA: /data/postgres PGPORT: 5432 volumes: - ./storage/lago_postgres_data:/data/postgres ports: - 172.17.0.1:40211:5432 redis: image: elestio/redis:7.0 restart: always command: ["redis-server", "--requirepass", "${REDIS_PASSWORD}"] volumes: - ./storage/lago_redis_data:/data ports: - 172.17.0.1:31542:6379 api: image: elestio/lago-api:${SOFTWARE_VERSION_TAG} restart: always depends_on: - db - redis command: ["./scripts/start.sh"] environment: - LAGO_API_URL=[***]{DOMAIN}:34079 - DATABASE_URL=postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB} - REDIS_URL=redis://${REDIS_HOST}:${REDIS_PORT} - REDIS_PASSWORD=${REDIS_PASSWORD} - SECRET_KEY_BASE=${SECRET_KEY_BASE} - RAILS_ENV=production - RAILS_LOG_TO_STDOUT=${LAGO_RAILS_STDOUT} - SENTRY_DSN=${SENTRY_DSN} - LAGO_FRONT_URL=[***]{DOMAIN} - RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - LAGO_RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - LAGO_SIDEKIQ_WEB=${LAGO_SIDEKIQ_WEB} - ENCRYPTION_PRIMARY_KEY=${LAGO_ENCRYPTION_PRIMARY_KEY} - ENCRYPTION_DETERMINISTIC_KEY=${LAGO_ENCRYPTION_DETERMINISTIC_KEY} - ENCRYPTION_KEY_DERIVATION_SALT=${LAGO_ENCRYPTION_KEY_DERIVATION_SALT} - LAGO_USE_AWS_S3=${LAGO_USE_AWS_S3} - LAGO_AWS_S3_ACCESS_KEY_ID=${LAGO_AWS_S3_ACCESS_KEY_ID:-azerty123456} - LAGO_AWS_S3_SECRET_ACCESS_KEY=${LAGO_AWS_S3_SECRET_ACCESS_KEY:-azerty123456} - LAGO_AWS_S3_REGION=${LAGO_AWS_S3_REGION:-us-east-1} - LAGO_AWS_S3_BUCKET=${LAGO_AWS_S3_BUCKET:-bucket} - LAGO_AWS_S3_ENDPOINT=${LAGO_AWS_S3_ENDPOINT} - LAGO_USE_GCS=${LAGO_USE_GCS:-false} - LAGO_GCS_PROJECT=${LAGO_GCS_PROJECT:-} - LAGO_GCS_BUCKET=${LAGO_GCS_BUCKET:-} - LAGO_PDF_URL=${LAGO_PDF_URL:-[***]} - LAGO_REDIS_CACHE_URL=redis://${LAGO_REDIS_CACHE_HOST}:${LAGO_REDIS_CACHE_PORT} - LAGO_REDIS_CACHE_PASSWORD=${LAGO_REDIS_CACHE_PASSWORD} - LAGO_DISABLE_SEGMENT=${LAGO_DISABLE_SEGMENT} - LAGO_OAUTH_PROXY_URL=[***] - LAGO_LICENSE=${LAGO_LICENSE:-} volumes: - ./storage/lago_storage_data:/app/storage # 如果使用GCS,需要将凭据密钥文件放在此处 #- gcs_keyfile.json:/app/gcs_keyfile.json ports: - 172.17.0.1:17840:3000 front: image: elestio/lago-front:${SOFTWARE_VERSION_TAG} restart: always # 如果需要使用Let's Encrypt SSL,使用此命令 # command: "/bin/sh -c 'while :; do sleep 6h & wait $${!}; nginx -s reload; done & nginx -g \"daemon off;\"'" depends_on: - api environment: - API_URL=[***]{DOMAIN}:34079 - APP_ENV=production - CODEGEN_API=[***]{DOMAIN}:34079 - LAGO_DISABLE_SIGNUP=${LAGO_DISABLE_SIGNUP} - LAGO_OAUTH_PROXY_URL=[***] - SENTRY_DSN=${SENTRY_DSN_FRONT} ports: - 172.17.0.1:34746:80 # - 443:443 # 使用Let's Encrypt SSL # volumes: # - ./extra/nginx-letsencrypt.conf:/etc/nginx/conf.d/default.conf # - ./extra/certbot/conf:/etc/letsencrypt # - ./extra/certbot/www:/var/www/certbot # 使用自签名SSL证书 # volumes: # - ./extra/nginx-selfsigned.conf:/etc/nginx/conf.d/default.conf # - ./extra/ssl/nginx-selfsigned.crt:/etc/ssl/certs/nginx-selfsigned.crt # - ./extra/ssl/nginx-selfsigned.key:/etc/ssl/private/nginx-selfsigned.key # - ./extra/ssl/dhparam.pem:/etc/ssl/certs/dhparam.pem # 仅用于Let's Encrypt SSL支持 # certbot: # image: certbot/certbot # entrypoint: "/bin/sh -c 'trap exit TERM; while :; do certbot renew; sleep 12h & wait $${!}; done;'" # volumes: # - ./extra/certbot/conf:/etc/letsencrypt # - ./extra/certbot/www:/var/www/certbot api-worker: image: elestio/lago-api:${SOFTWARE_VERSION_TAG} restart: always depends_on: - api command: ["./scripts/start.worker.sh"] environment: - LAGO_API_URL=[***]{DOMAIN}:34079 - DATABASE_URL=postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB} - REDIS_URL=redis://${REDIS_HOST}:${REDIS_PORT} - REDIS_PASSWORD=${REDIS_PASSWORD} - SECRET_KEY_BASE=${SECRET_KEY_BASE} - RAILS_ENV=production - RAILS_LOG_TO_STDOUT=${LAGO_RAILS_STDOUT} - SENTRY_DSN=${SENTRY_DSN} - LAGO_RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - ENCRYPTION_PRIMARY_KEY=${LAGO_ENCRYPTION_PRIMARY_KEY} - ENCRYPTION_DETERMINISTIC_KEY=${LAGO_ENCRYPTION_DETERMINISTIC_KEY} - ENCRYPTION_KEY_DERIVATION_SALT=${LAGO_ENCRYPTION_KEY_DERIVATION_SALT} - LAGO_FRONT_URL=[***]{DOMAIN} - LAGO_USE_AWS_S3=${LAGO_USE_AWS_S3} - LAGO_AWS_S3_ACCESS_KEY_ID=${LAGO_AWS_S3_ACCESS_KEY_ID:-azerty123456} - LAGO_AWS_S3_SECRET_ACCESS_KEY=${LAGO_AWS_S3_SECRET_ACCESS_KEY:-azerty123456} - LAGO_AWS_S3_REGION=${LAGO_AWS_S3_REGION:-us-east-1} - LAGO_AWS_S3_BUCKET=${LAGO_AWS_S3_BUCKET:-bucket} - LAGO_AWS_S3_ENDPOINT=${LAGO_AWS_S3_ENDPOINT} - LAGO_USE_GCS=${LAGO_USE_GCS} - LAGO_GCS_PROJECT=${LAGO_GCS_PROJECT:-} - LAGO_GCS_BUCKET=${LAGO_GCS_BUCKET:-} - LAGO_PDF_URL=${LAGO_PDF_URL:-[***]} - LAGO_REDIS_CACHE_URL=redis://${LAGO_REDIS_CACHE_HOST}:${LAGO_REDIS_CACHE_PORT} - LAGO_REDIS_CACHE_PASSWORD=${LAGO_REDIS_CACHE_PASSWORD} - LAGO_DISABLE_SEGMENT=${LAGO_DISABLE_SEGMENT} volumes: - ./storage/lago_storage_data:/app/storage api-clock: image: elestio/lago-api:${SOFTWARE_VERSION_TAG} restart: always depends_on: - api command: ["./scripts/start.clock.sh"] environment: - LAGO_API_URL=[***]{DOMAIN}:34079 - DATABASE_URL=postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB} - REDIS_URL=redis://${REDIS_HOST}:${REDIS_PORT} - REDIS_PASSWORD=${REDIS_PASSWORD} - SECRET_KEY_BASE=${SECRET_KEY_BASE} - RAILS_ENV=production - RAILS_LOG_TO_STDOUT=${LAGO_RAILS_STDOUT} - SENTRY_DSN=${SENTRY_DSN} - LAGO_RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - RSA_PRIVATE_KEY=${LAGO_RSA_PRIVATE_KEY} - ENCRYPTION_PRIMARY_KEY=${LAGO_ENCRYPTION_PRIMARY_KEY} - ENCRYPTION_DETERMINISTIC_KEY=${LAGO_ENCRYPTION_DETERMINISTIC_KEY} - ENCRYPTION_KEY_DERIVATION_SALT=${LAGO_ENCRYPTION_KEY_DERIVATION_SALT} pdf: image: getlago/lago-gotenberg:7 restart: always pgadmin4: image: dpage/pgadmin4:latest restart: always environment: PGADMIN_DEFAULT_EMAIL: ${ADMIN_EMAIL} PGADMIN_DEFAULT_PASSWORD: ${ADMIN_PASSWORD} PGADMIN_LISTEN_PORT: 8080 ports: - "172.17.0.1:15683:8080" volumes: - ./servers.json:/pgadmin4/servers.json
| 变量名 | 示例值 |
|---|---|
| SOFTWARE_VERSION_TAG | latest |
| ADMIN_EMAIL | *** |
| ADMIN_PASSWORD | your-password |
| DOMAIN | your.domain.com |
| MAIL_HOST | 172.17.0.1 |
| MAIL_PORT | 25 |
| FROM_EMAIL | *** |
| POSTGRES_DB | lago |
| POSTGRES_USER | postgres |
| POSTGRES_PASSWORD | your-password |
| POSTGRES_HOST | db |
| POSTGRES_PORT | 5432 |
| REDIS_HOST | redis |
| REDIS_PORT | 6379 |
| REDIS_PASSWORD | your-password |
| LAGO_REDIS_CACHE_HOST | redis |
| LAGO_REDIS_CACHE_PORT | 6379 |
| LAGO_REDIS_CACHE_PASSWORD | your-password |
| LAGO_RAILS_STDOUT | true |
| LAGO_USE_AWS_S3 | false |
| LAGO_DISABLE_SIGNUP | false |
您可以通过以下地址访问Web UI:[***]
Elestio Lago Docker镜像将容器日志发送到stdout。要查看日志,可使用以下命令:
docker-compose logs -f
要停止服务栈,可使用以下命令:
docker-compose down
为简化备份和恢复操作,我们使用文件夹卷挂载。您只需使用docker-compose down停止服务栈,然后备份docker-compose.yml文件所在目录下的所有文件和子文件夹即可。
例如,若要创建ZIP归档,请导航到包含docker-compose.yml文件的目录,并使用以下命令:
zip -r myarchive.zip .
要从ZIP归档恢复,请使用以下命令将归档解压缩到原始文件夹:
unzip myarchive.zip -d /path/to/original/folder
备份完成后,可使用以下命令重新启动服务栈:
docker-compose up -d
就是这样!通过这些简单步骤,您可以使用Docker Compose轻松备份和恢复数据卷。
Lago Github仓库
Lago文档
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429