gpt4 book ai didi

postgresql - 如何在 Github Action 中将配置参数添加到 postgres 服务容器?

转载 作者:行者123 更新时间:2023-12-05 02:03:06 27 4
gpt4 key购买 nike

我正在使用 Github Actions Service Container 来启动一个 postgres 实例,如下所示:

name: Pull Request

on:
pull_request:
branches:
- main
- staging

jobs:
test-and-build:
runs-on: ubuntu-latest

services:
redis:
image: redis
ports:
- 6379:6379
postgres:
image: postgres
env:
POSTGRES_PASSWORD: postgres
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432

...

这可行,但我想通过禁用 fsync 来加速 postgres 实例,如下所述:https://dev.to/thejessleigh/speed-up-your-postgresql-unit-tests-with-one-weird-trick-364p

当在 docker 容器中本地运行 postgres 时,这极大地加快了我的运行速度,我希望在 Github Actions 中做同样的事情,但我很难看到我是如何配置图像的。似乎将 -c fsync=off 传递到上面的选项 block 会导致错误:

Exit code 125 returned from process: file name '/usr/bin/docker', arguments 'create --name 04a7236d2e964fccb8a7d95684b3cf05_postgres_0249b3 --label cc4956 --network github_network_3023184aafab424896b4e553d7ad9c38 --network-alias postgres -p 5432:5432 --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 -c fsync=off -e "POSTGRES_PASSWORD=postgres" -e GITHUB_ACTIONS=true -e CI=true postgres'.

有什么想法吗?

最佳答案

目前似乎没有办法将命令注入(inject)服务,以便您可以关闭 rsync 功能。 Github 操作使用不支持 -c 属性的创建命令。

但是您可以使用来自 https://github.com/bitnami/bitnami-docker-postgresql 的不同图像,它允许您通过环境变量将其关闭。这是一个例子:

name: Postgress test
on:
push:
jobs:
test:
runs-on: ubuntu-latest
services:
postgres:
image: 'bitnami/postgresql:latest'
env:
POSTGRESQL_DATABASE: test_postgress
POSTGRESQL_USERNAME: test_user
POSTGRESQL_PASSWORD: test_password
POSTGRESQL_FSYNC: "off"
options: >-
--health-cmd "pg_isready -d test_postgress -U test_user -p 5432"
--health-interval 10s
--health-timeout 5s
--health-retries 5
ports:
- 5432:5432
steps:
- run: echo test

旁注,这个环境在他们的自述文件中没有记录,但你可以在他们的源代码中找到它 https://github.com/bitnami/bitnami-docker-postgresql/blob/b2b1c1410293fc9a8b58a52b56f2ceabdac59bb1/9.6/debian-10/rootfs/opt/bitnami/scripts/libpostgresql.sh#L433-L445

关于postgresql - 如何在 Github Action 中将配置参数添加到 postgres 服务容器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65438055/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com