AWS CodeBuild의 로컬 캐시를 작동 시키려고 노력했지만 제 인생에서 가장 기본적인 캐시도 작동하지 않습니다. 나의 궁극적 인 목표는 여기에 설명 된대로 Gradle 아티팩트를 캐시하는 것 입니다.
그러나 그것을 작동시킬 수 없었기 때문에 더 간단한 테스트를 시도했습니다. 여기서 각 빌드를 증가 /root/foo
시키는 파일로 디렉토리를 캐시하려고 시도했습니다 counter.txt
. 서로의 몇 분 내에 후속 빌드를 실행하면 로그에 “2”, “3”등이 표시됩니다. 그러나 실제로 심볼릭 링크가 설정되었지만 다음 빌드는 이전 counter.txt
파일을 보지 못하므로 무언가가 매우 깨졌습니다.
누구나 로컬 캐시가 실제로 CodeBuild에서 작동하는지 확인할 수 있습니까? 현재 기능이 손상되었는지 궁금합니다. 아니면 내가해야 할 일을 완전히 오해하고 있습니까?
buildspec.yml :
version: 0.2
phases:
install:
runtime-versions:
java: corretto8
build:
commands:
- pwd
- ls -l /root/
- ls -l /root/foo/
- ./cache-test.sh
- ls -l /root/
- ls -l /root/foo/
cache:
paths:
- '/root/foo/*'
cache-test.sh :
#!/bin/bash
if [ -d "/root/foo" ]; then
C=$(cat /root/foo/count.txt)
C=$((C + 1))
echo "*********************************"
echo "*********************************"
echo "Incrementing counter to $C"
echo $C > /root/foo/count.txt
echo "*********************************"
echo "*********************************"
else
mkdir /root/foo
echo "*********************************"
echo "*********************************"
echo "File not found, starting count at 1"
echo "*********************************"
echo "*********************************"
echo 1 > /root/foo/count.txt
fi
CodeBuild 출력 : (빠른 연속 실행시에도 동일한 출력)
[Container] 2019/11/10 22:35:08 Waiting for agent ping
[Container] 2019/11/10 22:35:10 Waiting for DOWNLOAD_SOURCE
[Container] 2019/11/10 22:35:10 Phase is DOWNLOAD_SOURCE
[Container] 2019/11/10 22:35:10 CODEBUILD_SRC_DIR=/codebuild/output/src905503483/src
[Container] 2019/11/10 22:35:10 YAML location is /codebuild/output/src905503483/src/buildspec.yml
[Container] 2019/11/10 22:35:10 No commands found for phase name: INSTALL
[Container] 2019/11/10 22:35:10 Processing environment variables
[Container] 2019/11/10 22:35:10 Moving to directory /codebuild/output/src905503483/src
[Container] 2019/11/10 22:35:10 MkdirAll: /codebuild/local-cache/custom/de68c9f22ae028d4e4dfb0d11bbb481053d28b1373db0d6a56ebee0416bf13b2/root/foo
[Container] 2019/11/10 22:35:10 Symlinking: /root/foo => /codebuild/local-cache/custom/de68c9f22ae028d4e4dfb0d11bbb481053d28b1373db0d6a56ebee0416bf13b2/root/foo
[Container] 2019/11/10 22:35:10 Registering with agent
[Container] 2019/11/10 22:35:10 Phases found in YAML: 2
[Container] 2019/11/10 22:35:10 BUILD: 6 commands
[Container] 2019/11/10 22:35:10 INSTALL: 0 commands
[Container] 2019/11/10 22:35:10 Phase complete: DOWNLOAD_SOURCE State: SUCCEEDED
[Container] 2019/11/10 22:35:10 Phase context status code: Message:
[Container] 2019/11/10 22:35:11 Entering phase INSTALL
[Container] 2019/11/10 22:35:11 Running command echo "Installing corretto(OpenJDK) version 8 ..."
Installing corretto(OpenJDK) version 8 ...
[Container] 2019/11/10 22:35:11 Running command export JAVA_HOME="$JAVA_8_HOME"
[Container] 2019/11/10 22:35:11 Running command export JRE_HOME="$JRE_8_HOME"
[Container] 2019/11/10 22:35:11 Running command export JDK_HOME="$JDK_8_HOME"
[Container] 2019/11/10 22:35:11 Running command for tool_path in "$JAVA_8_HOME"/bin/* "$JRE_8_HOME"/bin/*;
do tool=`basename "$tool_path"`;
if [ $tool != 'java-rmi.cgi' ];
then
rm -f /usr/bin/$tool /var/lib/alternatives/$tool \
&& update-alternatives --install /usr/bin/$tool $tool $tool_path 20000;
fi;
done
[Container] 2019/11/10 22:35:11 Phase complete: INSTALL State: SUCCEEDED
[Container] 2019/11/10 22:35:11 Phase context status code: Message:
[Container] 2019/11/10 22:35:11 Entering phase PRE_BUILD
[Container] 2019/11/10 22:35:11 Phase complete: PRE_BUILD State: SUCCEEDED
[Container] 2019/11/10 22:35:11 Phase context status code: Message:
[Container] 2019/11/10 22:35:11 Entering phase BUILD
[Container] 2019/11/10 22:35:11 Running command pwd
/codebuild/output/src905503483/src
[Container] 2019/11/10 22:35:11 Running command ls -l /root/
total 4
lrwxrwxrwx 1 root root 103 Nov 10 22:35 foo -> /codebuild/local-cache/custom/de68c9f22ae028d4e4dfb0d11bbb481053d28b1373db0d6a56ebee0416bf13b2/root/foo
[Container] 2019/11/10 22:35:11 Running command ls -l /root/foo/
total 0
[Container] 2019/11/10 22:35:11 Running command ./cache-test.sh
cat: /root/foo/count.txt: No such file or directory
*********************************
*********************************
Incrementing counter to 1
*********************************
*********************************
[Container] 2019/11/10 22:35:11 Running command ls -l /root/
total 4
lrwxrwxrwx 1 root root 103 Nov 10 22:35 foo -> /codebuild/local-cache/custom/de68c9f22ae028d4e4dfb0d11bbb481053d28b1373db0d6a56ebee0416bf13b2/root/foo
[Container] 2019/11/10 22:35:11 Running command ls -l /root/foo/
total 4
-rw-r--r-- 1 root root 2 Nov 10 22:35 count.txt
[Container] 2019/11/10 22:35:11 Phase complete: BUILD State: SUCCEEDED
[Container] 2019/11/10 22:35:11 Phase context status code: Message:
[Container] 2019/11/10 22:35:11 Entering phase POST_BUILD
[Container] 2019/11/10 22:35:11 Phase complete: POST_BUILD State: SUCCEEDED
[Container] 2019/11/10 22:35:11 Phase context status code: Message:
CodeBuild 프로젝트 JSON :
{
"projects": [
{
"name": "test-project",
"arn": "arn:aws:codebuild:us-east-2:xxx:project/xxx",
"source": {
"type": "CODEPIPELINE",
"insecureSsl": false
},
"secondarySourceVersions": [],
"artifacts": {
"type": "CODEPIPELINE",
"name": "test-project",
"packaging": "NONE",
"encryptionDisabled": false
},
"secondaryArtifacts": [],
"cache": {
"type": "LOCAL",
"modes": [
"LOCAL_SOURCE_CACHE",
"LOCAL_CUSTOM_CACHE"
]
},
"environment": {
"type": "LINUX_CONTAINER",
"image": "aws/codebuild/amazonlinux2-x86_64-standard:1.0",
"computeType": "BUILD_GENERAL1_SMALL",
"environmentVariables": [],
"privilegedMode": false,
"imagePullCredentialsType": "CODEBUILD"
},
"serviceRole": "arn:aws:iam::xxx:role/service-role/xxx",
"timeoutInMinutes": 60,
"queuedTimeoutInMinutes": 480,
"encryptionKey": "arn:aws:kms:us-east-2:xxx:alias/aws/s3",
"tags": [],
"created": 1573364156.631,
"lastModified": 1573423155.674,
"badge": {
"badgeEnabled": false
},
"logsConfig": {
"cloudWatchLogs": {
"status": "ENABLED",
"groupName": "xxx",
"streamName": "xxx"
},
"s3Logs": {
"status": "DISABLED",
"encryptionDisabled": false
}
}
}
],
"projectsNotFound": []
}
답변
설명서는 명확하지 않지만 AWS CodeBuild Local 캐시는 디렉토리를 캐시 할 수만 있습니다 (작성 시점). AWS CodeBuild buildspec 사양에서 경로가 개별 파일 또는 와일드 카드 일 수 있지만 실제로 파일을 지정하면 오류가 발생 하기 때문에 약간 혼동 됩니다.
Unable to initialize cache download: only directories can be cached locally: ...
귀하의 예에서 캐시를 다음과 같이 지정하십시오.
cache:
paths:
- '/root/foo/*'
여기서 *는 foo 내의 모든 개별 파일과 폴더를 나타내지 만 폴더 만 캐시됩니다.
전체 디렉토리를 지정하면 작동합니다
cache:
paths:
- /root/foo/
답변
나는 제한된 성공으로 캐시를 스스로 작동 시키려고 노력했다.
공개 소스는 아니지만 다음과 같은 몇 가지 관찰 사항이 있습니다.
-
빌드 시간이 5 분 이상인 경우에만 캐시를 사용할 수 있습니다.
-
새 빌드가 동일한 빌드 호스트에 성공적으로 배치 된 경우 캐시를 사용할 수 있습니다.
-
새 빌드가 마지막 빌드 후 5-15 분 내에 실행되는 경우 캐시를 사용할 수 있습니다. 캐시는 마지막 빌드 시간에 따라 최대 15 분 동안 사용 가능한 상태로 유지 될 수 있습니다.
-
5 분을 초과하는 빌드에도 불구하고 캐시가 다른 빌드 호스트에 배치되어 캐시가 항상 작동하지 않을 수 있습니다.
-
또한 캐시가 새 빌드 속도를 5 분 미만으로 단축하는 경우 해당 빌드가 캐시되지 않아 후속 누락이 발생합니다.
CodeBuild 엔지니어는 이러한 방식으로 디자인해야 할 충분한 이유가 있다고 생각하지만 위의 제한으로 인해 로컬 캐시 기능이 제한적으로 사용됩니다.