问题描述
我正在使用 Testcontainers 通过 docker 启动 CockroachDB 实例。
我需要通过将属性 sql.defaults.experimental_temporary_tables.enabled
设置为 true 来启用对临时表的支持。
当机器运行时,我可以这样做:
docker exec -it CockroachDBHibernate ./cockroach sql --insecure -e "SET CLUSTER SETTING sql.defaults.experimental_temporary_tables.enabled = 'true';"
但是当我尝试使用 Testcontainers 运行相同的命令时:
container.execInContainer(
"./cockroach sql --insecure -e \"SET CLUSTER SETTING sql.defaults.experimental_temporary_tables.enabled = 'true';\"" );
OCI runtime exec Failed: exec Failed: container_linux.go:370: starting container process caused: exec: "./cockroach sql --insecure -e \"SET CLUSTER SETTING sql.defaults.experimental_temporary_tables.enabled = 'true';\"": stat ./cockroach sql --insecure -e "SET CLUSTER SETTING sql.defaults.experimental_temporary_tables.enabled = 'true';": no such file or directory: unkNown
请注意,错误通过 Container.ExecResult#getStdout()
可见。
退出代码是 126
我正在使用 Testcontainers 1.15.2
和 CockroachDB v20.2.5
谢谢
解决方法
container.execInContainer( "sh","-c","./cockroach sql --insecure -e \"SET CLUSTER SETTING sql.defaults.experimental_temporary_tables.enabled = 'true';\"" );