From 816c0a49606f2f259bfc3020e975f79936642663 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 14:53:32 +0100 Subject: [PATCH 001/117] ci(jenkins): support windows build --- Jenkinsfile | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index 1212a2c5bf..b9ef96a753 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -90,6 +90,9 @@ pipeline { parallelTasks['linting'] = linting() } + // Windows + parallelTasks['Windows-Node.js-10'] = generateStepForWindows(version: '10') + parallel(parallelTasks) } } @@ -429,3 +432,33 @@ def getSmartTAVContext() { } } } + +def generateStepForWindows(Map params = [:]){ + def version = params?.version + def edge = params.containsKey('edge') ? params.edge : false + def disableAsyncHooks = params.get('disableAsyncHooks', false) + return { + node('windows-2019-immutable'){ + try { + env.HOME = "${WORKSPACE}" + if (disableAsyncHooks) { + env.ELASTIC_APM_ASYNC_HOOKS = 'false' + } + deleteDir() + unstash 'source' + dir(BASE_DIR){ + powershell label: 'Install tools', script: """ + .\\test\\script\\appveyor\\install-redis.ps1 + .\\test\\script\\appveyor\\install-elasticsearch.ps1 + .\\test\\script\\appveyor\\install-cassandra.ps1 + Install-Product node ${version} + """ + bat 'npm install' + bat 'node test/test.js' + } + } catch(e){ + error(e.toString()) + } + } + } +} From 2fc0dfd20f06454778147275e9c514678afc816b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 14:54:27 +0100 Subject: [PATCH 002/117] chore: for testing purposes --- Jenkinsfile | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index b9ef96a753..71ed9428e3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -28,10 +28,10 @@ pipeline { } parameters { booleanParam(name: 'Run_As_Master_Branch', defaultValue: false, description: 'Allow to run any steps on a PR, some steps normally only run on master branch.') - booleanParam(name: 'bench_ci', defaultValue: true, description: 'Enable benchmarks.') - booleanParam(name: 'tav_ci', defaultValue: true, description: 'Enable TAV tests.') + booleanParam(name: 'bench_ci', defaultValue: false, description: 'Enable benchmarks.') + booleanParam(name: 'tav_ci', defaultValue: false, description: 'Enable TAV tests.') booleanParam(name: 'tests_ci', defaultValue: true, description: 'Enable tests.') - booleanParam(name: 'test_edge_ci', defaultValue: true, description: 'Enable tests for edge versions of nodejs.') + booleanParam(name: 'test_edge_ci', defaultValue: false, description: 'Enable tests for edge versions of nodejs.') } stages { /** @@ -76,7 +76,7 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - def parallelTasksWithoutAsyncHooks = [:] + /*def parallelTasksWithoutAsyncHooks = [:] node['NODEJS_VERSION'].each{ version -> parallelTasks["Node.js-${version}"] = generateStep(version: version) if (!version.startsWith('6')) { @@ -89,7 +89,7 @@ pipeline { // Linting in parallel with the test stage parallelTasks['linting'] = linting() } - + */ // Windows parallelTasks['Windows-Node.js-10'] = generateStepForWindows(version: '10') From ada9d6405da0375e40e5ceef10b2493a69deb4be Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 15:53:30 +0100 Subject: [PATCH 003/117] ci(jenkins): support java and minor changes --- Jenkinsfile | 1 + test/script/appveyor/install-cassandra.ps1 | 4 +++- test/script/appveyor/install-java.ps1 | 5 +++++ test/script/appveyor/install-redis.ps1 | 10 +++++++--- 4 files changed, 16 insertions(+), 4 deletions(-) create mode 100644 test/script/appveyor/install-java.ps1 diff --git a/Jenkinsfile b/Jenkinsfile index 71ed9428e3..57698690e2 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -448,6 +448,7 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR){ powershell label: 'Install tools', script: """ + .\\test\\script\\appveyor\\install-java.ps1 .\\test\\script\\appveyor\\install-redis.ps1 .\\test\\script\\appveyor\\install-elasticsearch.ps1 .\\test\\script\\appveyor\\install-cassandra.ps1 diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 index 6f5b9e9701..76f5730a82 100755 --- a/test/script/appveyor/install-cassandra.ps1 +++ b/test/script/appveyor/install-cassandra.ps1 @@ -1,6 +1,7 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" +Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan $cassandraVersion = "3.11.3" $downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" $extractRoot = "$env:USERPROFILE" @@ -9,11 +10,12 @@ $tarPath = "$extractRoot\cassandra.tar" $cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -appveyor DownloadFile $downloadUrl -FileName $tgzPath +(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) Write-Host "Extracting Cassandra..." 7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null 7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null +del $tgzPath Write-Host "Starting Cassandra..." Start-Process $cassandra -PassThru diff --git a/test/script/appveyor/install-java.ps1 b/test/script/appveyor/install-java.ps1 new file mode 100644 index 0000000000..620cd2a309 --- /dev/null +++ b/test/script/appveyor/install-java.ps1 @@ -0,0 +1,5 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Installing java..." +& choco install jdk8 -y --no-progress -r --version 8.0.211 diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 index c8506ff4b0..bc2a15cfdb 100755 --- a/test/script/appveyor/install-redis.ps1 +++ b/test/script/appveyor/install-redis.ps1 @@ -1,10 +1,14 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Write-Host "Downloading Redis..." -ForegroundColor Cyan +Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan +$redisVersion = "2.8.19" $redisRoot = "$env:SYSTEMDRIVE\Redis" -$zipPath = "$($env:USERPROFILE)\redis-2.8.19.zip" -(New-Object Net.WebClient).DownloadFile('https://github.com/MSOpenTech/redis/releases/download/win-2.8.19/redis-2.8.19.zip', $zipPath) +$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" +$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" + +Write-Host "Downloading Redis..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) 7z x $zipPath -y -o"$redisRoot" | Out-Null del $zipPath From 30bc58d739137b8e13eaf033661e9928f024b015 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 16:06:45 +0100 Subject: [PATCH 004/117] chore: let's print the env --- test/script/appveyor/install-java.ps1 | 3 +++ 1 file changed, 3 insertions(+) diff --git a/test/script/appveyor/install-java.ps1 b/test/script/appveyor/install-java.ps1 index 620cd2a309..4ff1b33442 100644 --- a/test/script/appveyor/install-java.ps1 +++ b/test/script/appveyor/install-java.ps1 @@ -1,5 +1,8 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" +Write-Host "Environment..." -ForegroundColor Cyan +Get-ChildItem Env: | Sort Name + Write-Host "Installing java..." & choco install jdk8 -y --no-progress -r --version 8.0.211 From 570dc045ece22dd909a426f4bd77770435781410 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 16:39:09 +0100 Subject: [PATCH 005/117] ci(jenkins): bump version with jdk --- test/script/appveyor/install-elasticsearch.ps1 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 index d4da2cfbc8..1c7fe9d515 100755 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -2,8 +2,8 @@ $ErrorActionPreference = "Stop" Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "6.1.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion).zip" +$esVersion = "7.3.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" $extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" $esRoot = "$extractRoot\elasticsearch-$esVersion" From fed751ec20d8eece001f8e805db75353703f8f73 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 16:53:33 +0100 Subject: [PATCH 006/117] ci(jenkins): unset JAVA_HOME to use the bundle --- Jenkinsfile | 1 - test/script/appveyor/install-elasticsearch.ps1 | 1 + test/script/appveyor/install-java.ps1 | 8 -------- 3 files changed, 1 insertion(+), 9 deletions(-) delete mode 100644 test/script/appveyor/install-java.ps1 diff --git a/Jenkinsfile b/Jenkinsfile index 57698690e2..71ed9428e3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -448,7 +448,6 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR){ powershell label: 'Install tools', script: """ - .\\test\\script\\appveyor\\install-java.ps1 .\\test\\script\\appveyor\\install-redis.ps1 .\\test\\script\\appveyor\\install-elasticsearch.ps1 .\\test\\script\\appveyor\\install-cassandra.ps1 diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 index 1c7fe9d515..8e6ac0f348 100755 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -7,6 +7,7 @@ $downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsear $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" $extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" $esRoot = "$extractRoot\elasticsearch-$esVersion" +[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") Write-Host "Downloading Elasticsearch..." (New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) diff --git a/test/script/appveyor/install-java.ps1 b/test/script/appveyor/install-java.ps1 deleted file mode 100644 index 4ff1b33442..0000000000 --- a/test/script/appveyor/install-java.ps1 +++ /dev/null @@ -1,8 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Environment..." -ForegroundColor Cyan -Get-ChildItem Env: | Sort Name - -Write-Host "Installing java..." -& choco install jdk8 -y --no-progress -r --version 8.0.211 From 252e8d7cede470e2455005c455bdf795fa9dd59e Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 25 Sep 2019 17:02:49 +0100 Subject: [PATCH 007/117] chore: debug --- test/script/appveyor/install-elasticsearch.ps1 | 3 +++ 1 file changed, 3 insertions(+) diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 index 8e6ac0f348..b66f51da56 100755 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -8,11 +8,14 @@ $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" $extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" $esRoot = "$extractRoot\elasticsearch-$esVersion" [Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") +Write-Host "Environment..." -ForegroundColor Cyan +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host "Downloading Elasticsearch..." (New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) 7z x $zipPath -y -o"$extractRoot" | Out-Null del $zipPath +Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} Write-Host "Installing Elasticsearch as a Windows service..." & "$esRoot\bin\elasticsearch-service.bat" install From 1dd966163c2e1c06083e8c7ebf543241887ae451 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 12:38:37 +0100 Subject: [PATCH 008/117] ci(jenkins): install nodejs with choco --- Jenkinsfile | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 71ed9428e3..344f6167e0 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -91,7 +91,7 @@ pipeline { } */ // Windows - parallelTasks['Windows-Node.js-10'] = generateStepForWindows(version: '10') + parallelTasks['Windows-Node.js-10'] = generateStepForWindows(version: '10.16.3') parallel(parallelTasks) } @@ -441,6 +441,8 @@ def generateStepForWindows(Map params = [:]){ node('windows-2019-immutable'){ try { env.HOME = "${WORKSPACE}" + // When installing with choco the PATH might not be updated within the already connected worker. + env.PATH = "${PATH};C:\\Program Files\\nodejs" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' } @@ -451,7 +453,7 @@ def generateStepForWindows(Map params = [:]){ .\\test\\script\\appveyor\\install-redis.ps1 .\\test\\script\\appveyor\\install-elasticsearch.ps1 .\\test\\script\\appveyor\\install-cassandra.ps1 - Install-Product node ${version} + & choco install nodejs --no-progress -y --version ${version} """ bat 'npm install' bat 'node test/test.js' From becd3dee74a7567c20db44654e74df765bef17e2 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 13:45:59 +0100 Subject: [PATCH 009/117] ci(jenkins): remove support to appveyor --- .appveyor.yml | 28 ----------------- test/script/appveyor/install-cassandra.ps1 | 23 -------------- .../script/appveyor/install-elasticsearch.ps1 | 31 ------------------- test/script/appveyor/install-redis.ps1 | 21 ------------- 4 files changed, 103 deletions(-) delete mode 100644 .appveyor.yml delete mode 100755 test/script/appveyor/install-cassandra.ps1 delete mode 100755 test/script/appveyor/install-elasticsearch.ps1 delete mode 100755 test/script/appveyor/install-redis.ps1 diff --git a/.appveyor.yml b/.appveyor.yml deleted file mode 100644 index 2355eb74da..0000000000 --- a/.appveyor.yml +++ /dev/null @@ -1,28 +0,0 @@ -environment: - PGUSER: "postgres" - PGPASSWORD: "Password12!" - MYSQL_PASSWORD: "Password12!" - -# Install scripts runs after repo cloning -install: - - ps: .\test\script\appveyor\install-redis.ps1 - - ps: .\test\script\appveyor\install-elasticsearch.ps1 - - ps: .\test\script\appveyor\install-cassandra.ps1 - - ps: Install-Product node 10 # Latest LTS - - npm install - -# Services are started after all install scripts have run -services: - - mysql - - mongodb - - postgresql - - mssql2017 - -# Post-install test scripts -test_script: - - node --version - - npm --version - - node test/test.js - -# Don't actually build -build: off diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 deleted file mode 100755 index 76f5730a82..0000000000 --- a/test/script/appveyor/install-cassandra.ps1 +++ /dev/null @@ -1,23 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan -$cassandraVersion = "3.11.3" -$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" -$extractRoot = "$env:USERPROFILE" -$tgzPath = "$extractRoot\cassandra.tar.gz" -$tarPath = "$extractRoot\cassandra.tar" -$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" - -Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) - -Write-Host "Extracting Cassandra..." -7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null -7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null -del $tgzPath - -Write-Host "Starting Cassandra..." -Start-Process $cassandra -PassThru - -Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 deleted file mode 100755 index b66f51da56..0000000000 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ /dev/null @@ -1,31 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "7.3.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" -$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" -$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" -$esRoot = "$extractRoot\elasticsearch-$esVersion" -[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") -Write-Host "Environment..." -ForegroundColor Cyan -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize - -Write-Host "Downloading Elasticsearch..." -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$extractRoot" | Out-Null -del $zipPath -Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} - -Write-Host "Installing Elasticsearch as a Windows service..." -& "$esRoot\bin\elasticsearch-service.bat" install - -Write-Host "Starting Elasticsearch service..." -& "$esRoot\bin\elasticsearch-service.bat" start - -do { - Write-Host "Waiting for Elasticsearch service to bootstrap..." - sleep 1 -} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) - -Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 deleted file mode 100755 index bc2a15cfdb..0000000000 --- a/test/script/appveyor/install-redis.ps1 +++ /dev/null @@ -1,21 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan -$redisVersion = "2.8.19" -$redisRoot = "$env:SYSTEMDRIVE\Redis" -$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" -$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" - -Write-Host "Downloading Redis..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$redisRoot" | Out-Null -del $zipPath - -Write-Host "Installing Redis as a Windows service..." -& "$redisRoot\redis-server.exe" --service-install - -Write-Host "Starting Redis service..." -& "$redisRoot\redis-server.exe" --service-start - -Write-Host "Redis installed" -ForegroundColor Green From 13ae974ea5831dfa9ec0d7b94016a80bcb2b3098 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 13:46:31 +0100 Subject: [PATCH 010/117] ci(jenkins): use docker instead --- .ci/scripts/windows/install-tools.ps1 | 12 ++++++++++++ Jenkinsfile | 10 +++------- 2 files changed, 15 insertions(+), 7 deletions(-) create mode 100644 .ci/scripts/windows/install-tools.ps1 diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 new file mode 100644 index 0000000000..4fd469c9d8 --- /dev/null +++ b/.ci/scripts/windows/install-tools.ps1 @@ -0,0 +1,12 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Installing Nodejs..." +& choco install nodejs --no-progress -y --version %VERSION% + +Write-Host "Installing Docker..." +& choco install docker-desktop --no-progress -y + +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize +& refreshenv +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize diff --git a/Jenkinsfile b/Jenkinsfile index 344f6167e0..9c66cbfb0e 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -438,23 +438,19 @@ def generateStepForWindows(Map params = [:]){ def edge = params.containsKey('edge') ? params.edge : false def disableAsyncHooks = params.get('disableAsyncHooks', false) return { - node('windows-2019-immutable'){ + node('windows-2019-docker-immutable'){ try { env.HOME = "${WORKSPACE}" // When installing with choco the PATH might not be updated within the already connected worker. env.PATH = "${PATH};C:\\Program Files\\nodejs" + env.VERSION = "${version}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' } deleteDir() unstash 'source' dir(BASE_DIR){ - powershell label: 'Install tools', script: """ - .\\test\\script\\appveyor\\install-redis.ps1 - .\\test\\script\\appveyor\\install-elasticsearch.ps1 - .\\test\\script\\appveyor\\install-cassandra.ps1 - & choco install nodejs --no-progress -y --version ${version} - """ + powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat 'npm install' bat 'node test/test.js' } From 203aa173de6d71741e381d716b5f2e0a52cc141d Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 15:31:59 +0100 Subject: [PATCH 011/117] chore: fix env variable call --- .ci/scripts/windows/install-tools.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 4fd469c9d8..eae8ccecba 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -2,7 +2,7 @@ $ErrorActionPreference = "Stop" Write-Host "Installing Nodejs..." -& choco install nodejs --no-progress -y --version %VERSION% +& choco install nodejs --no-progress -y --version "$env:VERSION" Write-Host "Installing Docker..." & choco install docker-desktop --no-progress -y From 1ddbb6aee16e24faa9123bfab22baee2c74dce4d Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 15:32:10 +0100 Subject: [PATCH 012/117] chore: more debug details --- Jenkinsfile | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index 9c66cbfb0e..0d77b257f6 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -449,7 +449,10 @@ def generateStepForWindows(Map params = [:]){ } deleteDir() unstash 'source' - dir(BASE_DIR){ + dir(BASE_DIR) { + bat 'docker --version' + bat 'docker-compose --version' + bat 'docker run --rm -t hello-world' powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat 'npm install' bat 'node test/test.js' From d558da30c4a85831b63a1cb03fcee13306fc7195 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 26 Sep 2019 16:01:40 +0100 Subject: [PATCH 013/117] ci(jenkins): install docker-compose --- .ci/scripts/windows/install-tools.ps1 | 7 ++++--- Jenkinsfile | 15 ++++++++++++--- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index eae8ccecba..091efd59d0 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -1,12 +1,13 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize + Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$env:VERSION" -Write-Host "Installing Docker..." -& choco install docker-desktop --no-progress -y +Write-Host "Installing docker-compose..." +choco install docker-compose --no-progress -y -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize & refreshenv Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize diff --git a/Jenkinsfile b/Jenkinsfile index 0d77b257f6..9a0e25701f 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -451,11 +451,20 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { bat 'docker --version' - bat 'docker-compose --version' bat 'docker run --rm -t hello-world' powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat 'npm install' - bat 'node test/test.js' + bat ''' + set + refreshenv + set + npm install + ''' + bat ''' + set + refreshenv + set + node test/test.js + ''' } } catch(e){ error(e.toString()) From 60e94e74efb55536ee64b0835c5818d4d671c6d3 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 12:50:12 +0100 Subject: [PATCH 014/117] Revert "ci(jenkins): remove support to appveyor" This reverts commit becd3dee74a7567c20db44654e74df765bef17e2. --- .appveyor.yml | 28 +++++++++++++++++ test/script/appveyor/install-cassandra.ps1 | 23 ++++++++++++++ .../script/appveyor/install-elasticsearch.ps1 | 31 +++++++++++++++++++ test/script/appveyor/install-redis.ps1 | 21 +++++++++++++ 4 files changed, 103 insertions(+) create mode 100644 .appveyor.yml create mode 100755 test/script/appveyor/install-cassandra.ps1 create mode 100755 test/script/appveyor/install-elasticsearch.ps1 create mode 100755 test/script/appveyor/install-redis.ps1 diff --git a/.appveyor.yml b/.appveyor.yml new file mode 100644 index 0000000000..2355eb74da --- /dev/null +++ b/.appveyor.yml @@ -0,0 +1,28 @@ +environment: + PGUSER: "postgres" + PGPASSWORD: "Password12!" + MYSQL_PASSWORD: "Password12!" + +# Install scripts runs after repo cloning +install: + - ps: .\test\script\appveyor\install-redis.ps1 + - ps: .\test\script\appveyor\install-elasticsearch.ps1 + - ps: .\test\script\appveyor\install-cassandra.ps1 + - ps: Install-Product node 10 # Latest LTS + - npm install + +# Services are started after all install scripts have run +services: + - mysql + - mongodb + - postgresql + - mssql2017 + +# Post-install test scripts +test_script: + - node --version + - npm --version + - node test/test.js + +# Don't actually build +build: off diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 new file mode 100755 index 0000000000..76f5730a82 --- /dev/null +++ b/test/script/appveyor/install-cassandra.ps1 @@ -0,0 +1,23 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan +$cassandraVersion = "3.11.3" +$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" +$extractRoot = "$env:USERPROFILE" +$tgzPath = "$extractRoot\cassandra.tar.gz" +$tarPath = "$extractRoot\cassandra.tar" +$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" + +Write-Host "Downloading Cassandra..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) + +Write-Host "Extracting Cassandra..." +7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null +7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null +del $tgzPath + +Write-Host "Starting Cassandra..." +Start-Process $cassandra -PassThru + +Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 new file mode 100755 index 0000000000..b66f51da56 --- /dev/null +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -0,0 +1,31 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan +$esVersion = "7.3.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" +$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" +$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" +$esRoot = "$extractRoot\elasticsearch-$esVersion" +[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") +Write-Host "Environment..." -ForegroundColor Cyan +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize + +Write-Host "Downloading Elasticsearch..." +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$extractRoot" | Out-Null +del $zipPath +Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} + +Write-Host "Installing Elasticsearch as a Windows service..." +& "$esRoot\bin\elasticsearch-service.bat" install + +Write-Host "Starting Elasticsearch service..." +& "$esRoot\bin\elasticsearch-service.bat" start + +do { + Write-Host "Waiting for Elasticsearch service to bootstrap..." + sleep 1 +} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) + +Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 new file mode 100755 index 0000000000..bc2a15cfdb --- /dev/null +++ b/test/script/appveyor/install-redis.ps1 @@ -0,0 +1,21 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan +$redisVersion = "2.8.19" +$redisRoot = "$env:SYSTEMDRIVE\Redis" +$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" +$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" + +Write-Host "Downloading Redis..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$redisRoot" | Out-Null +del $zipPath + +Write-Host "Installing Redis as a Windows service..." +& "$redisRoot\redis-server.exe" --service-install + +Write-Host "Starting Redis service..." +& "$redisRoot\redis-server.exe" --service-start + +Write-Host "Redis installed" -ForegroundColor Green From 426db1359c79f23b47e48a2d69af2c960ba96ad5 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 12:51:51 +0100 Subject: [PATCH 015/117] ci(jenkins): docker is not supported --- .ci/scripts/windows/install-tools.ps1 | 6 ------ Jenkinsfile | 11 +---------- 2 files changed, 1 insertion(+), 16 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 091efd59d0..df6fabbd90 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -5,9 +5,3 @@ Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$env:VERSION" - -Write-Host "Installing docker-compose..." -choco install docker-compose --no-progress -y - -& refreshenv -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize diff --git a/Jenkinsfile b/Jenkinsfile index 9a0e25701f..ccc303fbda 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -450,19 +450,10 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - bat 'docker --version' - bat 'docker run --rm -t hello-world' powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat ''' - set - refreshenv + bat label: 'Run tests', script: ''' set npm install - ''' - bat ''' - set - refreshenv - set node test/test.js ''' } From efdb9cd45678b7ce951456d0f18d62e54eb5a1d6 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 12:57:52 +0100 Subject: [PATCH 016/117] ci(jenkins): install dependent modules --- .../appveyor => .ci/scripts/windows}/install-cassandra.ps1 | 0 {test/script/appveyor => .ci/scripts/windows}/install-redis.ps1 | 0 Jenkinsfile | 2 ++ 3 files changed, 2 insertions(+) rename {test/script/appveyor => .ci/scripts/windows}/install-cassandra.ps1 (100%) rename {test/script/appveyor => .ci/scripts/windows}/install-redis.ps1 (100%) diff --git a/test/script/appveyor/install-cassandra.ps1 b/.ci/scripts/windows/install-cassandra.ps1 similarity index 100% rename from test/script/appveyor/install-cassandra.ps1 rename to .ci/scripts/windows/install-cassandra.ps1 diff --git a/test/script/appveyor/install-redis.ps1 b/.ci/scripts/windows/install-redis.ps1 similarity index 100% rename from test/script/appveyor/install-redis.ps1 rename to .ci/scripts/windows/install-redis.ps1 diff --git a/Jenkinsfile b/Jenkinsfile index 0a786c8c8f..81e775d31d 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -442,6 +442,8 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { + powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat label: 'Run tests', script: ''' set From 8160e9ab4d7ad7a07b30c96df3eb66b5be6b0eef Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 12:58:58 +0100 Subject: [PATCH 017/117] ci(jenkins): install elasticsearch --- .../appveyor => .ci/scripts/windows}/install-elasticsearch.ps1 | 0 Jenkinsfile | 1 + 2 files changed, 1 insertion(+) rename {test/script/appveyor => .ci/scripts/windows}/install-elasticsearch.ps1 (100%) diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 similarity index 100% rename from test/script/appveyor/install-elasticsearch.ps1 rename to .ci/scripts/windows/install-elasticsearch.ps1 diff --git a/Jenkinsfile b/Jenkinsfile index 81e775d31d..8cee4a6d8e 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -444,6 +444,7 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" + powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat label: 'Run tests', script: ''' set From 956303163269d7997df397f30f0139332c317bcd Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 13:22:57 +0100 Subject: [PATCH 018/117] ci(jenkins): running independently --- Jenkinsfile | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 8cee4a6d8e..63e014179b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -442,15 +442,12 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" - powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" + //powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" + //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat label: 'Run tests', script: ''' - set - npm install - node test/test.js - ''' + bat 'npm install' + bat 'node test/test.js' } } catch(e){ error(e.toString()) From 42d8c2d5128339362dce3c673b5282948a80f5a3 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 13:49:51 +0100 Subject: [PATCH 019/117] ci(jenkins): without the infra --- .ci/scripts/windows/install-cassandra.ps1 | 23 -------------- .ci/scripts/windows/install-elasticsearch.ps1 | 31 ------------------- .ci/scripts/windows/install-redis.ps1 | 21 ------------- Jenkinsfile | 3 -- 4 files changed, 78 deletions(-) delete mode 100755 .ci/scripts/windows/install-cassandra.ps1 delete mode 100755 .ci/scripts/windows/install-elasticsearch.ps1 delete mode 100755 .ci/scripts/windows/install-redis.ps1 diff --git a/.ci/scripts/windows/install-cassandra.ps1 b/.ci/scripts/windows/install-cassandra.ps1 deleted file mode 100755 index 76f5730a82..0000000000 --- a/.ci/scripts/windows/install-cassandra.ps1 +++ /dev/null @@ -1,23 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan -$cassandraVersion = "3.11.3" -$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" -$extractRoot = "$env:USERPROFILE" -$tgzPath = "$extractRoot\cassandra.tar.gz" -$tarPath = "$extractRoot\cassandra.tar" -$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" - -Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) - -Write-Host "Extracting Cassandra..." -7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null -7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null -del $tgzPath - -Write-Host "Starting Cassandra..." -Start-Process $cassandra -PassThru - -Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 deleted file mode 100755 index b66f51da56..0000000000 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ /dev/null @@ -1,31 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "7.3.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" -$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" -$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" -$esRoot = "$extractRoot\elasticsearch-$esVersion" -[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") -Write-Host "Environment..." -ForegroundColor Cyan -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize - -Write-Host "Downloading Elasticsearch..." -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$extractRoot" | Out-Null -del $zipPath -Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} - -Write-Host "Installing Elasticsearch as a Windows service..." -& "$esRoot\bin\elasticsearch-service.bat" install - -Write-Host "Starting Elasticsearch service..." -& "$esRoot\bin\elasticsearch-service.bat" start - -do { - Write-Host "Waiting for Elasticsearch service to bootstrap..." - sleep 1 -} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) - -Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/.ci/scripts/windows/install-redis.ps1 b/.ci/scripts/windows/install-redis.ps1 deleted file mode 100755 index bc2a15cfdb..0000000000 --- a/.ci/scripts/windows/install-redis.ps1 +++ /dev/null @@ -1,21 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan -$redisVersion = "2.8.19" -$redisRoot = "$env:SYSTEMDRIVE\Redis" -$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" -$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" - -Write-Host "Downloading Redis..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$redisRoot" | Out-Null -del $zipPath - -Write-Host "Installing Redis as a Windows service..." -& "$redisRoot\redis-server.exe" --service-install - -Write-Host "Starting Redis service..." -& "$redisRoot\redis-server.exe" --service-start - -Write-Host "Redis installed" -ForegroundColor Green diff --git a/Jenkinsfile b/Jenkinsfile index 63e014179b..2bb0d335d4 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -442,9 +442,6 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - //powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" - //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat 'npm install' bat 'node test/test.js' From 2455329aa9f867ffa6960eb14dce897f9d15158c Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:28:33 +0100 Subject: [PATCH 020/117] ci(jenkins): support more nodejs versions --- .ci/scripts/windows/install-tools.ps1 | 5 ++++- Jenkinsfile | 4 +++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index df6fabbd90..8cc924d3c3 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -3,5 +3,8 @@ $ErrorActionPreference = "Stop" Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize +Write-Host "Getting latest Nodejs version..." +$Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 + Write-Host "Installing Nodejs..." -& choco install nodejs --no-progress -y --version "$env:VERSION" +& choco install nodejs --no-progress -y --version "$Version" diff --git a/Jenkinsfile b/Jenkinsfile index 2bb0d335d4..fb983d1e9c 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -89,7 +89,9 @@ pipeline { } */ // Windows - parallelTasks['Windows-Node.js-10'] = generateStepForWindows(version: '10.16.3') + node['NODEJS_VERSION'].each{ version -> + parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) + } parallel(parallelTasks) } From 49ac3c6808f73e907d2a163748a03a3e4bda3d05 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:35:40 +0100 Subject: [PATCH 021/117] ci(jenkins): env list not required --- .ci/scripts/windows/install-tools.ps1 | 2 -- 1 file changed, 2 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 8cc924d3c3..cb771ebd12 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -1,8 +1,6 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize - Write-Host "Getting latest Nodejs version..." $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 From adcaafde8f7ba213baec967b52b93a3c1ce84815 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:38:29 +0100 Subject: [PATCH 022/117] ci(jenkins): debugging purposes --- Jenkinsfile | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index fb983d1e9c..a163001c41 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -445,6 +445,10 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" + bat label: 'Tool versions', script: ''' + npm --version + node --version + ''' bat 'npm install' bat 'node test/test.js' } From 135752f6b5ab62f8071fb18904f762e4653c9425 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:40:53 +0100 Subject: [PATCH 023/117] ci(jenkins): jenkins is now the place --- .appveyor.yml | 28 ---------------------------- 1 file changed, 28 deletions(-) delete mode 100644 .appveyor.yml diff --git a/.appveyor.yml b/.appveyor.yml deleted file mode 100644 index 2355eb74da..0000000000 --- a/.appveyor.yml +++ /dev/null @@ -1,28 +0,0 @@ -environment: - PGUSER: "postgres" - PGPASSWORD: "Password12!" - MYSQL_PASSWORD: "Password12!" - -# Install scripts runs after repo cloning -install: - - ps: .\test\script\appveyor\install-redis.ps1 - - ps: .\test\script\appveyor\install-elasticsearch.ps1 - - ps: .\test\script\appveyor\install-cassandra.ps1 - - ps: Install-Product node 10 # Latest LTS - - npm install - -# Services are started after all install scripts have run -services: - - mysql - - mongodb - - postgresql - - mssql2017 - -# Post-install test scripts -test_script: - - node --version - - npm --version - - node test/test.js - -# Don't actually build -build: off From 859e5ac784f2268cbf4e27d82acd7a59e8820777 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:49:21 +0100 Subject: [PATCH 024/117] Revert "chore: for testing purposes" This reverts commit a37263c817a8a62d2a5aa17a575c445488c5e678. --- Jenkinsfile | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index a163001c41..ff513698bd 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -28,10 +28,10 @@ pipeline { } parameters { booleanParam(name: 'Run_As_Master_Branch', defaultValue: false, description: 'Allow to run any steps on a PR, some steps normally only run on master branch.') - booleanParam(name: 'bench_ci', defaultValue: false, description: 'Enable benchmarks.') - booleanParam(name: 'tav_ci', defaultValue: false, description: 'Enable TAV tests.') + booleanParam(name: 'bench_ci', defaultValue: true, description: 'Enable benchmarks.') + booleanParam(name: 'tav_ci', defaultValue: true, description: 'Enable TAV tests.') booleanParam(name: 'tests_ci', defaultValue: true, description: 'Enable tests.') - booleanParam(name: 'test_edge_ci', defaultValue: false, description: 'Enable tests for edge versions of nodejs.') + booleanParam(name: 'test_edge_ci', defaultValue: true, description: 'Enable tests for edge versions of nodejs.') } stages { /** @@ -87,7 +87,7 @@ pipeline { // Linting in parallel with the test stage parallelTasks['linting'] = linting() } - */ + // Windows node['NODEJS_VERSION'].each{ version -> parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) From 279ed7d509f6c217ca31d10a5931021159f566a1 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 14:49:49 +0100 Subject: [PATCH 025/117] ci(jenkins): workflow --- Jenkinsfile | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index ff513698bd..4d697f782a 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -76,10 +76,11 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - /*def parallelTasksWithoutAsyncHooks = [:] + def parallelTasksWithoutAsyncHooks = [:] node['NODEJS_VERSION'].each{ version -> parallelTasks["Node.js-${version}"] = generateStep(version: version) parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) + parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) } // PRs don't require to run here as it's now managed within the linting pipeline @@ -88,11 +89,6 @@ pipeline { parallelTasks['linting'] = linting() } - // Windows - node['NODEJS_VERSION'].each{ version -> - parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) - } - parallel(parallelTasks) } } From 29209507c2e143d106e240065cb38edbab234234 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 15:33:20 +0100 Subject: [PATCH 026/117] ci(jenkins): disable performance --- Jenkinsfile | 2 -- 1 file changed, 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 4d697f782a..3135bf8b57 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -18,8 +18,6 @@ pipeline { buildDiscarder(logRotator(numToKeepStr: '20', artifactNumToKeepStr: '20', daysToKeepStr: '30')) timestamps() ansiColor('xterm') - disableResume() - durabilityHint('PERFORMANCE_OPTIMIZED') rateLimitBuilds(throttle: [count: 60, durationName: 'hour', userBoost: true]) quietPeriod(10) } From 46545c31e2c491fee570b8e95dac7c1eacd9f6c3 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 30 Sep 2019 15:44:35 +0100 Subject: [PATCH 027/117] Revert "ci(jenkins): disable performance" This reverts commit 29209507c2e143d106e240065cb38edbab234234. --- Jenkinsfile | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index 3135bf8b57..4d697f782a 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -18,6 +18,8 @@ pipeline { buildDiscarder(logRotator(numToKeepStr: '20', artifactNumToKeepStr: '20', daysToKeepStr: '30')) timestamps() ansiColor('xterm') + disableResume() + durabilityHint('PERFORMANCE_OPTIMIZED') rateLimitBuilds(throttle: [count: 60, durationName: 'hour', userBoost: true]) quietPeriod(10) } From d97b21d42c0546c7f81a8756c8a744ca8c112055 Mon Sep 17 00:00:00 2001 From: Stephen Belanger Date: Wed, 2 Oct 2019 15:54:03 -0700 Subject: [PATCH 028/117] test: fix windows process.title --- test/agent.js | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/test/agent.js b/test/agent.js index 3186c5fe13..38f7f904bd 100644 --- a/test/agent.js +++ b/test/agent.js @@ -1327,10 +1327,7 @@ function assertMetadata (t, payload) { t.equal(payload.process.pid, process.pid) t.ok(payload.process.pid > 0, 'should have a pid greater than 0') t.ok(payload.process.title, 'should have a process title') - t.ok( - /(npm|node)/.test(payload.process.title), - `process.title should contain expected value (was: "${payload.process.title}")` - ) + t.equal(payload.process.title, process.title) t.deepEqual(payload.process.argv, process.argv) t.ok(payload.process.argv.length >= 2, 'should have at least two process arguments') } From 5991e4f1a09a6ab83e6048a9eeb4c956e3448348 Mon Sep 17 00:00:00 2001 From: Stephen Belanger Date: Thu, 3 Oct 2019 15:21:34 -0700 Subject: [PATCH 029/117] ci(config): do not use symlink symlink does not work on Windows, so use npm link instead. --- test/config.js | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) diff --git a/test/config.js b/test/config.js index 6bd43a7d3f..136880faf9 100644 --- a/test/config.js +++ b/test/config.js @@ -452,13 +452,22 @@ test('serviceName defaults to package name', function (t) { { action: 'mkdirp', dir: path.join(tmp, 'node_modules') - }, - { + } + ] + + if (process.platform === 'win32') { + files.push({ + action: 'npm link', + from: path.resolve(__dirname, '..'), + to: tmp + }) + } else { + files.push({ action: 'symlink', from: path.resolve(__dirname, '..'), to: path.join(tmp, 'node_modules/elastic-apm-node') - } - ] + }) + } // NOTE: Reduce the sequence to a promise chain rather // than using Promise.all(), as the tasks are dependent. @@ -474,6 +483,15 @@ test('serviceName defaults to package name', function (t) { case 'symlink': { return symlink(file.from, file.to) } + case 'npm link': { + return exec('npm link', { + cwd: file.from + }).then(() => { + return exec('npm link elastic-apm-node', { + cwd: file.to + }) + }) + } } }) }, Promise.resolve()) From 88154f75208c4a1e1414e70c095b19ce2ae965e9 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 14:44:00 +0100 Subject: [PATCH 030/117] Revert "ci(jenkins): without the infra" This reverts commit 42d8c2d5128339362dce3c673b5282948a80f5a3. --- .ci/scripts/windows/install-cassandra.ps1 | 23 ++++++++++++++ .ci/scripts/windows/install-elasticsearch.ps1 | 31 +++++++++++++++++++ .ci/scripts/windows/install-redis.ps1 | 21 +++++++++++++ Jenkinsfile | 3 ++ 4 files changed, 78 insertions(+) create mode 100755 .ci/scripts/windows/install-cassandra.ps1 create mode 100755 .ci/scripts/windows/install-elasticsearch.ps1 create mode 100755 .ci/scripts/windows/install-redis.ps1 diff --git a/.ci/scripts/windows/install-cassandra.ps1 b/.ci/scripts/windows/install-cassandra.ps1 new file mode 100755 index 0000000000..76f5730a82 --- /dev/null +++ b/.ci/scripts/windows/install-cassandra.ps1 @@ -0,0 +1,23 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan +$cassandraVersion = "3.11.3" +$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" +$extractRoot = "$env:USERPROFILE" +$tgzPath = "$extractRoot\cassandra.tar.gz" +$tarPath = "$extractRoot\cassandra.tar" +$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" + +Write-Host "Downloading Cassandra..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) + +Write-Host "Extracting Cassandra..." +7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null +7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null +del $tgzPath + +Write-Host "Starting Cassandra..." +Start-Process $cassandra -PassThru + +Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 new file mode 100755 index 0000000000..b66f51da56 --- /dev/null +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -0,0 +1,31 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan +$esVersion = "7.3.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" +$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" +$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" +$esRoot = "$extractRoot\elasticsearch-$esVersion" +[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") +Write-Host "Environment..." -ForegroundColor Cyan +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize + +Write-Host "Downloading Elasticsearch..." +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$extractRoot" | Out-Null +del $zipPath +Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} + +Write-Host "Installing Elasticsearch as a Windows service..." +& "$esRoot\bin\elasticsearch-service.bat" install + +Write-Host "Starting Elasticsearch service..." +& "$esRoot\bin\elasticsearch-service.bat" start + +do { + Write-Host "Waiting for Elasticsearch service to bootstrap..." + sleep 1 +} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) + +Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/.ci/scripts/windows/install-redis.ps1 b/.ci/scripts/windows/install-redis.ps1 new file mode 100755 index 0000000000..bc2a15cfdb --- /dev/null +++ b/.ci/scripts/windows/install-redis.ps1 @@ -0,0 +1,21 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan +$redisVersion = "2.8.19" +$redisRoot = "$env:SYSTEMDRIVE\Redis" +$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" +$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" + +Write-Host "Downloading Redis..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$redisRoot" | Out-Null +del $zipPath + +Write-Host "Installing Redis as a Windows service..." +& "$redisRoot\redis-server.exe" --service-install + +Write-Host "Starting Redis service..." +& "$redisRoot\redis-server.exe" --service-start + +Write-Host "Redis installed" -ForegroundColor Green diff --git a/Jenkinsfile b/Jenkinsfile index 4d697f782a..56b4a0f8a9 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -440,6 +440,9 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { + //powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" + //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat label: 'Tool versions', script: ''' npm --version From b08826ddb5037b22d18f01cc36da5ccc7386b22e Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 14:51:31 +0100 Subject: [PATCH 031/117] ci(jenkins): install java --- .ci/scripts/windows/install-tools.ps1 | 3 +++ Jenkinsfile | 6 ++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index cb771ebd12..807f88dd9e 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -6,3 +6,6 @@ $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nod Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" + +Write-Host "Installing JDK8..." +& choco install jdk8 --no-progress -y -params "installdir=$env:JAVA_HOME" diff --git a/Jenkinsfile b/Jenkinsfile index 56b4a0f8a9..41997d3d07 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -431,8 +431,10 @@ def generateStepForWindows(Map params = [:]){ node('windows-2019-docker-immutable'){ try { env.HOME = "${WORKSPACE}" + // Ensure the JDK is the one installed + env.JAVA_HOME = 'C:\\jdk8' // When installing with choco the PATH might not be updated within the already connected worker. - env.PATH = "${PATH};C:\\Program Files\\nodejs" + env.PATH = "${env.JAVA_HOME}\\bin;${PATH};C:\\Program Files\\nodejs" env.VERSION = "${version}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -440,10 +442,10 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { + powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" //powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" - powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat label: 'Tool versions', script: ''' npm --version node --version From 92966f225eb57111a1b2ad579fd240f8e6ff1019 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 14:51:55 +0100 Subject: [PATCH 032/117] chore: enable cassandra --- Jenkinsfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index 41997d3d07..0d3b18a0ec 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -443,7 +443,7 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - //powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" bat label: 'Tool versions', script: ''' From 0c8a7980782379ba7d2245e1ae85cff025948fc8 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 14:54:00 +0100 Subject: [PATCH 033/117] ci(jenkins): for testing purposes --- Jenkinsfile | 352 +--------------------------------------------------- 1 file changed, 2 insertions(+), 350 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 0d3b18a0ec..8e7195da3f 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -2,7 +2,7 @@ @Library('apm@current') _ pipeline { - agent any + agent { label 'docker && immutable' } environment { REPO = 'apm-agent-nodejs' BASE_DIR = "src/github.com/elastic/${env.REPO}" @@ -38,28 +38,17 @@ pipeline { Checkout the code and stash it, to use it on other stages. */ stage('Checkout') { - agent { label 'immutable' } options { skipDefaultCheckout() } steps { deleteDir() gitCheckout(basedir: "${BASE_DIR}", githubNotifyFirstTimeContributor: true) stash allowEmpty: true, name: 'source', useDefaultExcludes: false - script { - dir("${BASE_DIR}"){ - def regexps =[ - "^lib/instrumentation/modules/", - "^test/instrumentation/modules/" - ] - env.TAV_UPDATED = isGitRegionMatch(regexps: regexps) - } - } } } /** Run tests. */ stage('Test') { - agent { label 'docker && immutable' } options { skipDefaultCheckout() } environment { HOME = "${env.WORKSPACE}" @@ -76,350 +65,13 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - def parallelTasksWithoutAsyncHooks = [:] - node['NODEJS_VERSION'].each{ version -> - parallelTasks["Node.js-${version}"] = generateStep(version: version) - parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) - parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) - } - - // PRs don't require to run here as it's now managed within the linting pipeline - if (!env.CHANGE_ID) { - // Linting in parallel with the test stage - parallelTasks['linting'] = linting() - } - + parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: "12") parallel(parallelTasks) } } } } } - /** - Run TAV tests. - */ - stage('TAV Test') { - agent { label 'docker && immutable' } - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - } - when { - beforeAgent true - allOf { - not { - branch '^greenkeeper/.*' - } - anyOf { - expression { return params.Run_As_Master_Branch } - triggeredBy 'TimerTrigger' - changeRequest() - expression { return env.TAV_UPDATED != "false" } - } - expression { return params.tav_ci } - } - } - steps { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def tavContext = getSmartTAVContext() - withGithubNotify(context: tavContext.ghContextName, description: tavContext.ghDescription, tab: 'tests') { - def parallelTasks = [:] - tavContext.node['NODEJS_VERSION'].each{ version -> - tavContext.tav['TAV'].each{ tav_item -> - parallelTasks["Node.js-${version}-${tav_item}"] = generateStep(version: version, tav: tav_item) - } - } - parallel(parallelTasks) - } - } - } - } - } - /** - Run Edge tests. - */ - stage('Edge Test') { - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - } - when { - beforeAgent true - allOf { - anyOf { - expression { return params.Run_As_Master_Branch } - triggeredBy 'TimerTrigger' - } - expression { return params.test_edge_ci } - } - } - parallel { - stage('Nightly Test') { - agent { label 'docker && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" - } - steps { - withGithubNotify(context: 'Nightly Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-nightly"] = generateStep(version: version, edge: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('Nightly Test - No async hooks') { - agent { label 'docker && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" - } - steps { - withGithubNotify(context: 'Nightly No Async Hooks Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-nightly-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('RC Test') { - agent { label 'docker && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" - } - steps { - withGithubNotify(context: 'RC Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-rc"] = generateStep(version: version, edge: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('RC Test - No async hooks') { - agent { label 'docker && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" - } - steps { - withGithubNotify(context: 'RC No Async Hooks Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-rc-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) - } - parallel(parallelTasks) - } - } - } - } - } - } - } - stage('Integration Tests') { - agent none - when { - beforeAgent true - allOf { - anyOf { - environment name: 'GIT_BUILD_CAUSE', value: 'pr' - expression { return !params.Run_As_Master_Branch } - } - } - } - steps { - log(level: 'INFO', text: 'Launching Async ITs') - build(job: env.ITS_PIPELINE, propagate: false, wait: false, - parameters: [string(name: 'AGENT_INTEGRATION_TEST', value: 'Node.js'), - string(name: 'BUILD_OPTS', value: "--nodejs-agent-package ${env.CHANGE_FORK?.trim() ?: 'elastic' }/${env.REPO}#${env.GIT_BASE_COMMIT}"), - string(name: 'GITHUB_CHECK_NAME', value: env.GITHUB_CHECK_ITS_NAME), - string(name: 'GITHUB_CHECK_REPO', value: env.REPO), - string(name: 'GITHUB_CHECK_SHA1', value: env.GIT_BASE_COMMIT)]) - githubNotify(context: "${env.GITHUB_CHECK_ITS_NAME}", description: "${env.GITHUB_CHECK_ITS_NAME} ...", status: 'PENDING', targetUrl: "${env.JENKINS_URL}search/?q=${env.ITS_PIPELINE.replaceAll('/','+')}") - } - } - /** - Run the benchmarks and store the results on ES. - The result JSON files are also archive into Jenkins. - */ - stage('Benchmarks') { - agent { label 'metal' } - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - RESULT_FILE = 'apm-agent-benchmark-results.json' - NODE_VERSION = '12' - } - when { - beforeAgent true - allOf { - anyOf { - branch 'master' - tag pattern: 'v\\d+\\.\\d+\\.\\d+.*', comparator: 'REGEXP' - expression { return params.Run_As_Master_Branch } - } - expression { return params.bench_ci } - } - } - steps { - withGithubNotify(context: 'Benchmarks', tab: 'artifacts') { - dir(env.BUILD_NUMBER) { - deleteDir() - unstash 'source' - dir(BASE_DIR){ - sh '.ci/scripts/run-benchmarks.sh "${RESULT_FILE}"' - } - } - } - } - post { - always { - catchError(message: 'sendBenchmarks failed', buildResult: 'FAILURE') { - sendBenchmarks(file: "${BUILD_NUMBER}/${BASE_DIR}/${RESULT_FILE}", - index: 'benchmark-nodejs', archive: true) - } - catchError(message: 'deleteDir failed', buildResult: 'SUCCESS', stageResult: 'UNSTABLE') { - deleteDir() - } - } - } - } - } - post { - cleanup { - notifyBuildResult() - } - } -} - -def generateStep(Map params = [:]){ - def version = params?.version - def tav = params.containsKey('tav') ? params.tav : '' - def edge = params.containsKey('edge') ? params.edge : false - def disableAsyncHooks = params.get('disableAsyncHooks', false) - return { - node('docker && linux && immutable'){ - try { - env.HOME = "${WORKSPACE}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - retry(2){ - sleep randomNumber(min:10, max: 30) - sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) - } - } - } catch(e){ - error(e.toString()) - } finally { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") - codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") - } - } - } -} - -/** -* Gather the TAV context for the current execution. Then the TAV stage will execute -* the TAV using a smarter approach. -*/ -def getSmartTAVContext() { - context = [:] - context.ghContextName = 'TAV Test' - context.ghDescription = context.ghContextName - context.node = readYaml(file: '.ci/.jenkins_tav_nodejs.yml') - - // Hard to debug what's going on as there are a few nested conditions. Let's then add more verbose output - echo """\ - env.GITHUB_COMMENT=${env.GITHUB_COMMENT} - params.Run_As_Master_Branch=${params.Run_As_Master_Branch} - env.CHANGE_ID=${env.CHANGE_ID} - env.TAV_UPDATED=${env.TAV_UPDATED}""".stripIndent() - - if (env.GITHUB_COMMENT) { - def modules = getModulesFromCommentTrigger(regex: '(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?module\\W+tests\\W+for\\W+(.+)') - if (modules.isEmpty()) { - context.ghDescription = 'TAV Test disabled' - context.tav = readYaml(text: 'TAV:') - context.node = readYaml(text: 'NODEJS_VERSION:') - } else { - if (modules.find{ it == 'ALL' }) { - context.tav = readYaml(file: '.ci/.jenkins_tav.yml') - } else { - context.ghContextName = 'TAV Test Subset' - context.ghDescription = 'TAV Test comment-triggered' - context.tav = readYaml(text: """TAV:${modules.collect{ it.replaceAll('"', '').replaceAll("'", '') }.collect{ "\n - '${it}'"}.join("") }""") - } - } - } else if (params.Run_As_Master_Branch) { - context.ghDescription = 'TAV Test param-triggered' - context.tav = readYaml(file: '.ci/.jenkins_tav.yml') - } else if (env.CHANGE_ID && env.TAV_UPDATED != "false") { - context.ghContextName = 'TAV Test Subset' - context.ghDescription = 'TAV Test changes-triggered' - sh '.ci/scripts/get_tav.sh .ci/.jenkins_generated_tav.yml' - context.tav = readYaml(file: '.ci/.jenkins_generated_tav.yml') - } else { - context.ghDescription = 'TAV Test disabled' - context.tav = readYaml(text: 'TAV:') - context.node = readYaml(text: 'NODEJS_VERSION:') - } - return context - } - - def linting(){ - return { - node('docker && linux && immutable') { - catchError(stageResult: 'UNSTABLE', message: 'Linting failures') { - withGithubNotify(context: 'Linting') { - deleteDir() - unstash 'source' - script { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: 'Basic tests I', script: 'cd /app && .ci/scripts/test_basic.sh') - sh(label: 'Basic tests II', script: 'cd /app && .ci/scripts/test_types_babel_esm.sh') - } - } - } - } - } } } From d2547c8bc01c1c780c1468279105b01a1bf3f91f Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 15:11:41 +0100 Subject: [PATCH 034/117] ci(jenkins): force the installation --- .ci/scripts/windows/install-tools.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 807f88dd9e..387980873b 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -8,4 +8,4 @@ Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" Write-Host "Installing JDK8..." -& choco install jdk8 --no-progress -y -params "installdir=$env:JAVA_HOME" +& choco install jdk8 --no-progress -y --force -params "installdir=$env:JAVA_HOME" From f379c6200c5f575bb7defb550611849b4c03f227 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 15:25:58 +0100 Subject: [PATCH 035/117] ci(jenkins): hardcode the string --- .ci/scripts/windows/install-tools.ps1 | 2 +- Jenkinsfile | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 387980873b..f4cfc219d2 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -8,4 +8,4 @@ Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" Write-Host "Installing JDK8..." -& choco install jdk8 --no-progress -y --force -params "installdir=$env:JAVA_HOME" +& choco install jdk8 --no-progress -y --force -params 'installdir=c:\\java' diff --git a/Jenkinsfile b/Jenkinsfile index 8e7195da3f..16aa23a4b2 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -84,7 +84,7 @@ def generateStepForWindows(Map params = [:]){ try { env.HOME = "${WORKSPACE}" // Ensure the JDK is the one installed - env.JAVA_HOME = 'C:\\jdk8' + env.JAVA_HOME = 'C:\\java' // When installing with choco the PATH might not be updated within the already connected worker. env.PATH = "${env.JAVA_HOME}\\bin;${PATH};C:\\Program Files\\nodejs" env.VERSION = "${version}" From 7ebcf97c2a1431a9d1e2b4d022d802ba4ab8ecf9 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 15:37:30 +0100 Subject: [PATCH 036/117] ci(jenkins): skip reboot --- .ci/scripts/windows/install-tools.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index f4cfc219d2..eb4685ce9d 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -8,4 +8,4 @@ Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" Write-Host "Installing JDK8..." -& choco install jdk8 --no-progress -y --force -params 'installdir=c:\\java' +& choco install jdk8 --no-progress -y --force --ignore-detected-reboot -params 'installdir=c:\\java' From d94f694693c3af89ebabec127e4716faae3a577b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 15:48:31 +0100 Subject: [PATCH 037/117] ci(jenkins): uninstall current jdk --- .ci/scripts/windows/install-tools.ps1 | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index eb4685ce9d..cf95d9d202 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -7,5 +7,8 @@ $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nod Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" +Write-Host "Uninstalling JDK8..." +& choco uninstall jdk8 --no-progress -y --force --ignore-detected-reboot + Write-Host "Installing JDK8..." & choco install jdk8 --no-progress -y --force --ignore-detected-reboot -params 'installdir=c:\\java' From 11ff86fcebd8d70402825f402a91b6d0d33f1d56 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 20:46:38 +0100 Subject: [PATCH 038/117] Revert "ci(jenkins): for testing purposes" This reverts commit 0c8a7980782379ba7d2245e1ae85cff025948fc8. --- Jenkinsfile | 352 +++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 350 insertions(+), 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 16aa23a4b2..74f337559f 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -2,7 +2,7 @@ @Library('apm@current') _ pipeline { - agent { label 'docker && immutable' } + agent any environment { REPO = 'apm-agent-nodejs' BASE_DIR = "src/github.com/elastic/${env.REPO}" @@ -38,17 +38,28 @@ pipeline { Checkout the code and stash it, to use it on other stages. */ stage('Checkout') { + agent { label 'immutable' } options { skipDefaultCheckout() } steps { deleteDir() gitCheckout(basedir: "${BASE_DIR}", githubNotifyFirstTimeContributor: true) stash allowEmpty: true, name: 'source', useDefaultExcludes: false + script { + dir("${BASE_DIR}"){ + def regexps =[ + "^lib/instrumentation/modules/", + "^test/instrumentation/modules/" + ] + env.TAV_UPDATED = isGitRegionMatch(regexps: regexps) + } + } } } /** Run tests. */ stage('Test') { + agent { label 'docker && immutable' } options { skipDefaultCheckout() } environment { HOME = "${env.WORKSPACE}" @@ -65,13 +76,350 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: "12") + def parallelTasksWithoutAsyncHooks = [:] + node['NODEJS_VERSION'].each{ version -> + parallelTasks["Node.js-${version}"] = generateStep(version: version) + parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) + parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) + } + + // PRs don't require to run here as it's now managed within the linting pipeline + if (!env.CHANGE_ID) { + // Linting in parallel with the test stage + parallelTasks['linting'] = linting() + } + parallel(parallelTasks) } } } } } + /** + Run TAV tests. + */ + stage('TAV Test') { + agent { label 'docker && immutable' } + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + } + when { + beforeAgent true + allOf { + not { + branch '^greenkeeper/.*' + } + anyOf { + expression { return params.Run_As_Master_Branch } + triggeredBy 'TimerTrigger' + changeRequest() + expression { return env.TAV_UPDATED != "false" } + } + expression { return params.tav_ci } + } + } + steps { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def tavContext = getSmartTAVContext() + withGithubNotify(context: tavContext.ghContextName, description: tavContext.ghDescription, tab: 'tests') { + def parallelTasks = [:] + tavContext.node['NODEJS_VERSION'].each{ version -> + tavContext.tav['TAV'].each{ tav_item -> + parallelTasks["Node.js-${version}-${tav_item}"] = generateStep(version: version, tav: tav_item) + } + } + parallel(parallelTasks) + } + } + } + } + } + /** + Run Edge tests. + */ + stage('Edge Test') { + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + } + when { + beforeAgent true + allOf { + anyOf { + expression { return params.Run_As_Master_Branch } + triggeredBy 'TimerTrigger' + } + expression { return params.test_edge_ci } + } + } + parallel { + stage('Nightly Test') { + agent { label 'docker && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" + } + steps { + withGithubNotify(context: 'Nightly Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-nightly"] = generateStep(version: version, edge: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('Nightly Test - No async hooks') { + agent { label 'docker && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" + } + steps { + withGithubNotify(context: 'Nightly No Async Hooks Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-nightly-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('RC Test') { + agent { label 'docker && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" + } + steps { + withGithubNotify(context: 'RC Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-rc"] = generateStep(version: version, edge: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('RC Test - No async hooks') { + agent { label 'docker && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" + } + steps { + withGithubNotify(context: 'RC No Async Hooks Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-rc-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) + } + parallel(parallelTasks) + } + } + } + } + } + } + } + stage('Integration Tests') { + agent none + when { + beforeAgent true + allOf { + anyOf { + environment name: 'GIT_BUILD_CAUSE', value: 'pr' + expression { return !params.Run_As_Master_Branch } + } + } + } + steps { + log(level: 'INFO', text: 'Launching Async ITs') + build(job: env.ITS_PIPELINE, propagate: false, wait: false, + parameters: [string(name: 'AGENT_INTEGRATION_TEST', value: 'Node.js'), + string(name: 'BUILD_OPTS', value: "--nodejs-agent-package ${env.CHANGE_FORK?.trim() ?: 'elastic' }/${env.REPO}#${env.GIT_BASE_COMMIT}"), + string(name: 'GITHUB_CHECK_NAME', value: env.GITHUB_CHECK_ITS_NAME), + string(name: 'GITHUB_CHECK_REPO', value: env.REPO), + string(name: 'GITHUB_CHECK_SHA1', value: env.GIT_BASE_COMMIT)]) + githubNotify(context: "${env.GITHUB_CHECK_ITS_NAME}", description: "${env.GITHUB_CHECK_ITS_NAME} ...", status: 'PENDING', targetUrl: "${env.JENKINS_URL}search/?q=${env.ITS_PIPELINE.replaceAll('/','+')}") + } + } + /** + Run the benchmarks and store the results on ES. + The result JSON files are also archive into Jenkins. + */ + stage('Benchmarks') { + agent { label 'metal' } + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + RESULT_FILE = 'apm-agent-benchmark-results.json' + NODE_VERSION = '12' + } + when { + beforeAgent true + allOf { + anyOf { + branch 'master' + tag pattern: 'v\\d+\\.\\d+\\.\\d+.*', comparator: 'REGEXP' + expression { return params.Run_As_Master_Branch } + } + expression { return params.bench_ci } + } + } + steps { + withGithubNotify(context: 'Benchmarks', tab: 'artifacts') { + dir(env.BUILD_NUMBER) { + deleteDir() + unstash 'source' + dir(BASE_DIR){ + sh '.ci/scripts/run-benchmarks.sh "${RESULT_FILE}"' + } + } + } + } + post { + always { + catchError(message: 'sendBenchmarks failed', buildResult: 'FAILURE') { + sendBenchmarks(file: "${BUILD_NUMBER}/${BASE_DIR}/${RESULT_FILE}", + index: 'benchmark-nodejs', archive: true) + } + catchError(message: 'deleteDir failed', buildResult: 'SUCCESS', stageResult: 'UNSTABLE') { + deleteDir() + } + } + } + } + } + post { + cleanup { + notifyBuildResult() + } + } +} + +def generateStep(Map params = [:]){ + def version = params?.version + def tav = params.containsKey('tav') ? params.tav : '' + def edge = params.containsKey('edge') ? params.edge : false + def disableAsyncHooks = params.get('disableAsyncHooks', false) + return { + node('docker && linux && immutable'){ + try { + env.HOME = "${WORKSPACE}" + if (disableAsyncHooks) { + env.ELASTIC_APM_ASYNC_HOOKS = 'false' + } + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + retry(2){ + sleep randomNumber(min:10, max: 30) + sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + } + } + } catch(e){ + error(e.toString()) + } finally { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") + } + } + } +} + +/** +* Gather the TAV context for the current execution. Then the TAV stage will execute +* the TAV using a smarter approach. +*/ +def getSmartTAVContext() { + context = [:] + context.ghContextName = 'TAV Test' + context.ghDescription = context.ghContextName + context.node = readYaml(file: '.ci/.jenkins_tav_nodejs.yml') + + // Hard to debug what's going on as there are a few nested conditions. Let's then add more verbose output + echo """\ + env.GITHUB_COMMENT=${env.GITHUB_COMMENT} + params.Run_As_Master_Branch=${params.Run_As_Master_Branch} + env.CHANGE_ID=${env.CHANGE_ID} + env.TAV_UPDATED=${env.TAV_UPDATED}""".stripIndent() + + if (env.GITHUB_COMMENT) { + def modules = getModulesFromCommentTrigger(regex: '(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?module\\W+tests\\W+for\\W+(.+)') + if (modules.isEmpty()) { + context.ghDescription = 'TAV Test disabled' + context.tav = readYaml(text: 'TAV:') + context.node = readYaml(text: 'NODEJS_VERSION:') + } else { + if (modules.find{ it == 'ALL' }) { + context.tav = readYaml(file: '.ci/.jenkins_tav.yml') + } else { + context.ghContextName = 'TAV Test Subset' + context.ghDescription = 'TAV Test comment-triggered' + context.tav = readYaml(text: """TAV:${modules.collect{ it.replaceAll('"', '').replaceAll("'", '') }.collect{ "\n - '${it}'"}.join("") }""") + } + } + } else if (params.Run_As_Master_Branch) { + context.ghDescription = 'TAV Test param-triggered' + context.tav = readYaml(file: '.ci/.jenkins_tav.yml') + } else if (env.CHANGE_ID && env.TAV_UPDATED != "false") { + context.ghContextName = 'TAV Test Subset' + context.ghDescription = 'TAV Test changes-triggered' + sh '.ci/scripts/get_tav.sh .ci/.jenkins_generated_tav.yml' + context.tav = readYaml(file: '.ci/.jenkins_generated_tav.yml') + } else { + context.ghDescription = 'TAV Test disabled' + context.tav = readYaml(text: 'TAV:') + context.node = readYaml(text: 'NODEJS_VERSION:') + } + return context + } + + def linting(){ + return { + node('docker && linux && immutable') { + catchError(stageResult: 'UNSTABLE', message: 'Linting failures') { + withGithubNotify(context: 'Linting') { + deleteDir() + unstash 'source' + script { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: 'Basic tests I', script: 'cd /app && .ci/scripts/test_basic.sh') + sh(label: 'Basic tests II', script: 'cd /app && .ci/scripts/test_types_babel_esm.sh') + } + } + } + } + } } } From a82931b50ad92e7e3c971e957de3178ee64e5848 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 20:49:02 +0100 Subject: [PATCH 039/117] chore: testing purposes --- Jenkinsfile | 352 +--------------------------------------------------- 1 file changed, 1 insertion(+), 351 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 3bf71eb1b2..ec09c8bfcc 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -23,15 +23,9 @@ pipeline { rateLimitBuilds(throttle: [count: 60, durationName: 'hour', userBoost: true]) quietPeriod(10) } - triggers { - issueCommentTrigger('(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?(?:module\\W+)?tests(?:\\W+please)?.*') - } parameters { booleanParam(name: 'Run_As_Master_Branch', defaultValue: false, description: 'Allow to run any steps on a PR, some steps normally only run on master branch.') - booleanParam(name: 'bench_ci', defaultValue: true, description: 'Enable benchmarks.') - booleanParam(name: 'tav_ci', defaultValue: true, description: 'Enable TAV tests.') booleanParam(name: 'tests_ci', defaultValue: true, description: 'Enable tests.') - booleanParam(name: 'test_edge_ci', defaultValue: true, description: 'Enable tests for edge versions of nodejs.') } stages { /** @@ -43,15 +37,6 @@ pipeline { deleteDir() gitCheckout(basedir: "${BASE_DIR}", githubNotifyFirstTimeContributor: true) stash allowEmpty: true, name: 'source', useDefaultExcludes: false - script { - dir("${BASE_DIR}"){ - def regexps =[ - "^lib/instrumentation/modules/", - "^test/instrumentation/modules/" - ] - env.TAV_UPDATED = isGitRegionMatch(regexps: regexps) - } - } } } /** @@ -74,18 +59,7 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - def parallelTasksWithoutAsyncHooks = [:] - node['NODEJS_VERSION'].each{ version -> - parallelTasks["Node.js-${version}"] = generateStep(version: version) - parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) - parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) - } - - // PRs don't require to run here as it's now managed within the linting pipeline - if (!env.CHANGE_ID) { - // Linting in parallel with the test stage - parallelTasks['linting'] = linting() - } + parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') parallel(parallelTasks) } @@ -93,330 +67,6 @@ pipeline { } } } - /** - Run TAV tests. - */ - stage('TAV Test') { - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - } - when { - beforeAgent true - allOf { - not { - branch '^greenkeeper/.*' - } - anyOf { - expression { return params.Run_As_Master_Branch } - triggeredBy 'TimerTrigger' - changeRequest() - expression { return env.TAV_UPDATED != "false" } - } - expression { return params.tav_ci } - } - } - steps { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def tavContext = getSmartTAVContext() - withGithubNotify(context: tavContext.ghContextName, description: tavContext.ghDescription, tab: 'tests') { - def parallelTasks = [:] - tavContext.node['NODEJS_VERSION'].each{ version -> - tavContext.tav['TAV'].each{ tav_item -> - parallelTasks["Node.js-${version}-${tav_item}"] = generateStep(version: version, tav: tav_item) - } - } - parallel(parallelTasks) - } - } - } - } - } - /** - Run Edge tests. - */ - stage('Edge Test') { - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - } - when { - beforeAgent true - allOf { - anyOf { - expression { return params.Run_As_Master_Branch } - triggeredBy 'TimerTrigger' - } - expression { return params.test_edge_ci } - } - } - parallel { - stage('Nightly Test') { - agent { label 'linux && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" - } - steps { - withGithubNotify(context: 'Nightly Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-nightly"] = generateStep(version: version, edge: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('Nightly Test - No async hooks') { - agent { label 'linux && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" - } - steps { - withGithubNotify(context: 'Nightly No Async Hooks Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-nightly-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('RC Test') { - agent { label 'linux && immutablee' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" - } - steps { - withGithubNotify(context: 'RC Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-rc"] = generateStep(version: version, edge: true) - } - parallel(parallelTasks) - } - } - } - } - } - stage('RC Test - No async hooks') { - agent { label 'linux && immutable' } - environment { - NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" - } - steps { - withGithubNotify(context: 'RC No Async Hooks Test', tab: 'tests') { - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - script { - def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') - def parallelTasks = [:] - node['NODEJS_VERSION'].each { version -> - parallelTasks["Node.js-${version}-rc-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) - } - parallel(parallelTasks) - } - } - } - } - } - } - } - stage('Integration Tests') { - agent none - when { - beforeAgent true - allOf { - anyOf { - environment name: 'GIT_BUILD_CAUSE', value: 'pr' - expression { return !params.Run_As_Master_Branch } - } - } - } - steps { - log(level: 'INFO', text: 'Launching Async ITs') - build(job: env.ITS_PIPELINE, propagate: false, wait: false, - parameters: [string(name: 'AGENT_INTEGRATION_TEST', value: 'Node.js'), - string(name: 'BUILD_OPTS', value: "--nodejs-agent-package ${env.CHANGE_FORK?.trim() ?: 'elastic' }/${env.REPO}#${env.GIT_BASE_COMMIT}"), - string(name: 'GITHUB_CHECK_NAME', value: env.GITHUB_CHECK_ITS_NAME), - string(name: 'GITHUB_CHECK_REPO', value: env.REPO), - string(name: 'GITHUB_CHECK_SHA1', value: env.GIT_BASE_COMMIT)]) - githubNotify(context: "${env.GITHUB_CHECK_ITS_NAME}", description: "${env.GITHUB_CHECK_ITS_NAME} ...", status: 'PENDING', targetUrl: "${env.JENKINS_URL}search/?q=${env.ITS_PIPELINE.replaceAll('/','+')}") - } - } - /** - Run the benchmarks and store the results on ES. - The result JSON files are also archive into Jenkins. - */ - stage('Benchmarks') { - agent { label 'metal' } - options { skipDefaultCheckout() } - environment { - HOME = "${env.WORKSPACE}" - RESULT_FILE = 'apm-agent-benchmark-results.json' - NODE_VERSION = '12' - } - when { - beforeAgent true - allOf { - anyOf { - branch 'master' - tag pattern: 'v\\d+\\.\\d+\\.\\d+.*', comparator: 'REGEXP' - expression { return params.Run_As_Master_Branch } - } - expression { return params.bench_ci } - } - } - steps { - withGithubNotify(context: 'Benchmarks', tab: 'artifacts') { - dir(env.BUILD_NUMBER) { - deleteDir() - unstash 'source' - dir(BASE_DIR){ - sh '.ci/scripts/run-benchmarks.sh "${RESULT_FILE}"' - } - } - } - } - post { - always { - catchError(message: 'sendBenchmarks failed', buildResult: 'FAILURE') { - sendBenchmarks(file: "${BUILD_NUMBER}/${BASE_DIR}/${RESULT_FILE}", - index: 'benchmark-nodejs', archive: true) - } - catchError(message: 'deleteDir failed', buildResult: 'SUCCESS', stageResult: 'UNSTABLE') { - deleteDir() - } - } - } - } - } - post { - cleanup { - notifyBuildResult() - } - } -} - -def generateStep(Map params = [:]){ - def version = params?.version - def tav = params.containsKey('tav') ? params.tav : '' - def edge = params.containsKey('edge') ? params.edge : false - def disableAsyncHooks = params.get('disableAsyncHooks', false) - return { - node('linux && immutable'){ - try { - env.HOME = "${WORKSPACE}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - retry(2){ - sleep randomNumber(min:10, max: 30) - sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) - } - } - } catch(e){ - error(e.toString()) - } finally { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") - codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") - } - } - } -} - -/** -* Gather the TAV context for the current execution. Then the TAV stage will execute -* the TAV using a smarter approach. -*/ -def getSmartTAVContext() { - context = [:] - context.ghContextName = 'TAV Test' - context.ghDescription = context.ghContextName - context.node = readYaml(file: '.ci/.jenkins_tav_nodejs.yml') - - // Hard to debug what's going on as there are a few nested conditions. Let's then add more verbose output - echo """\ - env.GITHUB_COMMENT=${env.GITHUB_COMMENT} - params.Run_As_Master_Branch=${params.Run_As_Master_Branch} - env.CHANGE_ID=${env.CHANGE_ID} - env.TAV_UPDATED=${env.TAV_UPDATED}""".stripIndent() - - if (env.GITHUB_COMMENT) { - def modules = getModulesFromCommentTrigger(regex: '(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?module\\W+tests\\W+for\\W+(.+)') - if (modules.isEmpty()) { - context.ghDescription = 'TAV Test disabled' - context.tav = readYaml(text: 'TAV:') - context.node = readYaml(text: 'NODEJS_VERSION:') - } else { - if (modules.find{ it == 'ALL' }) { - context.tav = readYaml(file: '.ci/.jenkins_tav.yml') - } else { - context.ghContextName = 'TAV Test Subset' - context.ghDescription = 'TAV Test comment-triggered' - context.tav = readYaml(text: """TAV:${modules.collect{ it.replaceAll('"', '').replaceAll("'", '') }.collect{ "\n - '${it}'"}.join("") }""") - } - } - } else if (params.Run_As_Master_Branch) { - context.ghDescription = 'TAV Test param-triggered' - context.tav = readYaml(file: '.ci/.jenkins_tav.yml') - } else if (env.CHANGE_ID && env.TAV_UPDATED != "false") { - context.ghContextName = 'TAV Test Subset' - context.ghDescription = 'TAV Test changes-triggered' - sh '.ci/scripts/get_tav.sh .ci/.jenkins_generated_tav.yml' - context.tav = readYaml(file: '.ci/.jenkins_generated_tav.yml') - } else { - context.ghDescription = 'TAV Test disabled' - context.tav = readYaml(text: 'TAV:') - context.node = readYaml(text: 'NODEJS_VERSION:') - } - return context - } - - def linting(){ - return { - node('linux && immutable') { - catchError(stageResult: 'UNSTABLE', message: 'Linting failures') { - withGithubNotify(context: 'Linting') { - deleteDir() - unstash 'source' - script { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: 'Basic tests I', script: 'cd /app && .ci/scripts/test_basic.sh') - sh(label: 'Basic tests II', script: 'cd /app && .ci/scripts/test_types_babel_esm.sh') - } - } - } - } - } } } From 7079fa330755e438f46a74e491b3674d69ca4c97 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 21:09:09 +0100 Subject: [PATCH 040/117] ci(jenkins): jdk8 get rebooted --- .ci/scripts/windows/install-tools.ps1 | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index cf95d9d202..63f0b899b5 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -7,8 +7,5 @@ $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nod Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" -Write-Host "Uninstalling JDK8..." -& choco uninstall jdk8 --no-progress -y --force --ignore-detected-reboot - Write-Host "Installing JDK8..." -& choco install jdk8 --no-progress -y --force --ignore-detected-reboot -params 'installdir=c:\\java' +& choco install adoptopenjdk8jre --no-progress -y --force -params 'installdir=c:\\java' From 110dfa19b9e7e3f850af65dc8c5fc0bda8003b6c Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 21:22:34 +0100 Subject: [PATCH 041/117] ci(jenkins): avoid windows limit --- .ci/scripts/windows/install-cassandra.ps1 | 2 +- .ci/scripts/windows/install-elasticsearch.ps1 | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/install-cassandra.ps1 b/.ci/scripts/windows/install-cassandra.ps1 index 76f5730a82..a2cc1f615e 100755 --- a/.ci/scripts/windows/install-cassandra.ps1 +++ b/.ci/scripts/windows/install-cassandra.ps1 @@ -4,7 +4,7 @@ $ErrorActionPreference = "Stop" Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan $cassandraVersion = "3.11.3" $downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" -$extractRoot = "$env:USERPROFILE" +$extractRoot = "$env:SYSTEMDRIVE" $tgzPath = "$extractRoot\cassandra.tar.gz" $tarPath = "$extractRoot\cassandra.tar" $cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 index b66f51da56..40fc50d01d 100755 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -5,7 +5,7 @@ Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor $esVersion = "7.3.2" $downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" -$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" +$extractRoot = "$env:SYSTEMDRIVE" $esRoot = "$extractRoot\elasticsearch-$esVersion" [Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") Write-Host "Environment..." -ForegroundColor Cyan From 3f45610a14713a98d5608b10d63a6a022b39fa4b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 21:43:35 +0100 Subject: [PATCH 042/117] ci(jenkins): fix download --- .ci/scripts/windows/install-elasticsearch.ps1 | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 index 40fc50d01d..b07049831a 100755 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -12,6 +12,8 @@ Write-Host "Environment..." -ForegroundColor Cyan Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host "Downloading Elasticsearch..." +# Fixes: The request was aborted: Could not create SSL/TLS secure +[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 (New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) 7z x $zipPath -y -o"$extractRoot" | Out-Null del $zipPath From 95ceac4e5f0071fc0bb5b3369603119b72ca1265 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 21:56:09 +0100 Subject: [PATCH 043/117] ci(jenkins): fix download and path --- .ci/scripts/windows/install-redis.ps1 | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.ci/scripts/windows/install-redis.ps1 b/.ci/scripts/windows/install-redis.ps1 index bc2a15cfdb..1b9ba3e541 100755 --- a/.ci/scripts/windows/install-redis.ps1 +++ b/.ci/scripts/windows/install-redis.ps1 @@ -3,11 +3,13 @@ $ErrorActionPreference = "Stop" Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan $redisVersion = "2.8.19" -$redisRoot = "$env:SYSTEMDRIVE\Redis" +$redisRoot = "$env:SYSTEMDRIVE" $zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" $downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" Write-Host "Downloading Redis..." -ForegroundColor Cyan +# Fixes: The request was aborted: Could not create SSL/TLS secure +[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 (New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) 7z x $zipPath -y -o"$redisRoot" | Out-Null del $zipPath From 05fb1da2fa442516ff4a5507c9f310d2a74f3e9e Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 22:16:51 +0100 Subject: [PATCH 044/117] ci(jenkins): enable other tools --- Jenkinsfile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index ec09c8bfcc..62957b7069 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -91,8 +91,8 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - //powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" - //powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" + powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" + powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" bat label: 'Tool versions', script: ''' npm --version node --version From cc0bdd0e545645a3769f4609835bdab4c36651fe Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 22:47:49 +0100 Subject: [PATCH 045/117] ci(jenkins): downgrade version --- .ci/scripts/windows/install-elasticsearch.ps1 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 index b07049831a..dbba36cc66 100755 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -2,8 +2,8 @@ $ErrorActionPreference = "Stop" Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "7.3.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" +$esVersion = "6.1.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion).zip" $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" $extractRoot = "$env:SYSTEMDRIVE" $esRoot = "$extractRoot\elasticsearch-$esVersion" From 5f32bbbfc7fe597a307e01df7e2d797b7f0c0ca7 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 23:35:11 +0100 Subject: [PATCH 046/117] ci(jenkins): use choco instead --- .ci/scripts/windows/install-elasticsearch.ps1 | 24 +++---------------- 1 file changed, 3 insertions(+), 21 deletions(-) diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 index dbba36cc66..b533033df4 100755 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -1,29 +1,11 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "6.1.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion).zip" -$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" -$extractRoot = "$env:SYSTEMDRIVE" -$esRoot = "$extractRoot\elasticsearch-$esVersion" -[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") -Write-Host "Environment..." -ForegroundColor Cyan -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize - -Write-Host "Downloading Elasticsearch..." -# Fixes: The request was aborted: Could not create SSL/TLS secure -[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$extractRoot" | Out-Null -del $zipPath -Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} - -Write-Host "Installing Elasticsearch as a Windows service..." -& "$esRoot\bin\elasticsearch-service.bat" install +Write-Host "Installing Elasticsearch..." +& choco install elasticsearch --no-progress -y --version=6.7.0 Write-Host "Starting Elasticsearch service..." -& "$esRoot\bin\elasticsearch-service.bat" start +& elasticsearch-service.bat start do { Write-Host "Waiting for Elasticsearch service to bootstrap..." From 5761c41e575a96d65f0d671a98a9900e2234a3e6 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 4 Oct 2019 23:51:04 +0100 Subject: [PATCH 047/117] ci(jenkins): refreshenv --- .ci/scripts/windows/install-elasticsearch.ps1 | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 index b533033df4..476fc8e7a9 100755 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ b/.ci/scripts/windows/install-elasticsearch.ps1 @@ -4,6 +4,8 @@ $ErrorActionPreference = "Stop" Write-Host "Installing Elasticsearch..." & choco install elasticsearch --no-progress -y --version=6.7.0 +refreshenv + Write-Host "Starting Elasticsearch service..." & elasticsearch-service.bat start From cf41802c6e30fe49d43d687cb0e068fa326534fb Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 12:18:00 +0100 Subject: [PATCH 048/117] ci(jenkins): use docker instead --- Jenkinsfile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 62957b7069..df218f7802 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -91,8 +91,8 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - powershell label: 'Install elasticsearch', script: ".\\.ci\\scripts\\windows\\install-elasticsearch.ps1" - powershell label: 'Install redis', script: ".\\.ci\\scripts\\windows\\install-redis.ps1" + bat label: 'Run redis', script: 'docker run -d -p 6379:6379 redis' + bat label: 'Run elasticsearch', script: 'docker run -d -p 9200:9200 -p 9300:9300 sixeyed/elasticsearch:nanoserver' bat label: 'Tool versions', script: ''' npm --version node --version From 0b4e2648aaacf1adcff661ecfeec5006584b1f81 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 12:29:03 +0100 Subject: [PATCH 049/117] ci(jenkins): only elasticsearch --- Jenkinsfile | 1 - 1 file changed, 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index df218f7802..5967015082 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -91,7 +91,6 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - bat label: 'Run redis', script: 'docker run -d -p 6379:6379 redis' bat label: 'Run elasticsearch', script: 'docker run -d -p 9200:9200 -p 9300:9300 sixeyed/elasticsearch:nanoserver' bat label: 'Tool versions', script: ''' npm --version From a587e88970280f7f33f86b90b97087f476a03465 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 14:00:45 +0100 Subject: [PATCH 050/117] ci(jenkins): using docker --- .ci/scripts/windows/docker/README.md | 6 +++ .../windows/docker/elasticsearch/Dockerfile | 43 +++++++++++++++++++ .../docker/elasticsearch/elasticsearch.yml | 8 ++++ .ci/scripts/windows/install-elasticsearch.ps1 | 17 -------- .ci/scripts/windows/install-tools.ps1 | 3 -- Jenkinsfile | 10 +++-- 6 files changed, 63 insertions(+), 24 deletions(-) create mode 100644 .ci/scripts/windows/docker/README.md create mode 100644 .ci/scripts/windows/docker/elasticsearch/Dockerfile create mode 100644 .ci/scripts/windows/docker/elasticsearch/elasticsearch.yml delete mode 100755 .ci/scripts/windows/install-elasticsearch.ps1 diff --git a/.ci/scripts/windows/docker/README.md b/.ci/scripts/windows/docker/README.md new file mode 100644 index 0000000000..8de3a4bd92 --- /dev/null +++ b/.ci/scripts/windows/docker/README.md @@ -0,0 +1,6 @@ +## Version compatibility + +https://docs.microsoft.com/en-us/virtualization/windowscontainers/deploy-containers/version-compatibility#matching-container-host-version-with-container-image-versions + +### Further docs +- [ES for Windows](https://github.com/sixeyed/dockerfiles-windows/tree/master/elasticsearch) diff --git a/.ci/scripts/windows/docker/elasticsearch/Dockerfile b/.ci/scripts/windows/docker/elasticsearch/Dockerfile new file mode 100644 index 0000000000..5b1eb3b392 --- /dev/null +++ b/.ci/scripts/windows/docker/elasticsearch/Dockerfile @@ -0,0 +1,43 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 AS installer +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ARG ES_VERSION="6.7.2" +ENV ES_HOME="C:\elasticsearch" ` + ES_ROOT_URL="https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch" + +RUN Write-Host "Downloading: $env:ES_ROOT_URL-$env:ES_VERSION.zip"; ` + Invoke-WebRequest "$env:ES_ROOT_URL-$env:ES_VERSION.zip.sha512" -OutFile 'elasticsearch.zip.sha' -UseBasicParsing; ` + $env:ES_SHA = (Get-Content -Raw elasticsearch.zip.sha).Split(' ')[0]; ` + Invoke-WebRequest "$env:ES_ROOT_URL-$env:ES_VERSION.zip" -OutFile 'elasticsearch.zip' -UseBasicParsing; ` + if ((Get-FileHash elasticsearch.zip -Algorithm sha512).Hash.ToLower() -ne $env:ES_SHA) {exit 1}; ` + Expand-Archive elasticsearch.zip -DestinationPath C:\ ; ` + Move-Item c:/elasticsearch-$($env:ES_VERSION) $env:ES_HOME; + +# Elasticsearch +FROM openjdk:8-windowsservercore-1809 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop';"] + +ARG ES_VERSION="6.7.2" +ENV ES_VERSION=${ES_VERSION} ` + ES_HOME="C:\elasticsearch" ` + ES_JAVA_OPTS="-Xms1024m -Xmx1024m" + +VOLUME C:\data +EXPOSE 9200 9300 + +SHELL ["cmd", "/S", "/C"] +CMD ".\bin\elasticsearch.bat" + +WORKDIR $ES_HOME +COPY --from=installer C:\elasticsearch\ . +COPY elasticsearch.yml ./config/elasticsearch.yml + +HEALTHCHECK --interval=5s ` + CMD powershell -command ` + try { ` + $content = (iwr -useb http://localhost:9200/_cat/health).Content; ` + $health = $content.Split(' ')[3]; ` + if ($health -eq 'green' -or $health -eq 'yellow') { return 0 } ` + else { return 1 }; ` + } catch { return 1 } diff --git a/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml b/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml new file mode 100644 index 0000000000..d43c03a8c7 --- /dev/null +++ b/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml @@ -0,0 +1,8 @@ +network.host: 0.0.0.0 + +# this value is required because we set "network.host" +# be sure to modify it appropriately for a production cluster deployment +discovery.zen.minimum_master_nodes: 1 + +path: + data: C:\data diff --git a/.ci/scripts/windows/install-elasticsearch.ps1 b/.ci/scripts/windows/install-elasticsearch.ps1 deleted file mode 100755 index 476fc8e7a9..0000000000 --- a/.ci/scripts/windows/install-elasticsearch.ps1 +++ /dev/null @@ -1,17 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Installing Elasticsearch..." -& choco install elasticsearch --no-progress -y --version=6.7.0 - -refreshenv - -Write-Host "Starting Elasticsearch service..." -& elasticsearch-service.bat start - -do { - Write-Host "Waiting for Elasticsearch service to bootstrap..." - sleep 1 -} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) - -Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 63f0b899b5..cb771ebd12 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -6,6 +6,3 @@ $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nod Write-Host "Installing Nodejs..." & choco install nodejs --no-progress -y --version "$Version" - -Write-Host "Installing JDK8..." -& choco install adoptopenjdk8jre --no-progress -y --force -params 'installdir=c:\\java' diff --git a/Jenkinsfile b/Jenkinsfile index 5967015082..6973dc991b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -78,10 +78,8 @@ def generateStepForWindows(Map params = [:]){ node('windows-2019-docker-immutable'){ try { env.HOME = "${WORKSPACE}" - // Ensure the JDK is the one installed - env.JAVA_HOME = 'C:\\java' // When installing with choco the PATH might not be updated within the already connected worker. - env.PATH = "${env.JAVA_HOME}\\bin;${PATH};C:\\Program Files\\nodejs" + env.PATH = "${PATH};C:\\Program Files\\nodejs" env.VERSION = "${version}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -91,7 +89,11 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" - bat label: 'Run elasticsearch', script: 'docker run -d -p 9200:9200 -p 9300:9300 sixeyed/elasticsearch:nanoserver' + bat label: 'Run elasticsearch', script: ''' + cd .ci/scripts/windows/docker/elasticsearch + docker build --tag=elasticsearch . + docker run -d -p 9200:9200 -p 9300:9300 elasticsearch + ''' bat label: 'Tool versions', script: ''' npm --version node --version From 25a824ef59ef4b4c037b3f0f90479c25564773d3 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 15:46:34 +0100 Subject: [PATCH 051/117] ci(jenkins): redis with docker --- .ci/scripts/windows/docker/redis/Dockerfile | 18 + .ci/scripts/windows/docker/redis/redis.conf | 887 ++++++++++++++++++++ .ci/scripts/windows/install-redis.ps1 | 23 - Jenkinsfile | 12 +- 4 files changed, 916 insertions(+), 24 deletions(-) create mode 100644 .ci/scripts/windows/docker/redis/Dockerfile create mode 100644 .ci/scripts/windows/docker/redis/redis.conf delete mode 100755 .ci/scripts/windows/install-redis.ps1 diff --git a/.ci/scripts/windows/docker/redis/Dockerfile b/.ci/scripts/windows/docker/redis/Dockerfile new file mode 100644 index 0000000000..1036b18f70 --- /dev/null +++ b/.ci/scripts/windows/docker/redis/Dockerfile @@ -0,0 +1,18 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +ARG VERSION="2.8.19" +ENV REDIS_HOME="C:\redis" +ENV ROOT_URL="https://github.com/MSOpenTech/redis/releases/download/win" +WORKDIR $REDIS_HOME + +RUN Write-Host "Downloading: $env:ROOT_URL-$env:VERSION.zip"; ` + Invoke-WebRequest "$env:ROOT_URL-$env:VERSION/redis-$env:VERSION.zip" -OutFile 'redis.zip' -UseBasicParsing; ` + Expand-Archive redis.zip -DestinationPath C:\redis ; + +COPY redis.conf . +EXPOSE 6379 + +SHELL ["cmd", "/S", "/C"] +CMD "redis-server redis.conf" diff --git a/.ci/scripts/windows/docker/redis/redis.conf b/.ci/scripts/windows/docker/redis/redis.conf new file mode 100644 index 0000000000..47a8d0766c --- /dev/null +++ b/.ci/scripts/windows/docker/redis/redis.conf @@ -0,0 +1,887 @@ +# Redis configuration file example + +# Note on units: when memory size is needed, it is possible to specify +# it in the usual form of 1k 5GB 4M and so forth: +# +# 1k => 1000 bytes +# 1kb => 1024 bytes +# 1m => 1000000 bytes +# 1mb => 1024*1024 bytes +# 1g => 1000000000 bytes +# 1gb => 1024*1024*1024 bytes +# +# units are case insensitive so 1GB 1Gb 1gB are all the same. + +################################## INCLUDES ################################### + +# Include one or more other config files here. This is useful if you +# have a standard template that goes to all Redis servers but also need +# to customize a few per-server settings. Include files can include +# other files, so use this wisely. +# +# Notice option "include" won't be rewritten by command "CONFIG REWRITE" +# from admin or Redis Sentinel. Since Redis always uses the last processed +# line as value of a configuration directive, you'd better put includes +# at the beginning of this file to avoid overwriting config change at runtime. +# +# If instead you are interested in using includes to override configuration +# options, it is better to use include as the last line. +# +# include .\path\to\local.conf +# include c:\path\to\other.conf + +################################ GENERAL ##################################### + +# On Windows, daemonize and pidfile are not supported. +# However, you can run redis as a Windows service, and specify a logfile. +# The logfile will contain the pid. + +# Accept connections on the specified port, default is 6379. +# If port 0 is specified Redis will not listen on a TCP socket. +port 6379 + +# TCP listen() backlog. +# +# In high requests-per-second environments you need an high backlog in order +# to avoid slow clients connections issues. Note that the Linux kernel +# will silently truncate it to the value of /proc/sys/net/core/somaxconn so +# make sure to raise both the value of somaxconn and tcp_max_syn_backlog +# in order to get the desired effect. +tcp-backlog 511 + +# By default Redis listens for connections from all the network interfaces +# available on the server. It is possible to listen to just one or multiple +# interfaces using the "bind" configuration directive, followed by one or +# more IP addresses. +# +# Examples: +# +# bind 192.168.1.100 10.0.0.1 +# bind 127.0.0.1 + + +# Specify the path for the Unix socket that will be used to listen for +# incoming connections. There is no default, so Redis will not listen +# on a unix socket when not specified. +# +# unixsocket /tmp/redis.sock +# unixsocketperm 700 + +# Close the connection after a client is idle for N seconds (0 to disable) +timeout 0 + +# TCP keepalive. +# +# If non-zero, use SO_KEEPALIVE to send TCP ACKs to clients in absence +# of communication. This is useful for two reasons: +# +# 1) Detect dead peers. +# 2) Take the connection alive from the point of view of network +# equipment in the middle. +# +# On Linux, the specified value (in seconds) is the period used to send ACKs. +# Note that to close the connection the double of the time is needed. +# On other kernels the period depends on the kernel configuration. +# +# A reasonable value for this option is 60 seconds. +tcp-keepalive 0 + +# Specify the server verbosity level. +# This can be one of: +# debug (a lot of information, useful for development/testing) +# verbose (many rarely useful info, but not a mess like the debug level) +# notice (moderately verbose, what you want in production probably) +# warning (only very important / critical messages are logged) +loglevel debug + +# Specify the log file name. Also 'stdout' can be used to force +# Redis to log on the standard output. +logfile "" + +# To enable logging to the Windows EventLog, just set 'syslog-enabled' to +# yes, and optionally update the other syslog parameters to suit your needs. +# If Redis is installed and launched as a Windows Service, this will +# automatically be enabled. +# syslog-enabled no + +# Specify the source name of the events in the Windows Application log. +# syslog-ident redis + +# Set the number of databases. The default database is DB 0, you can select +# a different one on a per-connection basis using SELECT where +# dbid is a number between 0 and 'databases'-1 +databases 16 + +################################ SNAPSHOTTING ################################ +# +# Save the DB on disk: +# +# save +# +# Will save the DB if both the given number of seconds and the given +# number of write operations against the DB occurred. +# +# In the example below the behaviour will be to save: +# after 900 sec (15 min) if at least 1 key changed +# after 300 sec (5 min) if at least 10 keys changed +# after 60 sec if at least 10000 keys changed +# +# Note: you can disable saving completely by commenting out all "save" lines. +# +# It is also possible to remove all the previously configured save +# points by adding a save directive with a single empty string argument +# like in the following example: +# +# save "" + +save 900 1 +save 300 10 +save 60 10000 + +# By default Redis will stop accepting writes if RDB snapshots are enabled +# (at least one save point) and the latest background save failed. +# This will make the user aware (in a hard way) that data is not persisting +# on disk properly, otherwise chances are that no one will notice and some +# disaster will happen. +# +# If the background saving process will start working again Redis will +# automatically allow writes again. +# +# However if you have setup your proper monitoring of the Redis server +# and persistence, you may want to disable this feature so that Redis will +# continue to work as usual even if there are problems with disk, +# permissions, and so forth. +stop-writes-on-bgsave-error yes + +# Compress string objects using LZF when dump .rdb databases? +# For default that's set to 'yes' as it's almost always a win. +# If you want to save some CPU in the saving child set it to 'no' but +# the dataset will likely be bigger if you have compressible values or keys. +rdbcompression yes + +# Since version 5 of RDB a CRC64 checksum is placed at the end of the file. +# This makes the format more resistant to corruption but there is a performance +# hit to pay (around 10%) when saving and loading RDB files, so you can disable it +# for maximum performances. +# +# RDB files created with checksum disabled have a checksum of zero that will +# tell the loading code to skip the check. +rdbchecksum yes + +# The filename where to dump the DB +dbfilename dump.rdb + +# The working directory. +# +# The DB will be written inside this directory, with the filename specified +# above using the 'dbfilename' configuration directive. +# +# The Append Only File will also be created inside this directory. +# +# Note that you must specify a directory here, not a file name. +dir ./ + +################################# REPLICATION ################################# + +# Master-Slave replication. Use slaveof to make a Redis instance a copy of +# another Redis server. A few things to understand ASAP about Redis replication. +# +# 1) Redis replication is asynchronous, but you can configure a master to +# stop accepting writes if it appears to be not connected with at least +# a given number of slaves. +# 2) Redis slaves are able to perform a partial resynchronization with the +# master if the replication link is lost for a relatively small amount of +# time. You may want to configure the replication backlog size (see the next +# sections of this file) with a sensible value depending on your needs. +# 3) Replication is automatic and does not need user intervention. After a +# network partition slaves automatically try to reconnect to masters +# and resynchronize with them. +# +# slaveof + +# If the master is password protected (using the "requirepass" configuration +# directive below) it is possible to tell the slave to authenticate before +# starting the replication synchronization process, otherwise the master will +# refuse the slave request. +# +# masterauth + +# When a slave loses its connection with the master, or when the replication +# is still in progress, the slave can act in two different ways: +# +# 1) if slave-serve-stale-data is set to 'yes' (the default) the slave will +# still reply to client requests, possibly with out of date data, or the +# data set may just be empty if this is the first synchronization. +# +# 2) if slave-serve-stale-data is set to 'no' the slave will reply with +# an error "SYNC with master in progress" to all the kind of commands +# but to INFO and SLAVEOF. +# +slave-serve-stale-data yes + +# You can configure a slave instance to accept writes or not. Writing against +# a slave instance may be useful to store some ephemeral data (because data +# written on a slave will be easily deleted after resync with the master) but +# may also cause problems if clients are writing to it because of a +# misconfiguration. +# +# Since Redis 2.6 by default slaves are read-only. +# +# Note: read only slaves are not designed to be exposed to untrusted clients +# on the internet. It's just a protection layer against misuse of the instance. +# Still a read only slave exports by default all the administrative commands +# such as CONFIG, DEBUG, and so forth. To a limited extent you can improve +# security of read only slaves using 'rename-command' to shadow all the +# administrative / dangerous commands. +slave-read-only yes + +# Replication SYNC strategy: disk or socket. +# +# ------------------------------------------------------- +# WARNING: DISKLESS REPLICATION IS EXPERIMENTAL CURRENTLY +# ------------------------------------------------------- +# +# New slaves and reconnecting slaves that are not able to continue the replication +# process just receiving differences, need to do what is called a "full +# synchronization". An RDB file is transmitted from the master to the slaves. +# The transmission can happen in two different ways: +# +# 1) Disk-backed: The Redis master creates a new process that writes the RDB +# file on disk. Later the file is transferred by the parent +# process to the slaves incrementally. +# 2) Diskless: The Redis master creates a new process that directly writes the +# RDB file to slave sockets, without touching the disk at all. +# +# With disk-backed replication, while the RDB file is generated, more slaves +# can be queued and served with the RDB file as soon as the current child producing +# the RDB file finishes its work. With diskless replication instead once +# the transfer starts, new slaves arriving will be queued and a new transfer +# will start when the current one terminates. +# +# When diskless replication is used, the master waits a configurable amount of +# time (in seconds) before starting the transfer in the hope that multiple slaves +# will arrive and the transfer can be parallelized. +# +# With slow disks and fast (large bandwidth) networks, diskless replication +# works better. +repl-diskless-sync no + +# When diskless replication is enabled, it is possible to configure the delay +# the server waits in order to spawn the child that trnasfers the RDB via socket +# to the slaves. +# +# This is important since once the transfer starts, it is not possible to serve +# new slaves arriving, that will be queued for the next RDB transfer, so the server +# waits a delay in order to let more slaves arrive. +# +# The delay is specified in seconds, and by default is 5 seconds. To disable +# it entirely just set it to 0 seconds and the transfer will start ASAP. +repl-diskless-sync-delay 5 + +# Slaves send PINGs to server in a predefined interval. It's possible to change +# this interval with the repl_ping_slave_period option. The default value is 10 +# seconds. +# +# repl-ping-slave-period 10 + +# The following option sets the replication timeout for: +# +# 1) Bulk transfer I/O during SYNC, from the point of view of slave. +# 2) Master timeout from the point of view of slaves (data, pings). +# 3) Slave timeout from the point of view of masters (REPLCONF ACK pings). +# +# It is important to make sure that this value is greater than the value +# specified for repl-ping-slave-period otherwise a timeout will be detected +# every time there is low traffic between the master and the slave. +# +# repl-timeout 60 + +# Disable TCP_NODELAY on the slave socket after SYNC? +# +# If you select "yes" Redis will use a smaller number of TCP packets and +# less bandwidth to send data to slaves. But this can add a delay for +# the data to appear on the slave side, up to 40 milliseconds with +# Linux kernels using a default configuration. +# +# If you select "no" the delay for data to appear on the slave side will +# be reduced but more bandwidth will be used for replication. +# +# By default we optimize for low latency, but in very high traffic conditions +# or when the master and slaves are many hops away, turning this to "yes" may +# be a good idea. +repl-disable-tcp-nodelay no + +# Set the replication backlog size. The backlog is a buffer that accumulates +# slave data when slaves are disconnected for some time, so that when a slave +# wants to reconnect again, often a full resync is not needed, but a partial +# resync is enough, just passing the portion of data the slave missed while +# disconnected. +# +# The bigger the replication backlog, the longer the time the slave can be +# disconnected and later be able to perform a partial resynchronization. +# +# The backlog is only allocated once there is at least a slave connected. +# +# repl-backlog-size 1mb + +# After a master has no longer connected slaves for some time, the backlog +# will be freed. The following option configures the amount of seconds that +# need to elapse, starting from the time the last slave disconnected, for +# the backlog buffer to be freed. +# +# A value of 0 means to never release the backlog. +# +# repl-backlog-ttl 3600 + +# The slave priority is an integer number published by Redis in the INFO output. +# It is used by Redis Sentinel in order to select a slave to promote into a +# master if the master is no longer working correctly. +# +# A slave with a low priority number is considered better for promotion, so +# for instance if there are three slaves with priority 10, 100, 25 Sentinel will +# pick the one with priority 10, that is the lowest. +# +# However a special priority of 0 marks the slave as not able to perform the +# role of master, so a slave with priority of 0 will never be selected by +# Redis Sentinel for promotion. +# +# By default the priority is 100. +slave-priority 100 + +# It is possible for a master to stop accepting writes if there are less than +# N slaves connected, having a lag less or equal than M seconds. +# +# The N slaves need to be in "online" state. +# +# The lag in seconds, that must be <= the specified value, is calculated from +# the last ping received from the slave, that is usually sent every second. +# +# This option does not GUARANTEE that N replicas will accept the write, but +# will limit the window of exposure for lost writes in case not enough slaves +# are available, to the specified number of seconds. +# +# For example to require at least 3 slaves with a lag <= 10 seconds use: +# +# min-slaves-to-write 3 +# min-slaves-max-lag 10 +# +# Setting one or the other to 0 disables the feature. +# +# By default min-slaves-to-write is set to 0 (feature disabled) and +# min-slaves-max-lag is set to 10. + +################################## SECURITY ################################### + +# Require clients to issue AUTH before processing any other +# commands. This might be useful in environments in which you do not trust +# others with access to the host running redis-server. +# +# This should stay commented out for backward compatibility and because most +# people do not need auth (e.g. they run their own servers). +# +# Warning: since Redis is pretty fast an outside user can try up to +# 150k passwords per second against a good box. This means that you should +# use a very strong password otherwise it will be very easy to break. +# +# requirepass foobared + +# Command renaming. +# +# It is possible to change the name of dangerous commands in a shared +# environment. For instance the CONFIG command may be renamed into something +# hard to guess so that it will still be available for internal-use tools +# but not available for general clients. +# +# Example: +# +# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52 +# +# It is also possible to completely kill a command by renaming it into +# an empty string: +# +# rename-command CONFIG "" +# +# Please note that changing the name of commands that are logged into the +# AOF file or transmitted to slaves may cause problems. + +################################### LIMITS #################################### + +# Set the max number of connected clients at the same time. By default +# this limit is set to 10000 clients, however if the Redis server is not +# able to configure the process file limit to allow for the specified limit +# the max number of allowed clients is set to the current file limit +# minus 32 (as Redis reserves a few file descriptors for internal uses). +# +# Once the limit is reached Redis will close all the new connections sending +# an error 'max number of clients reached'. +# +# maxclients 10000 + +# The Linux version of Redis relies on the system call fork() to perform +# point-in-time snapshots of the heap. In addition to the AOF and RDB backup +# mechanism, the master-slave synchronization and clustering features are +# dependent on this behavior of fork(). In order for the Windows version to +# perform like the Linux version we had to simulate this aspect of fork(). +# Doing so meant moving the Redis heap into a memory mapped file that can +# be shared with a child process. +# +# *** There must be disk space available for this file in order for Redis +# to launch. *** The default configuration places this file in the local +# appdata directory. If you wish to move this file to another local disk, +# use the heapdir flag as described below. +# +# The maxheap flag controls the maximum size of this memory mapped file, +# as well as the total usable space for the Redis heap. Running Redis +# without either maxheap or maxmemory will result in a memory mapped file +# being created that is equal to the size of physical memory. During +# fork() operations the total page file commit will max out at around: +# +# (size of physical memory) + (2 * size of maxheap) +# +# For instance, on a machine with 8GB of physical RAM, the max page file +# commit with the default maxheap size will be (8)+(2*8) GB , or 24GB. The +# default page file sizing of Windows will allow for this without having +# to reconfigure the system. Larger heap sizes are possible, but the maximum +# page file size will have to be increased accordingly. +# +# The Redis heap must be larger than the value specified by the maxmemory +# flag, as the heap allocator has its own memory requirements and +# fragmentation of the heap is inevitable. If only the maxmemory flag is +# specified, maxheap will be set at 1.5*maxmemory. If the maxheap flag is +# specified along with maxmemory, the maxheap flag will be automatically +# increased if it is smaller than 1.5*maxmemory. +# +maxheap 128m + +# The heap memory mapped file must reside on a local path for heap sharing +# between processes to work. A UNC path will not suffice here. For maximum +# performance this should be located on the fastest local drive available. +# This value defaults to the local application data folder(e.g., +# "%USERPROFILE%\AppData\Local"). Since this file can be very large, you +# may wish to place this on a drive other than the one the operating system +# is installed on. +# +# Note that you must specify a directory here, not a file name. +# heapdir + +# If Redis is to be used as an in-memory-only cache without any kind of +# persistence, then the fork() mechanism used by the background AOF/RDB +# persistence is unneccessary. As an optimization, all persistence can be +# turned off in the Windows version of Redis. This will disable the creation of +# the memory mapped heap file, redirect heap allocations to the system heap +# allocator, and disable commands that would otherwise cause fork() operations: +# BGSAVE and BGREWRITEAOF. This flag may not be combined with any of the other +# flags that configure AOF and RDB operations. +# persistence-available [(yes)|no] + +# Don't use more memory than the specified amount of bytes. +# When the memory limit is reached Redis will try to remove keys +# according to the eviction policy selected (see maxmemory-policy). +# +# If Redis can't remove keys according to the policy, or if the policy is +# set to 'noeviction', Redis will start to reply with errors to commands +# that would use more memory, like SET, LPUSH, and so on, and will continue +# to reply to read-only commands like GET. +# +# This option is usually useful when using Redis as an LRU cache, or to set +# a hard memory limit for an instance (using the 'noeviction' policy). +# +# WARNING: If you have slaves attached to an instance with maxmemory on, +# the size of the output buffers needed to feed the slaves are subtracted +# from the used memory count, so that network problems / resyncs will +# not trigger a loop where keys are evicted, and in turn the output +# buffer of slaves is full with DELs of keys evicted triggering the deletion +# of more keys, and so forth until the database is completely emptied. +# +# In short... if you have slaves attached it is suggested that you set a lower +# limit for maxmemory so that there is some free RAM on the system for slave +# output buffers (but this is not needed if the policy is 'noeviction'). +# +maxmemory 64m + +# MAXMEMORY POLICY: how Redis will select what to remove when maxmemory +# is reached. You can select among five behaviors: +# +# volatile-lru -> remove the key with an expire set using an LRU algorithm +# allkeys-lru -> remove any key according to the LRU algorithm +# volatile-random -> remove a random key with an expire set +# allkeys-random -> remove a random key, any key +# volatile-ttl -> remove the key with the nearest expire time (minor TTL) +# noeviction -> don't expire at all, just return an error on write operations +# +# Note: with any of the above policies, Redis will return an error on write +# operations, when there are no suitable keys for eviction. +# +# At the date of writing these commands are: set setnx setex append +# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd +# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby +# zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby +# getset mset msetnx exec sort +# +# The default is: +# +# maxmemory-policy volatile-lru + +# LRU and minimal TTL algorithms are not precise algorithms but approximated +# algorithms (in order to save memory), so you can select as well the sample +# size to check. For instance for default Redis will check three keys and +# pick the one that was used less recently, you can change the sample size +# using the following configuration directive. +# +# maxmemory-samples 3 + +############################## APPEND ONLY MODE ############################### + +# By default Redis asynchronously dumps the dataset on disk. This mode is +# good enough in many applications, but an issue with the Redis process or +# a power outage may result into a few minutes of writes lost (depending on +# the configured save points). +# +# The Append Only File is an alternative persistence mode that provides +# much better durability. For instance using the default data fsync policy +# (see later in the config file) Redis can lose just one second of writes in a +# dramatic event like a server power outage, or a single write if something +# wrong with the Redis process itself happens, but the operating system is +# still running correctly. +# +# AOF and RDB persistence can be enabled at the same time without problems. +# If the AOF is enabled on startup Redis will load the AOF, that is the file +# with the better durability guarantees. +# +# Please check http://redis.io/topics/persistence for more information. + +appendonly no + +# The name of the append only file (default: "appendonly.aof") +appendfilename "appendonly.aof" + +# The fsync() call tells the Operating System to actually write data on disk +# instead of waiting for more data in the output buffer. Some OS will really flush +# data on disk, some other OS will just try to do it ASAP. +# +# Redis supports three different modes: +# +# no: don't fsync, just let the OS flush the data when it wants. Faster. +# always: fsync after every write to the append only log . Slow, Safest. +# everysec: fsync only one time every second. Compromise. +# +# The default is "everysec", as that's usually the right compromise between +# speed and data safety. It's up to you to understand if you can relax this to +# "no" that will let the operating system flush the output buffer when +# it wants, for better performances (but if you can live with the idea of +# some data loss consider the default persistence mode that's snapshotting), +# or on the contrary, use "always" that's very slow but a bit safer than +# everysec. +# +# More details please check the following article: +# http://antirez.com/post/redis-persistence-demystified.html +# +# If unsure, use "everysec". + +# appendfsync always +appendfsync everysec +# appendfsync no + +# When the AOF fsync policy is set to always or everysec, and a background +# saving process (a background save or AOF log background rewriting) is +# performing a lot of I/O against the disk, in some Linux configurations +# Redis may block too long on the fsync() call. Note that there is no fix for +# this currently, as even performing fsync in a different thread will block +# our synchronous write(2) call. +# +# In order to mitigate this problem it's possible to use the following option +# that will prevent fsync() from being called in the main process while a +# BGSAVE or BGREWRITEAOF is in progress. +# +# This means that while another child is saving, the durability of Redis is +# the same as "appendfsync none". In practical terms, this means that it is +# possible to lose up to 30 seconds of log in the worst scenario (with the +# default Linux settings). +# +# If you have latency problems turn this to "yes". Otherwise leave it as +# "no" that is the safest pick from the point of view of durability. +no-appendfsync-on-rewrite no + +# Automatic rewrite of the append only file. +# Redis is able to automatically rewrite the log file implicitly calling +# BGREWRITEAOF when the AOF log size grows by the specified percentage. +# +# This is how it works: Redis remembers the size of the AOF file after the +# latest rewrite (if no rewrite has happened since the restart, the size of +# the AOF at startup is used). +# +# This base size is compared to the current size. If the current size is +# bigger than the specified percentage, the rewrite is triggered. Also +# you need to specify a minimal size for the AOF file to be rewritten, this +# is useful to avoid rewriting the AOF file even if the percentage increase +# is reached but it is still pretty small. +# +# Specify a percentage of zero in order to disable the automatic AOF +# rewrite feature. + +auto-aof-rewrite-percentage 100 +auto-aof-rewrite-min-size 64mb + +# An AOF file may be found to be truncated at the end during the Redis +# startup process, when the AOF data gets loaded back into memory. +# This may happen when the system where Redis is running +# crashes, especially when an ext4 filesystem is mounted without the +# data=ordered option (however this can't happen when Redis itself +# crashes or aborts but the operating system still works correctly). +# +# Redis can either exit with an error when this happens, or load as much +# data as possible (the default now) and start if the AOF file is found +# to be truncated at the end. The following option controls this behavior. +# +# If aof-load-truncated is set to yes, a truncated AOF file is loaded and +# the Redis server starts emitting a log to inform the user of the event. +# Otherwise if the option is set to no, the server aborts with an error +# and refuses to start. When the option is set to no, the user requires +# to fix the AOF file using the "redis-check-aof" utility before to restart +# the server. +# +# Note that if the AOF file will be found to be corrupted in the middle +# the server will still exit with an error. This option only applies when +# Redis will try to read more data from the AOF file but not enough bytes +# will be found. +aof-load-truncated yes + +################################ LUA SCRIPTING ############################### + +# Max execution time of a Lua script in milliseconds. +# +# If the maximum execution time is reached Redis will log that a script is +# still in execution after the maximum allowed time and will start to +# reply to queries with an error. +# +# When a long running script exceeds the maximum execution time only the +# SCRIPT KILL and SHUTDOWN NOSAVE commands are available. The first can be +# used to stop a script that did not yet called write commands. The second +# is the only way to shut down the server in the case a write command was +# already issued by the script but the user doesn't want to wait for the natural +# termination of the script. +# +# Set it to 0 or a negative value for unlimited execution without warnings. +lua-time-limit 5000 + +################################## SLOW LOG ################################### + +# The Redis Slow Log is a system to log queries that exceeded a specified +# execution time. The execution time does not include the I/O operations +# like talking with the client, sending the reply and so forth, +# but just the time needed to actually execute the command (this is the only +# stage of command execution where the thread is blocked and can not serve +# other requests in the meantime). +# +# You can configure the slow log with two parameters: one tells Redis +# what is the execution time, in microseconds, to exceed in order for the +# command to get logged, and the other parameter is the length of the +# slow log. When a new command is logged the oldest one is removed from the +# queue of logged commands. + +# The following time is expressed in microseconds, so 1000000 is equivalent +# to one second. Note that a negative number disables the slow log, while +# a value of zero forces the logging of every command. +slowlog-log-slower-than 10000 + +# There is no limit to this length. Just be aware that it will consume memory. +# You can reclaim memory used by the slow log with SLOWLOG RESET. +slowlog-max-len 128 + +################################ LATENCY MONITOR ############################## + +# The Redis latency monitoring subsystem samples different operations +# at runtime in order to collect data related to possible sources of +# latency of a Redis instance. +# +# Via the LATENCY command this information is available to the user that can +# print graphs and obtain reports. +# +# The system only logs operations that were performed in a time equal or +# greater than the amount of milliseconds specified via the +# latency-monitor-threshold configuration directive. When its value is set +# to zero, the latency monitor is turned off. +# +# By default latency monitoring is disabled since it is mostly not needed +# if you don't have latency issues, and collecting data has a performance +# impact, that while very small, can be measured under big load. Latency +# monitoring can easily be enalbed at runtime using the command +# "CONFIG SET latency-monitor-threshold " if needed. +latency-monitor-threshold 0 + +############################# Event notification ############################## + +# Redis can notify Pub/Sub clients about events happening in the key space. +# This feature is documented at http://redis.io/topics/notifications +# +# For instance if keyspace events notification is enabled, and a client +# performs a DEL operation on key "foo" stored in the Database 0, two +# messages will be published via Pub/Sub: +# +# PUBLISH __keyspace@0__:foo del +# PUBLISH __keyevent@0__:del foo +# +# It is possible to select the events that Redis will notify among a set +# of classes. Every class is identified by a single character: +# +# K Keyspace events, published with __keyspace@__ prefix. +# E Keyevent events, published with __keyevent@__ prefix. +# g Generic commands (non-type specific) like DEL, EXPIRE, RENAME, ... +# $ String commands +# l List commands +# s Set commands +# h Hash commands +# z Sorted set commands +# x Expired events (events generated every time a key expires) +# e Evicted events (events generated when a key is evicted for maxmemory) +# A Alias for g$lshzxe, so that the "AKE" string means all the events. +# +# The "notify-keyspace-events" takes as argument a string that is composed +# of zero or multiple characters. The empty string means that notifications +# are disabled. +# +# Example: to enable list and generic events, from the point of view of the +# event name, use: +# +# notify-keyspace-events Elg +# +# Example 2: to get the stream of the expired keys subscribing to channel +# name __keyevent@0__:expired use: +# +# notify-keyspace-events Ex +# +# By default all notifications are disabled because most users don't need +# this feature and the feature has some overhead. Note that if you don't +# specify at least one of K or E, no events will be delivered. +notify-keyspace-events "" + +############################### ADVANCED CONFIG ############################### + +# Hashes are encoded using a memory efficient data structure when they have a +# small number of entries, and the biggest entry does not exceed a given +# threshold. These thresholds can be configured using the following directives. +hash-max-ziplist-entries 512 +hash-max-ziplist-value 64 + +# Similarly to hashes, small lists are also encoded in a special way in order +# to save a lot of space. The special representation is only used when +# you are under the following limits: +list-max-ziplist-entries 512 +list-max-ziplist-value 64 + +# Sets have a special encoding in just one case: when a set is composed +# of just strings that happen to be integers in radix 10 in the range +# of 64 bit signed integers. +# The following configuration setting sets the limit in the size of the +# set in order to use this special memory saving encoding. +set-max-intset-entries 512 + +# Similarly to hashes and lists, sorted sets are also specially encoded in +# order to save a lot of space. This encoding is only used when the length and +# elements of a sorted set are below the following limits: +zset-max-ziplist-entries 128 +zset-max-ziplist-value 64 + +# HyperLogLog sparse representation bytes limit. The limit includes the +# 16 bytes header. When an HyperLogLog using the sparse representation crosses +# this limit, it is converted into the dense representation. +# +# A value greater than 16000 is totally useless, since at that point the +# dense representation is more memory efficient. +# +# The suggested value is ~ 3000 in order to have the benefits of +# the space efficient encoding without slowing down too much PFADD, +# which is O(N) with the sparse encoding. The value can be raised to +# ~ 10000 when CPU is not a concern, but space is, and the data set is +# composed of many HyperLogLogs with cardinality in the 0 - 15000 range. +hll-sparse-max-bytes 3000 + +# Active rehashing uses 1 millisecond every 100 milliseconds of CPU time in +# order to help rehashing the main Redis hash table (the one mapping top-level +# keys to values). The hash table implementation Redis uses (see dict.c) +# performs a lazy rehashing: the more operation you run into a hash table +# that is rehashing, the more rehashing "steps" are performed, so if the +# server is idle the rehashing is never complete and some more memory is used +# by the hash table. +# +# The default is to use this millisecond 10 times every second in order to +# actively rehash the main dictionaries, freeing memory when possible. +# +# If unsure: +# use "activerehashing no" if you have hard latency requirements and it is +# not a good thing in your environment that Redis can reply from time to time +# to queries with 2 milliseconds delay. +# +# use "activerehashing yes" if you don't have such hard requirements but +# want to free memory asap when possible. +activerehashing yes + +# The client output buffer limits can be used to force disconnection of clients +# that are not reading data from the server fast enough for some reason (a +# common reason is that a Pub/Sub client can't consume messages as fast as the +# publisher can produce them). +# +# The limit can be set differently for the three different classes of clients: +# +# normal -> normal clients including MONITOR clients +# slave -> slave clients +# pubsub -> clients subscribed to at least one pubsub channel or pattern +# +# The syntax of every client-output-buffer-limit directive is the following: +# +# client-output-buffer-limit +# +# A client is immediately disconnected once the hard limit is reached, or if +# the soft limit is reached and remains reached for the specified number of +# seconds (continuously). +# So for instance if the hard limit is 32 megabytes and the soft limit is +# 16 megabytes / 10 seconds, the client will get disconnected immediately +# if the size of the output buffers reach 32 megabytes, but will also get +# disconnected if the client reaches 16 megabytes and continuously overcomes +# the limit for 10 seconds. +# +# By default normal clients are not limited because they don't receive data +# without asking (in a push way), but just after a request, so only +# asynchronous clients may create a scenario where data is requested faster +# than it can read. +# +# Instead there is a default limit for pubsub and slave clients, since +# subscribers and slaves receive data in a push fashion. +# +# Both the hard or the soft limit can be disabled by setting them to zero. +client-output-buffer-limit normal 0 0 0 +client-output-buffer-limit slave 256mb 64mb 60 +client-output-buffer-limit pubsub 32mb 8mb 60 + +# Redis calls an internal function to perform many background tasks, like +# closing connections of clients in timeot, purging expired keys that are +# never requested, and so forth. +# +# Not all tasks are perforemd with the same frequency, but Redis checks for +# tasks to perform according to the specified "hz" value. +# +# By default "hz" is set to 10. Raising the value will use more CPU when +# Redis is idle, but at the same time will make Redis more responsive when +# there are many keys expiring at the same time, and timeouts may be +# handled with more precision. +# +# The range is between 1 and 500, however a value over 100 is usually not +# a good idea. Most users should use the default of 10 and raise this up to +# 100 only in environments where very low latency is required. +hz 10 + +# When a child rewrites the AOF file, if the following option is enabled +# the file will be fsync-ed every 32 MB of data generated. This is useful +# in order to commit the file to the disk more incrementally and avoid +# big latency spikes. +aof-rewrite-incremental-fsync yes + +################################## INCLUDES ################################### + +# Include one or more other config files here. This is useful if you +# have a standard template that goes to all Redis server but also need +# to customize a few per-server settings. Include files can include +# other files, so use this wisely. +# +# include /path/to/local.conf +# include /path/to/other.conf diff --git a/.ci/scripts/windows/install-redis.ps1 b/.ci/scripts/windows/install-redis.ps1 deleted file mode 100755 index 1b9ba3e541..0000000000 --- a/.ci/scripts/windows/install-redis.ps1 +++ /dev/null @@ -1,23 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan -$redisVersion = "2.8.19" -$redisRoot = "$env:SYSTEMDRIVE" -$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" -$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" - -Write-Host "Downloading Redis..." -ForegroundColor Cyan -# Fixes: The request was aborted: Could not create SSL/TLS secure -[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$redisRoot" | Out-Null -del $zipPath - -Write-Host "Installing Redis as a Windows service..." -& "$redisRoot\redis-server.exe" --service-install - -Write-Host "Starting Redis service..." -& "$redisRoot\redis-server.exe" --service-start - -Write-Host "Redis installed" -ForegroundColor Green diff --git a/Jenkinsfile b/Jenkinsfile index 6973dc991b..94ca575c41 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -89,10 +89,15 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + bat label: 'Run redis', script: ''' + cd .ci/scripts/windows/docker/redis + docker build --tag=redis . + docker run -d -p 6379:6379 --name redis redis + ''' bat label: 'Run elasticsearch', script: ''' cd .ci/scripts/windows/docker/elasticsearch docker build --tag=elasticsearch . - docker run -d -p 9200:9200 -p 9300:9300 elasticsearch + docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch ''' bat label: 'Tool versions', script: ''' npm --version @@ -103,6 +108,11 @@ def generateStepForWindows(Map params = [:]){ } } catch(e){ error(e.toString()) + } finally { + bat label: 'Gather docker logs', returnStatus: true, script: ''' + docker logs redis + docker logs elasticsearch + ''' } } } From 1d8a6ef174584bc890a63a5328a9415a5af875dc Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 16:37:51 +0100 Subject: [PATCH 052/117] ci(jenkins): cassandra with docker --- .../windows/docker/cassandra/Dockerfile | 31 + .../windows/docker/cassandra/cassandra.yaml | 1237 +++++++++++++++++ .ci/scripts/windows/install-cassandra.ps1 | 23 - Jenkinsfile | 13 +- 4 files changed, 1276 insertions(+), 28 deletions(-) create mode 100644 .ci/scripts/windows/docker/cassandra/Dockerfile create mode 100644 .ci/scripts/windows/docker/cassandra/cassandra.yaml delete mode 100755 .ci/scripts/windows/install-cassandra.ps1 diff --git a/.ci/scripts/windows/docker/cassandra/Dockerfile b/.ci/scripts/windows/docker/cassandra/Dockerfile new file mode 100644 index 0000000000..4fae0ecf6b --- /dev/null +++ b/.ci/scripts/windows/docker/cassandra/Dockerfile @@ -0,0 +1,31 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 AS installer +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) + +RUN choco install 7zip.install --no-progress -y + +ARG VERSION="3.11.3" +ENV CASSANDRA_HOME="C:\cassandra" +ENV ROOT_URL="http://archive.apache.org/dist/cassandra" +WORKDIR $CASSANDRA_HOME + +RUN Write-Host "Downloading: ${env:ROOT_URL}/${env:VERSION}/apache-cassandra-${env:VERSION}-bin.tar.gz"; ` + Invoke-WebRequest "${env:ROOT_URL}/${env:VERSION}/apache-cassandra-${env:VERSION}-bin.tar.gz" -OutFile 'cassandra.tar.gz' -UseBasicParsing; ` + Write-Host "Installing: cassandra.tar.gz"; ` + 7z e cassandra.tar.gz -tgzip -y | Out-Null; ` + 7z x cassandra.tar -ttar -r -aou | Out-Null; ` + del cassandra.tar.gz; + +FROM openjdk:8-windowsservercore-1809 +ENV CASSANDRA_HOME="C:\cassandra" +ENV VERSION="3.11.3" +WORKDIR $CASSANDRA_HOME +COPY --from=installer ${CASSANDRA_HOME}\apache-cassandra-${VERSION}\ . +COPY cassandra.yaml .\conf\cassandra.yaml + +EXPOSE 9042 7000 + +SHELL ["cmd", "/S", "/C"] +CMD "bin\cassandra.bat" diff --git a/.ci/scripts/windows/docker/cassandra/cassandra.yaml b/.ci/scripts/windows/docker/cassandra/cassandra.yaml new file mode 100644 index 0000000000..98fc006099 --- /dev/null +++ b/.ci/scripts/windows/docker/cassandra/cassandra.yaml @@ -0,0 +1,1237 @@ +# Cassandra storage config YAML + +# NOTE: +# See http://wiki.apache.org/cassandra/StorageConfiguration for +# full explanations of configuration directives +# /NOTE + +# The name of the cluster. This is mainly used to prevent machines in +# one logical cluster from joining another. +cluster_name: 'Test Cluster' + +# This defines the number of tokens randomly assigned to this node on the ring +# The more tokens, relative to other nodes, the larger the proportion of data +# that this node will store. You probably want all nodes to have the same number +# of tokens assuming they have equal hardware capability. +# +# If you leave this unspecified, Cassandra will use the default of 1 token for legacy compatibility, +# and will use the initial_token as described below. +# +# Specifying initial_token will override this setting on the node's initial start, +# on subsequent starts, this setting will apply even if initial token is set. +# +# If you already have a cluster with 1 token per node, and wish to migrate to +# multiple tokens per node, see http://wiki.apache.org/cassandra/Operations +num_tokens: 256 + +# Triggers automatic allocation of num_tokens tokens for this node. The allocation +# algorithm attempts to choose tokens in a way that optimizes replicated load over +# the nodes in the datacenter for the replication strategy used by the specified +# keyspace. +# +# The load assigned to each node will be close to proportional to its number of +# vnodes. +# +# Only supported with the Murmur3Partitioner. +# allocate_tokens_for_keyspace: KEYSPACE + +# initial_token allows you to specify tokens manually. While you can use it with +# vnodes (num_tokens > 1, above) -- in which case you should provide a +# comma-separated list -- it's primarily used when adding nodes to legacy clusters +# that do not have vnodes enabled. +# initial_token: + +# See http://wiki.apache.org/cassandra/HintedHandoff +# May either be "true" or "false" to enable globally +hinted_handoff_enabled: true + +# When hinted_handoff_enabled is true, a black list of data centers that will not +# perform hinted handoff +# hinted_handoff_disabled_datacenters: +# - DC1 +# - DC2 + +# this defines the maximum amount of time a dead host will have hints +# generated. After it has been dead this long, new hints for it will not be +# created until it has been seen alive and gone down again. +max_hint_window_in_ms: 10800000 # 3 hours + +# Maximum throttle in KBs per second, per delivery thread. This will be +# reduced proportionally to the number of nodes in the cluster. (If there +# are two nodes in the cluster, each delivery thread will use the maximum +# rate; if there are three, each will throttle to half of the maximum, +# since we expect two nodes to be delivering hints simultaneously.) +hinted_handoff_throttle_in_kb: 1024 + +# Number of threads with which to deliver hints; +# Consider increasing this number when you have multi-dc deployments, since +# cross-dc handoff tends to be slower +max_hints_delivery_threads: 2 + +# Directory where Cassandra should store hints. +# If not set, the default directory is $CASSANDRA_HOME/data/hints. +# hints_directory: /var/lib/cassandra/hints + +# How often hints should be flushed from the internal buffers to disk. +# Will *not* trigger fsync. +hints_flush_period_in_ms: 10000 + +# Maximum size for a single hints file, in megabytes. +max_hints_file_size_in_mb: 128 + +# Compression to apply to the hint files. If omitted, hints files +# will be written uncompressed. LZ4, Snappy, and Deflate compressors +# are supported. +#hints_compression: +# - class_name: LZ4Compressor +# parameters: +# - + +# Maximum throttle in KBs per second, total. This will be +# reduced proportionally to the number of nodes in the cluster. +batchlog_replay_throttle_in_kb: 1024 + +# Authentication backend, implementing IAuthenticator; used to identify users +# Out of the box, Cassandra provides org.apache.cassandra.auth.{AllowAllAuthenticator, +# PasswordAuthenticator}. +# +# - AllowAllAuthenticator performs no checks - set it to disable authentication. +# - PasswordAuthenticator relies on username/password pairs to authenticate +# users. It keeps usernames and hashed passwords in system_auth.roles table. +# Please increase system_auth keyspace replication factor if you use this authenticator. +# If using PasswordAuthenticator, CassandraRoleManager must also be used (see below) +authenticator: AllowAllAuthenticator + +# Authorization backend, implementing IAuthorizer; used to limit access/provide permissions +# Out of the box, Cassandra provides org.apache.cassandra.auth.{AllowAllAuthorizer, +# CassandraAuthorizer}. +# +# - AllowAllAuthorizer allows any action to any user - set it to disable authorization. +# - CassandraAuthorizer stores permissions in system_auth.role_permissions table. Please +# increase system_auth keyspace replication factor if you use this authorizer. +authorizer: AllowAllAuthorizer + +# Part of the Authentication & Authorization backend, implementing IRoleManager; used +# to maintain grants and memberships between roles. +# Out of the box, Cassandra provides org.apache.cassandra.auth.CassandraRoleManager, +# which stores role information in the system_auth keyspace. Most functions of the +# IRoleManager require an authenticated login, so unless the configured IAuthenticator +# actually implements authentication, most of this functionality will be unavailable. +# +# - CassandraRoleManager stores role data in the system_auth keyspace. Please +# increase system_auth keyspace replication factor if you use this role manager. +role_manager: CassandraRoleManager + +# Validity period for roles cache (fetching granted roles can be an expensive +# operation depending on the role manager, CassandraRoleManager is one example) +# Granted roles are cached for authenticated sessions in AuthenticatedUser and +# after the period specified here, become eligible for (async) reload. +# Defaults to 2000, set to 0 to disable caching entirely. +# Will be disabled automatically for AllowAllAuthenticator. +roles_validity_in_ms: 2000 + +# Refresh interval for roles cache (if enabled). +# After this interval, cache entries become eligible for refresh. Upon next +# access, an async reload is scheduled and the old value returned until it +# completes. If roles_validity_in_ms is non-zero, then this must be +# also. +# Defaults to the same value as roles_validity_in_ms. +# roles_update_interval_in_ms: 2000 + +# Validity period for permissions cache (fetching permissions can be an +# expensive operation depending on the authorizer, CassandraAuthorizer is +# one example). Defaults to 2000, set to 0 to disable. +# Will be disabled automatically for AllowAllAuthorizer. +permissions_validity_in_ms: 2000 + +# Refresh interval for permissions cache (if enabled). +# After this interval, cache entries become eligible for refresh. Upon next +# access, an async reload is scheduled and the old value returned until it +# completes. If permissions_validity_in_ms is non-zero, then this must be +# also. +# Defaults to the same value as permissions_validity_in_ms. +# permissions_update_interval_in_ms: 2000 + +# Validity period for credentials cache. This cache is tightly coupled to +# the provided PasswordAuthenticator implementation of IAuthenticator. If +# another IAuthenticator implementation is configured, this cache will not +# be automatically used and so the following settings will have no effect. +# Please note, credentials are cached in their encrypted form, so while +# activating this cache may reduce the number of queries made to the +# underlying table, it may not bring a significant reduction in the +# latency of individual authentication attempts. +# Defaults to 2000, set to 0 to disable credentials caching. +credentials_validity_in_ms: 2000 + +# Refresh interval for credentials cache (if enabled). +# After this interval, cache entries become eligible for refresh. Upon next +# access, an async reload is scheduled and the old value returned until it +# completes. If credentials_validity_in_ms is non-zero, then this must be +# also. +# Defaults to the same value as credentials_validity_in_ms. +# credentials_update_interval_in_ms: 2000 + +# The partitioner is responsible for distributing groups of rows (by +# partition key) across nodes in the cluster. You should leave this +# alone for new clusters. The partitioner can NOT be changed without +# reloading all data, so when upgrading you should set this to the +# same partitioner you were already using. +# +# Besides Murmur3Partitioner, partitioners included for backwards +# compatibility include RandomPartitioner, ByteOrderedPartitioner, and +# OrderPreservingPartitioner. +# +partitioner: org.apache.cassandra.dht.Murmur3Partitioner + +# Directories where Cassandra should store data on disk. Cassandra +# will spread data evenly across them, subject to the granularity of +# the configured compaction strategy. +# If not set, the default directory is $CASSANDRA_HOME/data/data. +# data_file_directories: +# - /var/lib/cassandra/data + +# commit log. when running on magnetic HDD, this should be a +# separate spindle than the data directories. +# If not set, the default directory is $CASSANDRA_HOME/data/commitlog. +# commitlog_directory: /var/lib/cassandra/commitlog + +# Enable / disable CDC functionality on a per-node basis. This modifies the logic used +# for write path allocation rejection (standard: never reject. cdc: reject Mutation +# containing a CDC-enabled table if at space limit in cdc_raw_directory). +cdc_enabled: false + +# CommitLogSegments are moved to this directory on flush if cdc_enabled: true and the +# segment contains mutations for a CDC-enabled table. This should be placed on a +# separate spindle than the data directories. If not set, the default directory is +# $CASSANDRA_HOME/data/cdc_raw. +# cdc_raw_directory: /var/lib/cassandra/cdc_raw + +# Policy for data disk failures: +# +# die +# shut down gossip and client transports and kill the JVM for any fs errors or +# single-sstable errors, so the node can be replaced. +# +# stop_paranoid +# shut down gossip and client transports even for single-sstable errors, +# kill the JVM for errors during startup. +# +# stop +# shut down gossip and client transports, leaving the node effectively dead, but +# can still be inspected via JMX, kill the JVM for errors during startup. +# +# best_effort +# stop using the failed disk and respond to requests based on +# remaining available sstables. This means you WILL see obsolete +# data at CL.ONE! +# +# ignore +# ignore fatal errors and let requests fail, as in pre-1.2 Cassandra +disk_failure_policy: stop + +# Policy for commit disk failures: +# +# die +# shut down gossip and Thrift and kill the JVM, so the node can be replaced. +# +# stop +# shut down gossip and Thrift, leaving the node effectively dead, but +# can still be inspected via JMX. +# +# stop_commit +# shutdown the commit log, letting writes collect but +# continuing to service reads, as in pre-2.0.5 Cassandra +# +# ignore +# ignore fatal errors and let the batches fail +commit_failure_policy: stop + +# Maximum size of the native protocol prepared statement cache +# +# Valid values are either "auto" (omitting the value) or a value greater 0. +# +# Note that specifying a too large value will result in long running GCs and possbily +# out-of-memory errors. Keep the value at a small fraction of the heap. +# +# If you constantly see "prepared statements discarded in the last minute because +# cache limit reached" messages, the first step is to investigate the root cause +# of these messages and check whether prepared statements are used correctly - +# i.e. use bind markers for variable parts. +# +# Do only change the default value, if you really have more prepared statements than +# fit in the cache. In most cases it is not neccessary to change this value. +# Constantly re-preparing statements is a performance penalty. +# +# Default value ("auto") is 1/256th of the heap or 10MB, whichever is greater +prepared_statements_cache_size_mb: + +# Maximum size of the Thrift prepared statement cache +# +# If you do not use Thrift at all, it is safe to leave this value at "auto". +# +# See description of 'prepared_statements_cache_size_mb' above for more information. +# +# Default value ("auto") is 1/256th of the heap or 10MB, whichever is greater +thrift_prepared_statements_cache_size_mb: + +# Maximum size of the key cache in memory. +# +# Each key cache hit saves 1 seek and each row cache hit saves 2 seeks at the +# minimum, sometimes more. The key cache is fairly tiny for the amount of +# time it saves, so it's worthwhile to use it at large numbers. +# The row cache saves even more time, but must contain the entire row, +# so it is extremely space-intensive. It's best to only use the +# row cache if you have hot rows or static rows. +# +# NOTE: if you reduce the size, you may not get you hottest keys loaded on startup. +# +# Default value is empty to make it "auto" (min(5% of Heap (in MB), 100MB)). Set to 0 to disable key cache. +key_cache_size_in_mb: + +# Duration in seconds after which Cassandra should +# save the key cache. Caches are saved to saved_caches_directory as +# specified in this configuration file. +# +# Saved caches greatly improve cold-start speeds, and is relatively cheap in +# terms of I/O for the key cache. Row cache saving is much more expensive and +# has limited use. +# +# Default is 14400 or 4 hours. +key_cache_save_period: 14400 + +# Number of keys from the key cache to save +# Disabled by default, meaning all keys are going to be saved +# key_cache_keys_to_save: 100 + +# Row cache implementation class name. Available implementations: +# +# org.apache.cassandra.cache.OHCProvider +# Fully off-heap row cache implementation (default). +# +# org.apache.cassandra.cache.SerializingCacheProvider +# This is the row cache implementation availabile +# in previous releases of Cassandra. +# row_cache_class_name: org.apache.cassandra.cache.OHCProvider + +# Maximum size of the row cache in memory. +# Please note that OHC cache implementation requires some additional off-heap memory to manage +# the map structures and some in-flight memory during operations before/after cache entries can be +# accounted against the cache capacity. This overhead is usually small compared to the whole capacity. +# Do not specify more memory that the system can afford in the worst usual situation and leave some +# headroom for OS block level cache. Do never allow your system to swap. +# +# Default value is 0, to disable row caching. +row_cache_size_in_mb: 0 + +# Duration in seconds after which Cassandra should save the row cache. +# Caches are saved to saved_caches_directory as specified in this configuration file. +# +# Saved caches greatly improve cold-start speeds, and is relatively cheap in +# terms of I/O for the key cache. Row cache saving is much more expensive and +# has limited use. +# +# Default is 0 to disable saving the row cache. +row_cache_save_period: 0 + +# Number of keys from the row cache to save. +# Specify 0 (which is the default), meaning all keys are going to be saved +# row_cache_keys_to_save: 100 + +# Maximum size of the counter cache in memory. +# +# Counter cache helps to reduce counter locks' contention for hot counter cells. +# In case of RF = 1 a counter cache hit will cause Cassandra to skip the read before +# write entirely. With RF > 1 a counter cache hit will still help to reduce the duration +# of the lock hold, helping with hot counter cell updates, but will not allow skipping +# the read entirely. Only the local (clock, count) tuple of a counter cell is kept +# in memory, not the whole counter, so it's relatively cheap. +# +# NOTE: if you reduce the size, you may not get you hottest keys loaded on startup. +# +# Default value is empty to make it "auto" (min(2.5% of Heap (in MB), 50MB)). Set to 0 to disable counter cache. +# NOTE: if you perform counter deletes and rely on low gcgs, you should disable the counter cache. +counter_cache_size_in_mb: + +# Duration in seconds after which Cassandra should +# save the counter cache (keys only). Caches are saved to saved_caches_directory as +# specified in this configuration file. +# +# Default is 7200 or 2 hours. +counter_cache_save_period: 7200 + +# Number of keys from the counter cache to save +# Disabled by default, meaning all keys are going to be saved +# counter_cache_keys_to_save: 100 + +# saved caches +# If not set, the default directory is $CASSANDRA_HOME/data/saved_caches. +# saved_caches_directory: /var/lib/cassandra/saved_caches + +# commitlog_sync may be either "periodic" or "batch." +# +# When in batch mode, Cassandra won't ack writes until the commit log +# has been fsynced to disk. It will wait +# commitlog_sync_batch_window_in_ms milliseconds between fsyncs. +# This window should be kept short because the writer threads will +# be unable to do extra work while waiting. (You may need to increase +# concurrent_writes for the same reason.) +# +# commitlog_sync: batch +# commitlog_sync_batch_window_in_ms: 2 +# +# the other option is "periodic" where writes may be acked immediately +# and the CommitLog is simply synced every commitlog_sync_period_in_ms +# milliseconds. +commitlog_sync: periodic +commitlog_sync_period_in_ms: 10000 + +# The size of the individual commitlog file segments. A commitlog +# segment may be archived, deleted, or recycled once all the data +# in it (potentially from each columnfamily in the system) has been +# flushed to sstables. +# +# The default size is 32, which is almost always fine, but if you are +# archiving commitlog segments (see commitlog_archiving.properties), +# then you probably want a finer granularity of archiving; 8 or 16 MB +# is reasonable. +# Max mutation size is also configurable via max_mutation_size_in_kb setting in +# cassandra.yaml. The default is half the size commitlog_segment_size_in_mb * 1024. +# This should be positive and less than 2048. +# +# NOTE: If max_mutation_size_in_kb is set explicitly then commitlog_segment_size_in_mb must +# be set to at least twice the size of max_mutation_size_in_kb / 1024 +# +commitlog_segment_size_in_mb: 32 + +# Compression to apply to the commit log. If omitted, the commit log +# will be written uncompressed. LZ4, Snappy, and Deflate compressors +# are supported. +# commitlog_compression: +# - class_name: LZ4Compressor +# parameters: +# - + +# any class that implements the SeedProvider interface and has a +# constructor that takes a Map of parameters will do. +seed_provider: + # Addresses of hosts that are deemed contact points. + # Cassandra nodes use this list of hosts to find each other and learn + # the topology of the ring. You must change this if you are running + # multiple nodes! + - class_name: org.apache.cassandra.locator.SimpleSeedProvider + parameters: + # seeds is actually a comma-delimited list of addresses. + # Ex: ",," + - seeds: "127.0.0.1" + +# For workloads with more data than can fit in memory, Cassandra's +# bottleneck will be reads that need to fetch data from +# disk. "concurrent_reads" should be set to (16 * number_of_drives) in +# order to allow the operations to enqueue low enough in the stack +# that the OS and drives can reorder them. Same applies to +# "concurrent_counter_writes", since counter writes read the current +# values before incrementing and writing them back. +# +# On the other hand, since writes are almost never IO bound, the ideal +# number of "concurrent_writes" is dependent on the number of cores in +# your system; (8 * number_of_cores) is a good rule of thumb. +concurrent_reads: 32 +concurrent_writes: 32 +concurrent_counter_writes: 32 + +# For materialized view writes, as there is a read involved, so this should +# be limited by the less of concurrent reads or concurrent writes. +concurrent_materialized_view_writes: 32 + +# Maximum memory to use for sstable chunk cache and buffer pooling. +# 32MB of this are reserved for pooling buffers, the rest is used as an +# cache that holds uncompressed sstable chunks. +# Defaults to the smaller of 1/4 of heap or 512MB. This pool is allocated off-heap, +# so is in addition to the memory allocated for heap. The cache also has on-heap +# overhead which is roughly 128 bytes per chunk (i.e. 0.2% of the reserved size +# if the default 64k chunk size is used). +# Memory is only allocated when needed. +# file_cache_size_in_mb: 512 + +# Flag indicating whether to allocate on or off heap when the sstable buffer +# pool is exhausted, that is when it has exceeded the maximum memory +# file_cache_size_in_mb, beyond which it will not cache buffers but allocate on request. + +# buffer_pool_use_heap_if_exhausted: true + +# The strategy for optimizing disk read +# Possible values are: +# ssd (for solid state disks, the default) +# spinning (for spinning disks) +# disk_optimization_strategy: ssd + +# Total permitted memory to use for memtables. Cassandra will stop +# accepting writes when the limit is exceeded until a flush completes, +# and will trigger a flush based on memtable_cleanup_threshold +# If omitted, Cassandra will set both to 1/4 the size of the heap. +# memtable_heap_space_in_mb: 2048 +# memtable_offheap_space_in_mb: 2048 + +# memtable_cleanup_threshold is deprecated. The default calculation +# is the only reasonable choice. See the comments on memtable_flush_writers +# for more information. +# +# Ratio of occupied non-flushing memtable size to total permitted size +# that will trigger a flush of the largest memtable. Larger mct will +# mean larger flushes and hence less compaction, but also less concurrent +# flush activity which can make it difficult to keep your disks fed +# under heavy write load. +# +# memtable_cleanup_threshold defaults to 1 / (memtable_flush_writers + 1) +# memtable_cleanup_threshold: 0.11 + +# Specify the way Cassandra allocates and manages memtable memory. +# Options are: +# +# heap_buffers +# on heap nio buffers +# +# offheap_buffers +# off heap (direct) nio buffers +# +# offheap_objects +# off heap objects +memtable_allocation_type: heap_buffers + +# Total space to use for commit logs on disk. +# +# If space gets above this value, Cassandra will flush every dirty CF +# in the oldest segment and remove it. So a small total commitlog space +# will tend to cause more flush activity on less-active columnfamilies. +# +# The default value is the smaller of 8192, and 1/4 of the total space +# of the commitlog volume. +# +# commitlog_total_space_in_mb: 8192 + +# This sets the number of memtable flush writer threads per disk +# as well as the total number of memtables that can be flushed concurrently. +# These are generally a combination of compute and IO bound. +# +# Memtable flushing is more CPU efficient than memtable ingest and a single thread +# can keep up with the ingest rate of a whole server on a single fast disk +# until it temporarily becomes IO bound under contention typically with compaction. +# At that point you need multiple flush threads. At some point in the future +# it may become CPU bound all the time. +# +# You can tell if flushing is falling behind using the MemtablePool.BlockedOnAllocation +# metric which should be 0, but will be non-zero if threads are blocked waiting on flushing +# to free memory. +# +# memtable_flush_writers defaults to two for a single data directory. +# This means that two memtables can be flushed concurrently to the single data directory. +# If you have multiple data directories the default is one memtable flushing at a time +# but the flush will use a thread per data directory so you will get two or more writers. +# +# Two is generally enough to flush on a fast disk [array] mounted as a single data directory. +# Adding more flush writers will result in smaller more frequent flushes that introduce more +# compaction overhead. +# +# There is a direct tradeoff between number of memtables that can be flushed concurrently +# and flush size and frequency. More is not better you just need enough flush writers +# to never stall waiting for flushing to free memory. +# +#memtable_flush_writers: 2 + +# Total space to use for change-data-capture logs on disk. +# +# If space gets above this value, Cassandra will throw WriteTimeoutException +# on Mutations including tables with CDC enabled. A CDCCompactor is responsible +# for parsing the raw CDC logs and deleting them when parsing is completed. +# +# The default value is the min of 4096 mb and 1/8th of the total space +# of the drive where cdc_raw_directory resides. +# cdc_total_space_in_mb: 4096 + +# When we hit our cdc_raw limit and the CDCCompactor is either running behind +# or experiencing backpressure, we check at the following interval to see if any +# new space for cdc-tracked tables has been made available. Default to 250ms +# cdc_free_space_check_interval_ms: 250 + +# A fixed memory pool size in MB for for SSTable index summaries. If left +# empty, this will default to 5% of the heap size. If the memory usage of +# all index summaries exceeds this limit, SSTables with low read rates will +# shrink their index summaries in order to meet this limit. However, this +# is a best-effort process. In extreme conditions Cassandra may need to use +# more than this amount of memory. +index_summary_capacity_in_mb: + +# How frequently index summaries should be resampled. This is done +# periodically to redistribute memory from the fixed-size pool to sstables +# proportional their recent read rates. Setting to -1 will disable this +# process, leaving existing index summaries at their current sampling level. +index_summary_resize_interval_in_minutes: 60 + +# Whether to, when doing sequential writing, fsync() at intervals in +# order to force the operating system to flush the dirty +# buffers. Enable this to avoid sudden dirty buffer flushing from +# impacting read latencies. Almost always a good idea on SSDs; not +# necessarily on platters. +trickle_fsync: false +trickle_fsync_interval_in_kb: 10240 + +# TCP port, for commands and data +# For security reasons, you should not expose this port to the internet. Firewall it if needed. +storage_port: 7000 + +# SSL port, for encrypted communication. Unused unless enabled in +# encryption_options +# For security reasons, you should not expose this port to the internet. Firewall it if needed. +ssl_storage_port: 7001 + +# Address or interface to bind to and tell other Cassandra nodes to connect to. +# You _must_ change this if you want multiple nodes to be able to communicate! +# +# Set listen_address OR listen_interface, not both. +# +# Leaving it blank leaves it up to InetAddress.getLocalHost(). This +# will always do the Right Thing _if_ the node is properly configured +# (hostname, name resolution, etc), and the Right Thing is to use the +# address associated with the hostname (it might not be). +# +# Setting listen_address to 0.0.0.0 is always wrong. +# +listen_address: 127.0.0.1 + +# Set listen_address OR listen_interface, not both. Interfaces must correspond +# to a single address, IP aliasing is not supported. +# listen_interface: eth0 + +# If you choose to specify the interface by name and the interface has an ipv4 and an ipv6 address +# you can specify which should be chosen using listen_interface_prefer_ipv6. If false the first ipv4 +# address will be used. If true the first ipv6 address will be used. Defaults to false preferring +# ipv4. If there is only one address it will be selected regardless of ipv4/ipv6. +# listen_interface_prefer_ipv6: false + +# Address to broadcast to other Cassandra nodes +# Leaving this blank will set it to the same value as listen_address +# broadcast_address: 1.2.3.4 + +# When using multiple physical network interfaces, set this +# to true to listen on broadcast_address in addition to +# the listen_address, allowing nodes to communicate in both +# interfaces. +# Ignore this property if the network configuration automatically +# routes between the public and private networks such as EC2. +# listen_on_broadcast_address: false + +# Internode authentication backend, implementing IInternodeAuthenticator; +# used to allow/disallow connections from peer nodes. +# internode_authenticator: org.apache.cassandra.auth.AllowAllInternodeAuthenticator + +# Whether to start the native transport server. +# Please note that the address on which the native transport is bound is the +# same as the rpc_address. The port however is different and specified below. +start_native_transport: true +# port for the CQL native transport to listen for clients on +# For security reasons, you should not expose this port to the internet. Firewall it if needed. +native_transport_port: 9042 +# Enabling native transport encryption in client_encryption_options allows you to either use +# encryption for the standard port or to use a dedicated, additional port along with the unencrypted +# standard native_transport_port. +# Enabling client encryption and keeping native_transport_port_ssl disabled will use encryption +# for native_transport_port. Setting native_transport_port_ssl to a different value +# from native_transport_port will use encryption for native_transport_port_ssl while +# keeping native_transport_port unencrypted. +# native_transport_port_ssl: 9142 +# The maximum threads for handling requests when the native transport is used. +# This is similar to rpc_max_threads though the default differs slightly (and +# there is no native_transport_min_threads, idle threads will always be stopped +# after 30 seconds). +# native_transport_max_threads: 128 +# +# The maximum size of allowed frame. Frame (requests) larger than this will +# be rejected as invalid. The default is 256MB. If you're changing this parameter, +# you may want to adjust max_value_size_in_mb accordingly. This should be positive and less than 2048. +# native_transport_max_frame_size_in_mb: 256 + +# The maximum number of concurrent client connections. +# The default is -1, which means unlimited. +# native_transport_max_concurrent_connections: -1 + +# The maximum number of concurrent client connections per source ip. +# The default is -1, which means unlimited. +# native_transport_max_concurrent_connections_per_ip: -1 + +# Whether to start the thrift rpc server. +start_rpc: true + +# The address or interface to bind the Thrift RPC service and native transport +# server to. +# +# Set rpc_address OR rpc_interface, not both. +# +# Leaving rpc_address blank has the same effect as on listen_address +# (i.e. it will be based on the configured hostname of the node). +# +# Note that unlike listen_address, you can specify 0.0.0.0, but you must also +# set broadcast_rpc_address to a value other than 0.0.0.0. +# +# For security reasons, you should not expose this port to the internet. Firewall it if needed. +rpc_address: 0.0.0.0 + +# Set rpc_address OR rpc_interface, not both. Interfaces must correspond +# to a single address, IP aliasing is not supported. +# rpc_interface: eth1 + +# If you choose to specify the interface by name and the interface has an ipv4 and an ipv6 address +# you can specify which should be chosen using rpc_interface_prefer_ipv6. If false the first ipv4 +# address will be used. If true the first ipv6 address will be used. Defaults to false preferring +# ipv4. If there is only one address it will be selected regardless of ipv4/ipv6. +# rpc_interface_prefer_ipv6: false + +# port for Thrift to listen for clients on +rpc_port: 9160 + +# RPC address to broadcast to drivers and other Cassandra nodes. This cannot +# be set to 0.0.0.0. If left blank, this will be set to the value of +# rpc_address. If rpc_address is set to 0.0.0.0, broadcast_rpc_address must +# be set. +broadcast_rpc_address: 127.0.0.1 + +# enable or disable keepalive on rpc/native connections +rpc_keepalive: true + +# Cassandra provides two out-of-the-box options for the RPC Server: +# +# sync +# One thread per thrift connection. For a very large number of clients, memory +# will be your limiting factor. On a 64 bit JVM, 180KB is the minimum stack size +# per thread, and that will correspond to your use of virtual memory (but physical memory +# may be limited depending on use of stack space). +# +# hsha +# Stands for "half synchronous, half asynchronous." All thrift clients are handled +# asynchronously using a small number of threads that does not vary with the amount +# of thrift clients (and thus scales well to many clients). The rpc requests are still +# synchronous (one thread per active request). If hsha is selected then it is essential +# that rpc_max_threads is changed from the default value of unlimited. +# +# The default is sync because on Windows hsha is about 30% slower. On Linux, +# sync/hsha performance is about the same, with hsha of course using less memory. +# +# Alternatively, can provide your own RPC server by providing the fully-qualified class name +# of an o.a.c.t.TServerFactory that can create an instance of it. +rpc_server_type: sync + +# Uncomment rpc_min|max_thread to set request pool size limits. +# +# Regardless of your choice of RPC server (see above), the number of maximum requests in the +# RPC thread pool dictates how many concurrent requests are possible (but if you are using the sync +# RPC server, it also dictates the number of clients that can be connected at all). +# +# The default is unlimited and thus provides no protection against clients overwhelming the server. You are +# encouraged to set a maximum that makes sense for you in production, but do keep in mind that +# rpc_max_threads represents the maximum number of client requests this server may execute concurrently. +# +# rpc_min_threads: 16 +# rpc_max_threads: 2048 + +# uncomment to set socket buffer sizes on rpc connections +# rpc_send_buff_size_in_bytes: +# rpc_recv_buff_size_in_bytes: + +# Uncomment to set socket buffer size for internode communication +# Note that when setting this, the buffer size is limited by net.core.wmem_max +# and when not setting it it is defined by net.ipv4.tcp_wmem +# See also: +# /proc/sys/net/core/wmem_max +# /proc/sys/net/core/rmem_max +# /proc/sys/net/ipv4/tcp_wmem +# /proc/sys/net/ipv4/tcp_wmem +# and 'man tcp' +# internode_send_buff_size_in_bytes: + +# Uncomment to set socket buffer size for internode communication +# Note that when setting this, the buffer size is limited by net.core.wmem_max +# and when not setting it it is defined by net.ipv4.tcp_wmem +# internode_recv_buff_size_in_bytes: + +# Frame size for thrift (maximum message length). +thrift_framed_transport_size_in_mb: 15 + +# Set to true to have Cassandra create a hard link to each sstable +# flushed or streamed locally in a backups/ subdirectory of the +# keyspace data. Removing these links is the operator's +# responsibility. +incremental_backups: false + +# Whether or not to take a snapshot before each compaction. Be +# careful using this option, since Cassandra won't clean up the +# snapshots for you. Mostly useful if you're paranoid when there +# is a data format change. +snapshot_before_compaction: false + +# Whether or not a snapshot is taken of the data before keyspace truncation +# or dropping of column families. The STRONGLY advised default of true +# should be used to provide data safety. If you set this flag to false, you will +# lose data on truncation or drop. +auto_snapshot: true + +# Granularity of the collation index of rows within a partition. +# Increase if your rows are large, or if you have a very large +# number of rows per partition. The competing goals are these: +# +# - a smaller granularity means more index entries are generated +# and looking up rows withing the partition by collation column +# is faster +# - but, Cassandra will keep the collation index in memory for hot +# rows (as part of the key cache), so a larger granularity means +# you can cache more hot rows +column_index_size_in_kb: 64 + +# Per sstable indexed key cache entries (the collation index in memory +# mentioned above) exceeding this size will not be held on heap. +# This means that only partition information is held on heap and the +# index entries are read from disk. +# +# Note that this size refers to the size of the +# serialized index information and not the size of the partition. +column_index_cache_size_in_kb: 2 + +# Number of simultaneous compactions to allow, NOT including +# validation "compactions" for anti-entropy repair. Simultaneous +# compactions can help preserve read performance in a mixed read/write +# workload, by mitigating the tendency of small sstables to accumulate +# during a single long running compactions. The default is usually +# fine and if you experience problems with compaction running too +# slowly or too fast, you should look at +# compaction_throughput_mb_per_sec first. +# +# concurrent_compactors defaults to the smaller of (number of disks, +# number of cores), with a minimum of 2 and a maximum of 8. +# +# If your data directories are backed by SSD, you should increase this +# to the number of cores. +#concurrent_compactors: 1 + +# Throttles compaction to the given total throughput across the entire +# system. The faster you insert data, the faster you need to compact in +# order to keep the sstable count down, but in general, setting this to +# 16 to 32 times the rate you are inserting data is more than sufficient. +# Setting this to 0 disables throttling. Note that this account for all types +# of compaction, including validation compaction. +compaction_throughput_mb_per_sec: 16 + +# When compacting, the replacement sstable(s) can be opened before they +# are completely written, and used in place of the prior sstables for +# any range that has been written. This helps to smoothly transfer reads +# between the sstables, reducing page cache churn and keeping hot rows hot +sstable_preemptive_open_interval_in_mb: 50 + +# Throttles all outbound streaming file transfers on this node to the +# given total throughput in Mbps. This is necessary because Cassandra does +# mostly sequential IO when streaming data during bootstrap or repair, which +# can lead to saturating the network connection and degrading rpc performance. +# When unset, the default is 200 Mbps or 25 MB/s. +# stream_throughput_outbound_megabits_per_sec: 200 + +# Throttles all streaming file transfer between the datacenters, +# this setting allows users to throttle inter dc stream throughput in addition +# to throttling all network stream traffic as configured with +# stream_throughput_outbound_megabits_per_sec +# When unset, the default is 200 Mbps or 25 MB/s +# inter_dc_stream_throughput_outbound_megabits_per_sec: 200 + +# How long the coordinator should wait for read operations to complete +read_request_timeout_in_ms: 5000 +# How long the coordinator should wait for seq or index scans to complete +range_request_timeout_in_ms: 10000 +# How long the coordinator should wait for writes to complete +write_request_timeout_in_ms: 2000 +# How long the coordinator should wait for counter writes to complete +counter_write_request_timeout_in_ms: 5000 +# How long a coordinator should continue to retry a CAS operation +# that contends with other proposals for the same row +cas_contention_timeout_in_ms: 1000 +# How long the coordinator should wait for truncates to complete +# (This can be much longer, because unless auto_snapshot is disabled +# we need to flush first so we can snapshot before removing the data.) +truncate_request_timeout_in_ms: 60000 +# The default timeout for other, miscellaneous operations +request_timeout_in_ms: 10000 + +# How long before a node logs slow queries. Select queries that take longer than +# this timeout to execute, will generate an aggregated log message, so that slow queries +# can be identified. Set this value to zero to disable slow query logging. +slow_query_log_timeout_in_ms: 500 + +# Enable operation timeout information exchange between nodes to accurately +# measure request timeouts. If disabled, replicas will assume that requests +# were forwarded to them instantly by the coordinator, which means that +# under overload conditions we will waste that much extra time processing +# already-timed-out requests. +# +# Warning: before enabling this property make sure to ntp is installed +# and the times are synchronized between the nodes. +cross_node_timeout: false + +# Set keep-alive period for streaming +# This node will send a keep-alive message periodically with this period. +# If the node does not receive a keep-alive message from the peer for +# 2 keep-alive cycles the stream session times out and fail +# Default value is 300s (5 minutes), which means stalled stream +# times out in 10 minutes by default +# streaming_keep_alive_period_in_secs: 300 + +# phi value that must be reached for a host to be marked down. +# most users should never need to adjust this. +# phi_convict_threshold: 8 + +# endpoint_snitch -- Set this to a class that implements +# IEndpointSnitch. The snitch has two functions: +# +# - it teaches Cassandra enough about your network topology to route +# requests efficiently +# - it allows Cassandra to spread replicas around your cluster to avoid +# correlated failures. It does this by grouping machines into +# "datacenters" and "racks." Cassandra will do its best not to have +# more than one replica on the same "rack" (which may not actually +# be a physical location) +# +# CASSANDRA WILL NOT ALLOW YOU TO SWITCH TO AN INCOMPATIBLE SNITCH +# ONCE DATA IS INSERTED INTO THE CLUSTER. This would cause data loss. +# This means that if you start with the default SimpleSnitch, which +# locates every node on "rack1" in "datacenter1", your only options +# if you need to add another datacenter are GossipingPropertyFileSnitch +# (and the older PFS). From there, if you want to migrate to an +# incompatible snitch like Ec2Snitch you can do it by adding new nodes +# under Ec2Snitch (which will locate them in a new "datacenter") and +# decommissioning the old ones. +# +# Out of the box, Cassandra provides: +# +# SimpleSnitch: +# Treats Strategy order as proximity. This can improve cache +# locality when disabling read repair. Only appropriate for +# single-datacenter deployments. +# +# GossipingPropertyFileSnitch +# This should be your go-to snitch for production use. The rack +# and datacenter for the local node are defined in +# cassandra-rackdc.properties and propagated to other nodes via +# gossip. If cassandra-topology.properties exists, it is used as a +# fallback, allowing migration from the PropertyFileSnitch. +# +# PropertyFileSnitch: +# Proximity is determined by rack and data center, which are +# explicitly configured in cassandra-topology.properties. +# +# Ec2Snitch: +# Appropriate for EC2 deployments in a single Region. Loads Region +# and Availability Zone information from the EC2 API. The Region is +# treated as the datacenter, and the Availability Zone as the rack. +# Only private IPs are used, so this will not work across multiple +# Regions. +# +# Ec2MultiRegionSnitch: +# Uses public IPs as broadcast_address to allow cross-region +# connectivity. (Thus, you should set seed addresses to the public +# IP as well.) You will need to open the storage_port or +# ssl_storage_port on the public IP firewall. (For intra-Region +# traffic, Cassandra will switch to the private IP after +# establishing a connection.) +# +# RackInferringSnitch: +# Proximity is determined by rack and data center, which are +# assumed to correspond to the 3rd and 2nd octet of each node's IP +# address, respectively. Unless this happens to match your +# deployment conventions, this is best used as an example of +# writing a custom Snitch class and is provided in that spirit. +# +# You can use a custom Snitch by setting this to the full class name +# of the snitch, which will be assumed to be on your classpath. +endpoint_snitch: SimpleSnitch + +# controls how often to perform the more expensive part of host score +# calculation +dynamic_snitch_update_interval_in_ms: 100 +# controls how often to reset all host scores, allowing a bad host to +# possibly recover +dynamic_snitch_reset_interval_in_ms: 600000 +# if set greater than zero and read_repair_chance is < 1.0, this will allow +# 'pinning' of replicas to hosts in order to increase cache capacity. +# The badness threshold will control how much worse the pinned host has to be +# before the dynamic snitch will prefer other replicas over it. This is +# expressed as a double which represents a percentage. Thus, a value of +# 0.2 means Cassandra would continue to prefer the static snitch values +# until the pinned host was 20% worse than the fastest. +dynamic_snitch_badness_threshold: 0.1 + +# request_scheduler -- Set this to a class that implements +# RequestScheduler, which will schedule incoming client requests +# according to the specific policy. This is useful for multi-tenancy +# with a single Cassandra cluster. +# NOTE: This is specifically for requests from the client and does +# not affect inter node communication. +# org.apache.cassandra.scheduler.NoScheduler - No scheduling takes place +# org.apache.cassandra.scheduler.RoundRobinScheduler - Round robin of +# client requests to a node with a separate queue for each +# request_scheduler_id. The scheduler is further customized by +# request_scheduler_options as described below. +request_scheduler: org.apache.cassandra.scheduler.NoScheduler + +# Scheduler Options vary based on the type of scheduler +# +# NoScheduler +# Has no options +# +# RoundRobin +# throttle_limit +# The throttle_limit is the number of in-flight +# requests per client. Requests beyond +# that limit are queued up until +# running requests can complete. +# The value of 80 here is twice the number of +# concurrent_reads + concurrent_writes. +# default_weight +# default_weight is optional and allows for +# overriding the default which is 1. +# weights +# Weights are optional and will default to 1 or the +# overridden default_weight. The weight translates into how +# many requests are handled during each turn of the +# RoundRobin, based on the scheduler id. +# +# request_scheduler_options: +# throttle_limit: 80 +# default_weight: 5 +# weights: +# Keyspace1: 1 +# Keyspace2: 5 + +# request_scheduler_id -- An identifier based on which to perform +# the request scheduling. Currently the only valid option is keyspace. +# request_scheduler_id: keyspace + +# Enable or disable inter-node encryption +# JVM defaults for supported SSL socket protocols and cipher suites can +# be replaced using custom encryption options. This is not recommended +# unless you have policies in place that dictate certain settings, or +# need to disable vulnerable ciphers or protocols in case the JVM cannot +# be updated. +# FIPS compliant settings can be configured at JVM level and should not +# involve changing encryption settings here: +# https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/FIPS.html +# *NOTE* No custom encryption options are enabled at the moment +# The available internode options are : all, none, dc, rack +# +# If set to dc cassandra will encrypt the traffic between the DCs +# If set to rack cassandra will encrypt the traffic between the racks +# +# The passwords used in these options must match the passwords used when generating +# the keystore and truststore. For instructions on generating these files, see: +# http://download.oracle.com/javase/6/docs/technotes/guides/security/jsse/JSSERefGuide.html#CreateKeystore +# +server_encryption_options: + internode_encryption: none + keystore: conf/.keystore + keystore_password: cassandra + truststore: conf/.truststore + truststore_password: cassandra + # More advanced defaults below: + # protocol: TLS + # algorithm: SunX509 + # store_type: JKS + # cipher_suites: [TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_DHE_RSA_WITH_AES_128_CBC_SHA,TLS_DHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA] + # require_client_auth: false + # require_endpoint_verification: false + +# enable or disable client/server encryption. +client_encryption_options: + enabled: false + # If enabled and optional is set to true encrypted and unencrypted connections are handled. + optional: false + keystore: conf/.keystore + keystore_password: cassandra + # require_client_auth: false + # Set trustore and truststore_password if require_client_auth is true + # truststore: conf/.truststore + # truststore_password: cassandra + # More advanced defaults below: + # protocol: TLS + # algorithm: SunX509 + # store_type: JKS + # cipher_suites: [TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_DHE_RSA_WITH_AES_128_CBC_SHA,TLS_DHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA] + +# internode_compression controls whether traffic between nodes is +# compressed. +# Can be: +# +# all +# all traffic is compressed +# +# dc +# traffic between different datacenters is compressed +# +# none +# nothing is compressed. +internode_compression: dc + +# Enable or disable tcp_nodelay for inter-dc communication. +# Disabling it will result in larger (but fewer) network packets being sent, +# reducing overhead from the TCP protocol itself, at the cost of increasing +# latency if you block for cross-datacenter responses. +inter_dc_tcp_nodelay: false + +# TTL for different trace types used during logging of the repair process. +tracetype_query_ttl: 86400 +tracetype_repair_ttl: 604800 + +# By default, Cassandra logs GC Pauses greater than 200 ms at INFO level +# This threshold can be adjusted to minimize logging if necessary +# gc_log_threshold_in_ms: 200 + +# If unset, all GC Pauses greater than gc_log_threshold_in_ms will log at +# INFO level +# UDFs (user defined functions) are disabled by default. +# As of Cassandra 3.0 there is a sandbox in place that should prevent execution of evil code. +enable_user_defined_functions: false + +# Enables scripted UDFs (JavaScript UDFs). +# Java UDFs are always enabled, if enable_user_defined_functions is true. +# Enable this option to be able to use UDFs with "language javascript" or any custom JSR-223 provider. +# This option has no effect, if enable_user_defined_functions is false. +enable_scripted_user_defined_functions: false + +# Enables materialized view creation on this node. +# Materialized views are considered experimental and are not recommended for production use. +enable_materialized_views: true + +# The default Windows kernel timer and scheduling resolution is 15.6ms for power conservation. +# Lowering this value on Windows can provide much tighter latency and better throughput, however +# some virtualized environments may see a negative performance impact from changing this setting +# below their system default. The sysinternals 'clockres' tool can confirm your system's default +# setting. +windows_timer_interval: 1 + + +# Enables encrypting data at-rest (on disk). Different key providers can be plugged in, but the default reads from +# a JCE-style keystore. A single keystore can hold multiple keys, but the one referenced by +# the "key_alias" is the only key that will be used for encrypt opertaions; previously used keys +# can still (and should!) be in the keystore and will be used on decrypt operations +# (to handle the case of key rotation). +# +# It is strongly recommended to download and install Java Cryptography Extension (JCE) +# Unlimited Strength Jurisdiction Policy Files for your version of the JDK. +# (current link: http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html) +# +# Currently, only the following file types are supported for transparent data encryption, although +# more are coming in future cassandra releases: commitlog, hints +transparent_data_encryption_options: + enabled: false + chunk_length_kb: 64 + cipher: AES/CBC/PKCS5Padding + key_alias: testing:1 + # CBC IV length for AES needs to be 16 bytes (which is also the default size) + # iv_length: 16 + key_provider: + - class_name: org.apache.cassandra.security.JKSKeyProvider + parameters: + - keystore: conf/.keystore + keystore_password: cassandra + store_type: JCEKS + key_password: cassandra + + +##################### +# SAFETY THRESHOLDS # +##################### + +# When executing a scan, within or across a partition, we need to keep the +# tombstones seen in memory so we can return them to the coordinator, which +# will use them to make sure other replicas also know about the deleted rows. +# With workloads that generate a lot of tombstones, this can cause performance +# problems and even exaust the server heap. +# (http://www.datastax.com/dev/blog/cassandra-anti-patterns-queues-and-queue-like-datasets) +# Adjust the thresholds here if you understand the dangers and want to +# scan more tombstones anyway. These thresholds may also be adjusted at runtime +# using the StorageService mbean. +tombstone_warn_threshold: 1000 +tombstone_failure_threshold: 100000 + +# Log WARN on any multiple-partition batch size exceeding this value. 5kb per batch by default. +# Caution should be taken on increasing the size of this threshold as it can lead to node instability. +batch_size_warn_threshold_in_kb: 5 + +# Fail any multiple-partition batch exceeding this value. 50kb (10x warn threshold) by default. +batch_size_fail_threshold_in_kb: 50 + +# Log WARN on any batches not of type LOGGED than span across more partitions than this limit +unlogged_batch_across_partitions_warn_threshold: 10 + +# Log a warning when compacting partitions larger than this value +compaction_large_partition_warning_threshold_mb: 100 + +# GC Pauses greater than gc_warn_threshold_in_ms will be logged at WARN level +# Adjust the threshold based on your application throughput requirement +# By default, Cassandra logs GC Pauses greater than 200 ms at INFO level +gc_warn_threshold_in_ms: 1000 + +# Maximum size of any value in SSTables. Safety measure to detect SSTable corruption +# early. Any value size larger than this threshold will result into marking an SSTable +# as corrupted. This should be positive and less than 2048. +# max_value_size_in_mb: 256 + +# Back-pressure settings # +# If enabled, the coordinator will apply the back-pressure strategy specified below to each mutation +# sent to replicas, with the aim of reducing pressure on overloaded replicas. +back_pressure_enabled: false +# The back-pressure strategy applied. +# The default implementation, RateBasedBackPressure, takes three arguments: +# high ratio, factor, and flow type, and uses the ratio between incoming mutation responses and outgoing mutation requests. +# If below high ratio, outgoing mutations are rate limited according to the incoming rate decreased by the given factor; +# if above high ratio, the rate limiting is increased by the given factor; +# such factor is usually best configured between 1 and 10, use larger values for a faster recovery +# at the expense of potentially more dropped mutations; +# the rate limiting is applied according to the flow type: if FAST, it's rate limited at the speed of the fastest replica, +# if SLOW at the speed of the slowest one. +# New strategies can be added. Implementors need to implement org.apache.cassandra.net.BackpressureStrategy and +# provide a public constructor accepting a Map. +back_pressure_strategy: + - class_name: org.apache.cassandra.net.RateBasedBackPressure + parameters: + - high_ratio: 0.90 + factor: 5 + flow: FAST + +# Coalescing Strategies # +# Coalescing multiples messages turns out to significantly boost message processing throughput (think doubling or more). +# On bare metal, the floor for packet processing throughput is high enough that many applications won't notice, but in +# virtualized environments, the point at which an application can be bound by network packet processing can be +# surprisingly low compared to the throughput of task processing that is possible inside a VM. It's not that bare metal +# doesn't benefit from coalescing messages, it's that the number of packets a bare metal network interface can process +# is sufficient for many applications such that no load starvation is experienced even without coalescing. +# There are other benefits to coalescing network messages that are harder to isolate with a simple metric like messages +# per second. By coalescing multiple tasks together, a network thread can process multiple messages for the cost of one +# trip to read from a socket, and all the task submission work can be done at the same time reducing context switching +# and increasing cache friendliness of network message processing. +# See CASSANDRA-8692 for details. + +# Strategy to use for coalescing messages in OutboundTcpConnection. +# Can be fixed, movingaverage, timehorizon, disabled (default). +# You can also specify a subclass of CoalescingStrategies.CoalescingStrategy by name. +# otc_coalescing_strategy: DISABLED + +# How many microseconds to wait for coalescing. For fixed strategy this is the amount of time after the first +# message is received before it will be sent with any accompanying messages. For moving average this is the +# maximum amount of time that will be waited as well as the interval at which messages must arrive on average +# for coalescing to be enabled. +# otc_coalescing_window_us: 200 + +# Do not try to coalesce messages if we already got that many messages. This should be more than 2 and less than 128. +# otc_coalescing_enough_coalesced_messages: 8 + +# How many milliseconds to wait between two expiration runs on the backlog (queue) of the OutboundTcpConnection. +# Expiration is done if messages are piling up in the backlog. Droppable messages are expired to free the memory +# taken by expired messages. The interval should be between 0 and 1000, and in most installations the default value +# will be appropriate. A smaller value could potentially expire messages slightly sooner at the expense of more CPU +# time and queue contention while iterating the backlog of messages. +# An interval of 0 disables any wait time, which is the behavior of former Cassandra versions. +# +# otc_backlog_expiration_interval_ms: 200 diff --git a/.ci/scripts/windows/install-cassandra.ps1 b/.ci/scripts/windows/install-cassandra.ps1 deleted file mode 100755 index a2cc1f615e..0000000000 --- a/.ci/scripts/windows/install-cassandra.ps1 +++ /dev/null @@ -1,23 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan -$cassandraVersion = "3.11.3" -$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" -$extractRoot = "$env:SYSTEMDRIVE" -$tgzPath = "$extractRoot\cassandra.tar.gz" -$tarPath = "$extractRoot\cassandra.tar" -$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" - -Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) - -Write-Host "Extracting Cassandra..." -7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null -7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null -del $tgzPath - -Write-Host "Starting Cassandra..." -Start-Process $cassandra -PassThru - -Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/Jenkinsfile b/Jenkinsfile index 94ca575c41..ddf977f8a0 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -88,7 +88,11 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - powershell label: 'Install cassandra', script: ".\\.ci\\scripts\\windows\\install-cassandra.ps1" + bat label: 'Run cassandra', script: ''' + cd .ci/scripts/windows/docker/cassandra + docker build --tag=cassandra . + docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra + ''' bat label: 'Run redis', script: ''' cd .ci/scripts/windows/docker/redis docker build --tag=redis . @@ -109,10 +113,9 @@ def generateStepForWindows(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - bat label: 'Gather docker logs', returnStatus: true, script: ''' - docker logs redis - docker logs elasticsearch - ''' + bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' + bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' + bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' } } } From 46c13d5d65a343ce320c7c9529401d99c82f327d Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 17:12:12 +0100 Subject: [PATCH 053/117] ci(jenkins): mongodb with docker --- .ci/scripts/windows/docker/mongodb/Dockerfile | 21 +++++++++++++++++++ .ci/scripts/windows/docker/mongodb/mongod.cfg | 21 +++++++++++++++++++ Jenkinsfile | 6 ++++++ 3 files changed, 48 insertions(+) create mode 100644 .ci/scripts/windows/docker/mongodb/Dockerfile create mode 100644 .ci/scripts/windows/docker/mongodb/mongod.cfg diff --git a/.ci/scripts/windows/docker/mongodb/Dockerfile b/.ci/scripts/windows/docker/mongodb/Dockerfile new file mode 100644 index 0000000000..559017e576 --- /dev/null +++ b/.ci/scripts/windows/docker/mongodb/Dockerfile @@ -0,0 +1,21 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) + +ARG VERSION="4.2.0" +ENV MONGODB_HOME="C:\ProgramData\MongoDB\log" +WORKDIR $MONGODB_HOME +RUN choco install mongodb --version=${env:VERSION} --no-progress -y + +EXPOSE 27017 + +# Override confgs to enable the remote access +ENV MONGODB_BIN="C:\Program Files\MongoDB\Server\4.2\bin" +WORKDIR $MONGODB_BIN +COPY mongod.cfg . +WORKDIR $MONGODB_HOME + +# Keep running the container with the event logs in the stdout. +CMD ["powershell", "Get-Content", "mongod.log", "-Wait"] diff --git a/.ci/scripts/windows/docker/mongodb/mongod.cfg b/.ci/scripts/windows/docker/mongodb/mongod.cfg new file mode 100644 index 0000000000..35402f0a13 --- /dev/null +++ b/.ci/scripts/windows/docker/mongodb/mongod.cfg @@ -0,0 +1,21 @@ +# mongod.conf + +# for documentation of all options, see: +# http://docs.mongodb.org/manual/reference/configuration-options/ + +# Where and how to store data. +storage: + dbPath: C:\ProgramData\MongoDB\data\db + journal: + enabled: true + +# where to write logging data. +systemLog: + destination: file + logAppend: true + path: C:\ProgramData\MongoDB\log\mongod.log + +# network interfaces +net: + port: 27017 + bindIp: 0.0.0.0 diff --git a/Jenkinsfile b/Jenkinsfile index ddf977f8a0..953a33bb6d 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -103,6 +103,11 @@ def generateStepForWindows(Map params = [:]){ docker build --tag=elasticsearch . docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch ''' + bat label: 'Run mongodb', script: ''' + cd .ci/scripts/windows/docker/mongodb + docker build --tag=mongodb . + docker run -d -p 27017:27017 --name mongodb mongodb + ''' bat label: 'Tool versions', script: ''' npm --version node --version @@ -115,6 +120,7 @@ def generateStepForWindows(Map params = [:]){ } finally { bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' + bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' } } From 750eaad466836ab7ddc38782f5020d3e12ad8d03 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 18:38:46 +0100 Subject: [PATCH 054/117] ci(jenkins): docker debug --- Jenkinsfile | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index 953a33bb6d..1a7c84b139 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -92,21 +92,25 @@ def generateStepForWindows(Map params = [:]){ cd .ci/scripts/windows/docker/cassandra docker build --tag=cassandra . docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra + docker ps ''' bat label: 'Run redis', script: ''' cd .ci/scripts/windows/docker/redis docker build --tag=redis . docker run -d -p 6379:6379 --name redis redis + docker ps ''' bat label: 'Run elasticsearch', script: ''' cd .ci/scripts/windows/docker/elasticsearch docker build --tag=elasticsearch . docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch + docker ps ''' bat label: 'Run mongodb', script: ''' cd .ci/scripts/windows/docker/mongodb docker build --tag=mongodb . docker run -d -p 27017:27017 --name mongodb mongodb + docker ps ''' bat label: 'Tool versions', script: ''' npm --version @@ -118,6 +122,7 @@ def generateStepForWindows(Map params = [:]){ } catch(e){ error(e.toString()) } finally { + bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' From 9eb28c8d3b77c54afe51e7cf7b8c36117385b1ba Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 19:02:19 +0100 Subject: [PATCH 055/117] ci(jenkins): postgres docker --- .../windows/docker/postgres/Dockerfile | 17 + .../windows/docker/postgres/postgresql.conf | 658 ++++++++++++++++++ Jenkinsfile | 7 + 3 files changed, 682 insertions(+) create mode 100644 .ci/scripts/windows/docker/postgres/Dockerfile create mode 100644 .ci/scripts/windows/docker/postgres/postgresql.conf diff --git a/.ci/scripts/windows/docker/postgres/Dockerfile b/.ci/scripts/windows/docker/postgres/Dockerfile new file mode 100644 index 0000000000..088aa20076 --- /dev/null +++ b/.ci/scripts/windows/docker/postgres/Dockerfile @@ -0,0 +1,17 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) + +ARG VERSION="10.6.0.0" +ENV POSTGRES_HOME="C:\Program Files\PostgreSQL\10\data" +WORKDIR $POSTGRES_HOME +RUN choco install postgresql10 --version=${env:VERSION} --params '/Password:Password12!' --no-progress -y + +EXPOSE 5432 + +COPY postgresql.conf . + +# Keep running the container with the event logs in the stdout. +CMD ["powershell", "Get-Content", "log/postgresql.log", "-Wait"] diff --git a/.ci/scripts/windows/docker/postgres/postgresql.conf b/.ci/scripts/windows/docker/postgres/postgresql.conf new file mode 100644 index 0000000000..303774bf17 --- /dev/null +++ b/.ci/scripts/windows/docker/postgres/postgresql.conf @@ -0,0 +1,658 @@ +# ----------------------------- +# PostgreSQL configuration file +# ----------------------------- +# +# This file consists of lines of the form: +# +# name = value +# +# (The "=" is optional.) Whitespace may be used. Comments are introduced with +# "#" anywhere on a line. The complete list of parameter names and allowed +# values can be found in the PostgreSQL documentation. +# +# The commented-out settings shown in this file represent the default values. +# Re-commenting a setting is NOT sufficient to revert it to the default value; +# you need to reload the server. +# +# This file is read on server startup and when the server receives a SIGHUP +# signal. If you edit the file on a running system, you have to SIGHUP the +# server for the changes to take effect, run "pg_ctl reload", or execute +# "SELECT pg_reload_conf()". Some parameters, which are marked below, +# require a server shutdown and restart to take effect. +# +# Any parameter can also be given as a command-line option to the server, e.g., +# "postgres -c log_connections=on". Some parameters can be changed at run time +# with the "SET" SQL command. +# +# Memory units: kB = kilobytes Time units: ms = milliseconds +# MB = megabytes s = seconds +# GB = gigabytes min = minutes +# TB = terabytes h = hours +# d = days + + +#------------------------------------------------------------------------------ +# FILE LOCATIONS +#------------------------------------------------------------------------------ + +# The default values of these variables are driven from the -D command-line +# option or PGDATA environment variable, represented here as ConfigDir. + +#data_directory = 'ConfigDir' # use data in another directory + # (change requires restart) +#hba_file = 'ConfigDir/pg_hba.conf' # host-based authentication file + # (change requires restart) +#ident_file = 'ConfigDir/pg_ident.conf' # ident configuration file + # (change requires restart) + +# If external_pid_file is not explicitly set, no extra PID file is written. +#external_pid_file = '' # write an extra PID file + # (change requires restart) + + +#------------------------------------------------------------------------------ +# CONNECTIONS AND AUTHENTICATION +#------------------------------------------------------------------------------ + +# - Connection Settings - + +listen_addresses = '*' # what IP address(es) to listen on; + # comma-separated list of addresses; + # defaults to 'localhost'; use '*' for all + # (change requires restart) +port = 5432 # (change requires restart) +max_connections = 100 # (change requires restart) +#superuser_reserved_connections = 3 # (change requires restart) +#unix_socket_directories = '' # comma-separated list of directories + # (change requires restart) +#unix_socket_group = '' # (change requires restart) +#unix_socket_permissions = 0777 # begin with 0 to use octal notation + # (change requires restart) +#bonjour = off # advertise server via Bonjour + # (change requires restart) +#bonjour_name = '' # defaults to the computer name + # (change requires restart) + +# - Security and Authentication - + +#authentication_timeout = 1min # 1s-600s +#ssl = off +#ssl_ciphers = 'HIGH:MEDIUM:+3DES:!aNULL' # allowed SSL ciphers +#ssl_prefer_server_ciphers = on +#ssl_ecdh_curve = 'prime256v1' +#ssl_dh_params_file = '' +#ssl_cert_file = 'server.crt' +#ssl_key_file = 'server.key' +#ssl_ca_file = '' +#ssl_crl_file = '' +#password_encryption = md5 # md5 or scram-sha-256 +#db_user_namespace = off +#row_security = on + +# GSSAPI using Kerberos +#krb_server_keyfile = '' +#krb_caseins_users = off + +# - TCP Keepalives - +# see "man 7 tcp" for details + +#tcp_keepalives_idle = 0 # TCP_KEEPIDLE, in seconds; + # 0 selects the system default +#tcp_keepalives_interval = 0 # TCP_KEEPINTVL, in seconds; + # 0 selects the system default +#tcp_keepalives_count = 0 # TCP_KEEPCNT; + # 0 selects the system default + + +#------------------------------------------------------------------------------ +# RESOURCE USAGE (except WAL) +#------------------------------------------------------------------------------ + +# - Memory - + +shared_buffers = 128MB # min 128kB + # (change requires restart) +#huge_pages = try # on, off, or try + # (change requires restart) +#temp_buffers = 8MB # min 800kB +#max_prepared_transactions = 0 # zero disables the feature + # (change requires restart) +# Caution: it is not advisable to set max_prepared_transactions nonzero unless +# you actively intend to use prepared transactions. +#work_mem = 4MB # min 64kB +#maintenance_work_mem = 64MB # min 1MB +#replacement_sort_tuples = 150000 # limits use of replacement selection sort +#autovacuum_work_mem = -1 # min 1MB, or -1 to use maintenance_work_mem +#max_stack_depth = 2MB # min 100kB +dynamic_shared_memory_type = windows # the default is the first option + # supported by the operating system: + # posix + # sysv + # windows + # mmap + # use none to disable dynamic shared memory + # (change requires restart) + +# - Disk - + +#temp_file_limit = -1 # limits per-process temp file space + # in kB, or -1 for no limit + +# - Kernel Resource Usage - + +#max_files_per_process = 1000 # min 25 + # (change requires restart) +#shared_preload_libraries = '' # (change requires restart) + +# - Cost-Based Vacuum Delay - + +#vacuum_cost_delay = 0 # 0-100 milliseconds +#vacuum_cost_page_hit = 1 # 0-10000 credits +#vacuum_cost_page_miss = 10 # 0-10000 credits +#vacuum_cost_page_dirty = 20 # 0-10000 credits +#vacuum_cost_limit = 200 # 1-10000 credits + +# - Background Writer - + +#bgwriter_delay = 200ms # 10-10000ms between rounds +#bgwriter_lru_maxpages = 100 # 0-1000 max buffers written/round +#bgwriter_lru_multiplier = 2.0 # 0-10.0 multiplier on buffers scanned/round +#bgwriter_flush_after = 0 # measured in pages, 0 disables + +# - Asynchronous Behavior - + +#effective_io_concurrency = 0 # 1-1000; 0 disables prefetching +#max_worker_processes = 8 # (change requires restart) +#max_parallel_workers_per_gather = 2 # taken from max_parallel_workers +#max_parallel_workers = 8 # maximum number of max_worker_processes that + # can be used in parallel queries +#old_snapshot_threshold = -1 # 1min-60d; -1 disables; 0 is immediate + # (change requires restart) +#backend_flush_after = 0 # measured in pages, 0 disables + + +#------------------------------------------------------------------------------ +# WRITE AHEAD LOG +#------------------------------------------------------------------------------ + +# - Settings - + +#wal_level = replica # minimal, replica, or logical + # (change requires restart) +#fsync = on # flush data to disk for crash safety + # (turning this off can cause + # unrecoverable data corruption) +#synchronous_commit = on # synchronization level; + # off, local, remote_write, remote_apply, or on +#wal_sync_method = fsync # the default is the first option + # supported by the operating system: + # open_datasync + # fdatasync (default on Linux) + # fsync + # fsync_writethrough + # open_sync +#full_page_writes = on # recover from partial page writes +#wal_compression = off # enable compression of full-page writes +#wal_log_hints = off # also do full page writes of non-critical updates + # (change requires restart) +#wal_buffers = -1 # min 32kB, -1 sets based on shared_buffers + # (change requires restart) +#wal_writer_delay = 200ms # 1-10000 milliseconds +#wal_writer_flush_after = 1MB # measured in pages, 0 disables + +#commit_delay = 0 # range 0-100000, in microseconds +#commit_siblings = 5 # range 1-1000 + +# - Checkpoints - + +#checkpoint_timeout = 5min # range 30s-1d +#max_wal_size = 1GB +#min_wal_size = 80MB +#checkpoint_completion_target = 0.5 # checkpoint target duration, 0.0 - 1.0 +#checkpoint_flush_after = 0 # measured in pages, 0 disables +#checkpoint_warning = 30s # 0 disables + +# - Archiving - + +#archive_mode = off # enables archiving; off, on, or always + # (change requires restart) +#archive_command = '' # command to use to archive a logfile segment + # placeholders: %p = path of file to archive + # %f = file name only + # e.g. 'test ! -f /mnt/server/archivedir/%f && cp %p /mnt/server/archivedir/%f' +#archive_timeout = 0 # force a logfile segment switch after this + # number of seconds; 0 disables + + +#------------------------------------------------------------------------------ +# REPLICATION +#------------------------------------------------------------------------------ + +# - Sending Server(s) - + +# Set these on the master and on any standby that will send replication data. + +#max_wal_senders = 10 # max number of walsender processes + # (change requires restart) +#wal_keep_segments = 0 # in logfile segments, 16MB each; 0 disables +#wal_sender_timeout = 60s # in milliseconds; 0 disables + +#max_replication_slots = 10 # max number of replication slots + # (change requires restart) +#track_commit_timestamp = off # collect timestamp of transaction commit + # (change requires restart) + +# - Master Server - + +# These settings are ignored on a standby server. + +#synchronous_standby_names = '' # standby servers that provide sync rep + # method to choose sync standbys, number of sync standbys, + # and comma-separated list of application_name + # from standby(s); '*' = all +#vacuum_defer_cleanup_age = 0 # number of xacts by which cleanup is delayed + +# - Standby Servers - + +# These settings are ignored on a master server. + +#hot_standby = on # "off" disallows queries during recovery + # (change requires restart) +#max_standby_archive_delay = 30s # max delay before canceling queries + # when reading WAL from archive; + # -1 allows indefinite delay +#max_standby_streaming_delay = 30s # max delay before canceling queries + # when reading streaming WAL; + # -1 allows indefinite delay +#wal_receiver_status_interval = 10s # send replies at least this often + # 0 disables +#hot_standby_feedback = off # send info from standby to prevent + # query conflicts +#wal_receiver_timeout = 60s # time that receiver waits for + # communication from master + # in milliseconds; 0 disables +#wal_retrieve_retry_interval = 5s # time to wait before retrying to + # retrieve WAL after a failed attempt + +# - Subscribers - + +# These settings are ignored on a publisher. + +#max_logical_replication_workers = 4 # taken from max_worker_processes + # (change requires restart) +#max_sync_workers_per_subscription = 2 # taken from max_logical_replication_workers + + +#------------------------------------------------------------------------------ +# QUERY TUNING +#------------------------------------------------------------------------------ + +# - Planner Method Configuration - + +#enable_bitmapscan = on +#enable_hashagg = on +#enable_hashjoin = on +#enable_indexscan = on +#enable_indexonlyscan = on +#enable_material = on +#enable_mergejoin = on +#enable_nestloop = on +#enable_seqscan = on +#enable_sort = on +#enable_tidscan = on + +# - Planner Cost Constants - + +#seq_page_cost = 1.0 # measured on an arbitrary scale +#random_page_cost = 4.0 # same scale as above +#cpu_tuple_cost = 0.01 # same scale as above +#cpu_index_tuple_cost = 0.005 # same scale as above +#cpu_operator_cost = 0.0025 # same scale as above +#parallel_tuple_cost = 0.1 # same scale as above +#parallel_setup_cost = 1000.0 # same scale as above +#min_parallel_table_scan_size = 8MB +#min_parallel_index_scan_size = 512kB +#effective_cache_size = 4GB + +# - Genetic Query Optimizer - + +#geqo = on +#geqo_threshold = 12 +#geqo_effort = 5 # range 1-10 +#geqo_pool_size = 0 # selects default based on effort +#geqo_generations = 0 # selects default based on effort +#geqo_selection_bias = 2.0 # range 1.5-2.0 +#geqo_seed = 0.0 # range 0.0-1.0 + +# - Other Planner Options - + +#default_statistics_target = 100 # range 1-10000 +#constraint_exclusion = partition # on, off, or partition +#cursor_tuple_fraction = 0.1 # range 0.0-1.0 +#from_collapse_limit = 8 +#join_collapse_limit = 8 # 1 disables collapsing of explicit + # JOIN clauses +#force_parallel_mode = off + + +#------------------------------------------------------------------------------ +# ERROR REPORTING AND LOGGING +#------------------------------------------------------------------------------ + +# - Where to Log - + +log_destination = 'stderr' # Valid values are combinations of + # stderr, csvlog, syslog, and eventlog, + # depending on platform. csvlog + # requires logging_collector to be on. + +# This is used when logging to stderr: +logging_collector = on # Enable capturing of stderr and csvlog + # into log files. Required to be on for + # csvlogs. + # (change requires restart) + +# These are only used if logging_collector is on: +#log_directory = 'log' # directory where log files are written, + # can be absolute or relative to PGDATA +log_filename = 'postgresql.log' # log file name pattern, + # can include strftime() escapes +#log_file_mode = 0600 # creation mode for log files, + # begin with 0 to use octal notation +#log_truncate_on_rotation = off # If on, an existing log file with the + # same name as the new log file will be + # truncated rather than appended to. + # But such truncation only occurs on + # time-driven rotation, not on restarts + # or size-driven rotation. Default is + # off, meaning append to existing files + # in all cases. +#log_rotation_age = 1d # Automatic rotation of logfiles will + # happen after that time. 0 disables. +#log_rotation_size = 10MB # Automatic rotation of logfiles will + # happen after that much log output. + # 0 disables. + +# These are relevant when logging to syslog: +#syslog_facility = 'LOCAL0' +#syslog_ident = 'postgres' +#syslog_sequence_numbers = on +#syslog_split_messages = on + +# This is only relevant when logging to eventlog (win32): +# (change requires restart) +#event_source = 'PostgreSQL' + +# - When to Log - + +client_min_messages = info # values in order of decreasing detail: + # debug5 + # debug4 + # debug3 + # debug2 + # debug1 + # log + # notice + # warning + # error + +log_min_messages = info # values in order of decreasing detail: + # debug5 + # debug4 + # debug3 + # debug2 + # debug1 + # info + # notice + # warning + # error + # log + # fatal + # panic + +#log_min_error_statement = error # values in order of decreasing detail: + # debug5 + # debug4 + # debug3 + # debug2 + # debug1 + # info + # notice + # warning + # error + # log + # fatal + # panic (effectively off) + +#log_min_duration_statement = -1 # -1 is disabled, 0 logs all statements + # and their durations, > 0 logs only + # statements running at least this number + # of milliseconds + + +# - What to Log - + +#debug_print_parse = off +#debug_print_rewritten = off +#debug_print_plan = off +#debug_pretty_print = on +#log_checkpoints = off +log_connections = on +#log_disconnections = off +#log_duration = off +#log_error_verbosity = default # terse, default, or verbose messages +#log_hostname = off +#log_line_prefix = '%m [%p] ' # special values: + # %a = application name + # %u = user name + # %d = database name + # %r = remote host and port + # %h = remote host + # %p = process ID + # %t = timestamp without milliseconds + # %m = timestamp with milliseconds + # %n = timestamp with milliseconds (as a Unix epoch) + # %i = command tag + # %e = SQL state + # %c = session ID + # %l = session line number + # %s = session start timestamp + # %v = virtual transaction ID + # %x = transaction ID (0 if none) + # %q = stop here in non-session + # processes + # %% = '%' + # e.g. '<%u%%%d> ' +#log_lock_waits = off # log lock waits >= deadlock_timeout +#log_statement = 'none' # none, ddl, mod, all +#log_replication_commands = off +#log_temp_files = -1 # log temporary files equal or larger + # than the specified size in kilobytes; + # -1 disables, 0 logs all temp files +log_timezone = 'Africa/Casablanca' + + +# - Process Title - + +#cluster_name = '' # added to process titles if nonempty + # (change requires restart) +#update_process_title = off + + +#------------------------------------------------------------------------------ +# RUNTIME STATISTICS +#------------------------------------------------------------------------------ + +# - Query/Index Statistics Collector - + +#track_activities = on +#track_counts = on +#track_io_timing = off +#track_functions = none # none, pl, all +#track_activity_query_size = 1024 # (change requires restart) +#stats_temp_directory = 'pg_stat_tmp' + + +# - Statistics Monitoring - + +#log_parser_stats = off +#log_planner_stats = off +#log_executor_stats = off +#log_statement_stats = off + + +#------------------------------------------------------------------------------ +# AUTOVACUUM PARAMETERS +#------------------------------------------------------------------------------ + +#autovacuum = on # Enable autovacuum subprocess? 'on' + # requires track_counts to also be on. +#log_autovacuum_min_duration = -1 # -1 disables, 0 logs all actions and + # their durations, > 0 logs only + # actions running at least this number + # of milliseconds. +#autovacuum_max_workers = 3 # max number of autovacuum subprocesses + # (change requires restart) +#autovacuum_naptime = 1min # time between autovacuum runs +#autovacuum_vacuum_threshold = 50 # min number of row updates before + # vacuum +#autovacuum_analyze_threshold = 50 # min number of row updates before + # analyze +#autovacuum_vacuum_scale_factor = 0.2 # fraction of table size before vacuum +#autovacuum_analyze_scale_factor = 0.1 # fraction of table size before analyze +#autovacuum_freeze_max_age = 200000000 # maximum XID age before forced vacuum + # (change requires restart) +#autovacuum_multixact_freeze_max_age = 400000000 # maximum multixact age + # before forced vacuum + # (change requires restart) +#autovacuum_vacuum_cost_delay = 20ms # default vacuum cost delay for + # autovacuum, in milliseconds; + # -1 means use vacuum_cost_delay +#autovacuum_vacuum_cost_limit = -1 # default vacuum cost limit for + # autovacuum, -1 means use + # vacuum_cost_limit + + +#------------------------------------------------------------------------------ +# CLIENT CONNECTION DEFAULTS +#------------------------------------------------------------------------------ + +# - Statement Behavior - + +#search_path = '"$user", public' # schema names +#default_tablespace = '' # a tablespace name, '' uses the default +#temp_tablespaces = '' # a list of tablespace names, '' uses + # only default tablespace +#check_function_bodies = on +#default_transaction_isolation = 'read committed' +#default_transaction_read_only = off +#default_transaction_deferrable = off +#session_replication_role = 'origin' +#statement_timeout = 0 # in milliseconds, 0 is disabled +#lock_timeout = 0 # in milliseconds, 0 is disabled +#idle_in_transaction_session_timeout = 0 # in milliseconds, 0 is disabled +#vacuum_freeze_min_age = 50000000 +#vacuum_freeze_table_age = 150000000 +#vacuum_multixact_freeze_min_age = 5000000 +#vacuum_multixact_freeze_table_age = 150000000 +#bytea_output = 'hex' # hex, escape +#xmlbinary = 'base64' +#xmloption = 'content' +#gin_fuzzy_search_limit = 0 +#gin_pending_list_limit = 4MB + +# - Locale and Formatting - + +datestyle = 'iso, mdy' +#intervalstyle = 'postgres' +timezone = 'Africa/Casablanca' +#timezone_abbreviations = 'Default' # Select the set of available time zone + # abbreviations. Currently, there are + # Default + # Australia (historical usage) + # India + # You can create your own file in + # share/timezonesets/. +#extra_float_digits = 0 # min -15, max 3 +#client_encoding = sql_ascii # actually, defaults to database + # encoding + +# These settings are initialized by initdb, but they can be changed. +lc_messages = 'English_United States.1252' # locale for system error message + # strings +lc_monetary = 'English_United States.1252' # locale for monetary formatting +lc_numeric = 'English_United States.1252' # locale for number formatting +lc_time = 'English_United States.1252' # locale for time formatting + +# default configuration for text search +default_text_search_config = 'pg_catalog.english' + +# - Other Defaults - + +#dynamic_library_path = '$libdir' +#local_preload_libraries = '' +#session_preload_libraries = '' + + +#------------------------------------------------------------------------------ +# LOCK MANAGEMENT +#------------------------------------------------------------------------------ + +#deadlock_timeout = 1s +#max_locks_per_transaction = 64 # min 10 + # (change requires restart) +#max_pred_locks_per_transaction = 64 # min 10 + # (change requires restart) +#max_pred_locks_per_relation = -2 # negative values mean + # (max_pred_locks_per_transaction + # / -max_pred_locks_per_relation) - 1 +#max_pred_locks_per_page = 2 # min 0 + + +#------------------------------------------------------------------------------ +# VERSION/PLATFORM COMPATIBILITY +#------------------------------------------------------------------------------ + +# - Previous PostgreSQL Versions - + +#array_nulls = on +#backslash_quote = safe_encoding # on, off, or safe_encoding +#default_with_oids = off +#escape_string_warning = on +#lo_compat_privileges = off +#operator_precedence_warning = off +#quote_all_identifiers = off +#standard_conforming_strings = on +#synchronize_seqscans = on + +# - Other Platforms and Clients - + +#transform_null_equals = off + + +#------------------------------------------------------------------------------ +# ERROR HANDLING +#------------------------------------------------------------------------------ + +#exit_on_error = off # terminate session on any error? +#restart_after_crash = on # reinitialize after backend crash? + + +#------------------------------------------------------------------------------ +# CONFIG FILE INCLUDES +#------------------------------------------------------------------------------ + +# These options allow settings to be loaded from files other than the +# default postgresql.conf. + +#include_dir = 'conf.d' # include files ending in '.conf' from + # directory 'conf.d' +#include_if_exists = 'exists.conf' # include file only if it exists +#include = 'special.conf' # include file + + +#------------------------------------------------------------------------------ +# CUSTOMIZED OPTIONS +#------------------------------------------------------------------------------ + +# Add settings for extensions here diff --git a/Jenkinsfile b/Jenkinsfile index 1a7c84b139..f19fdd027b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -112,6 +112,12 @@ def generateStepForWindows(Map params = [:]){ docker run -d -p 27017:27017 --name mongodb mongodb docker ps ''' + bat label: 'Run postgres', script: ''' + cd .ci/scripts/windows/docker/postgres + docker build --tag=postgres . + docker run -d -p 5432:5432 --name postgres postgres + docker ps + ''' bat label: 'Tool versions', script: ''' npm --version node --version @@ -126,6 +132,7 @@ def generateStepForWindows(Map params = [:]){ bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' + bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' } } From 7a15ffc4330e176277144daa74975611dbfc6515 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 7 Oct 2019 20:51:46 +0100 Subject: [PATCH 056/117] ci(jenkins): mssql docker --- Jenkinsfile | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index f19fdd027b..db416e26d1 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -118,6 +118,10 @@ def generateStepForWindows(Map params = [:]){ docker run -d -p 5432:5432 --name postgres postgres docker ps ''' + bat label: 'Run mssql', script: ''' + docker run -d -p 1433:1433 -e sa_password=Very(!)Secure -e ACCEPT_EULA=Y --name mssql microsoft/mssql-server-windows-developer + docker ps + ''', returnStatus: true bat label: 'Tool versions', script: ''' npm --version node --version @@ -131,6 +135,7 @@ def generateStepForWindows(Map params = [:]){ bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' + bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' From 9cff59595b0a77a50148c3fa5a57597f93b662e2 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 11:26:24 +0100 Subject: [PATCH 057/117] ci(jenkins): run services in linux --- .ci/scripts/run-services.sh | 12 ++++++++++++ .ci/scripts/stop-services.sh | 18 ++++++++++++++++++ Jenkinsfile | 30 ++++++++++++++++++++++++------ 3 files changed, 54 insertions(+), 6 deletions(-) create mode 100755 .ci/scripts/run-services.sh create mode 100755 .ci/scripts/stop-services.sh diff --git a/.ci/scripts/run-services.sh b/.ci/scripts/run-services.sh new file mode 100755 index 0000000000..8e6093da34 --- /dev/null +++ b/.ci/scripts/run-services.sh @@ -0,0 +1,12 @@ +#!/usr/bin/env bash +set -exo pipefail + +USER_ID="$(id -u):$(id -g)" \ +docker-compose \ + --no-ansi \ + --log-level ERROR \ + --file .ci/docker/docker-compose.yml \ + up \ + --build \ + --remove-orphans \ + --detach diff --git a/.ci/scripts/stop-services.sh b/.ci/scripts/stop-services.sh new file mode 100755 index 0000000000..d7561241bb --- /dev/null +++ b/.ci/scripts/stop-services.sh @@ -0,0 +1,18 @@ +#!/usr/bin/env bash +set -exo pipefail + +docker-compose \ + --no-ansi \ + --log-level ERROR \ + --file .ci/docker/docker-compose.yml \ + logs \ + --timestamps \ + --tail=100 + +docker-compose \ + --no-ansi \ + --log-level ERROR \ + --file .ci/docker/docker-compose.yml \ + down \ + --volumes \ + --remove-orphans diff --git a/Jenkinsfile b/Jenkinsfile index db416e26d1..6d605e2e3d 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -57,22 +57,31 @@ pipeline { unstash 'source' dir("${BASE_DIR}"){ script { + // Prepare context for running all the services in the linux agent + sh label: 'Run required services', script: '.ci/scripts/run-services.sh' + def hostService = sh(label: 'Get IP', script: 'hostname -I | awk "{print $1}"', returnStdout: true) def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') - + parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12', host: hostService) parallel(parallelTasks) } } } } + post { + always { + dir("${BASE_DIR}"){ + sh label: 'Stop docker', returnStatus: true, script: '.ci/scripts/stop-services.sh' + } + } + } } } } def generateStepForWindows(Map params = [:]){ def version = params?.version - def edge = params.containsKey('edge') ? params.edge : false + def host = params?.host def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('windows-2019-docker-immutable'){ @@ -84,11 +93,19 @@ def generateStepForWindows(Map params = [:]){ if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' } + env.CASSANDRA_HOST = host + env.ES_HOST = host + env.MONGODB_HOST = host + env.MSSQL_HOST = host + env.MYSQL_HOST = host + env.PGHOST = host + env.REDIS_HOST = host deleteDir() unstash 'source' dir(BASE_DIR) { + powershell label: 'Ping', script: "Test-Connection $env:host -IPv4 -TimeoutSeconds 30" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat label: 'Run cassandra', script: ''' + /**bat label: 'Run cassandra', script: ''' cd .ci/scripts/windows/docker/cassandra docker build --tag=cassandra . docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra @@ -121,7 +138,7 @@ def generateStepForWindows(Map params = [:]){ bat label: 'Run mssql', script: ''' docker run -d -p 1433:1433 -e sa_password=Very(!)Secure -e ACCEPT_EULA=Y --name mssql microsoft/mssql-server-windows-developer docker ps - ''', returnStatus: true + ''', returnStatus: true */ bat label: 'Tool versions', script: ''' npm --version node --version @@ -133,12 +150,13 @@ def generateStepForWindows(Map params = [:]){ error(e.toString()) } finally { bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' - bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' + /**bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' + */ } } } From 96a30257af62d545ba509ab5b066650b7b1a0b30 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 11:36:24 +0100 Subject: [PATCH 058/117] ci(jenkins): fix interpolation --- Jenkinsfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index 6d605e2e3d..dd581bb156 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -59,7 +59,7 @@ pipeline { script { // Prepare context for running all the services in the linux agent sh label: 'Run required services', script: '.ci/scripts/run-services.sh' - def hostService = sh(label: 'Get IP', script: 'hostname -I | awk "{print $1}"', returnStdout: true) + def hostService = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true) def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12', host: hostService) From 5749a66b534b0de6c9fe54f80f4e72579b6f9f77 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 12:00:27 +0100 Subject: [PATCH 059/117] ci(jenkins): enable docker-compose wait --- .ci/docker/docker-compose-wait.yml | 68 ++++++++++++++++++++++++++++++ .ci/scripts/run-services.sh | 2 +- .ci/scripts/stop-services.sh | 4 +- Jenkinsfile | 7 ++- 4 files changed, 74 insertions(+), 7 deletions(-) create mode 100644 .ci/docker/docker-compose-wait.yml diff --git a/.ci/docker/docker-compose-wait.yml b/.ci/docker/docker-compose-wait.yml new file mode 100644 index 0000000000..d62d19c313 --- /dev/null +++ b/.ci/docker/docker-compose-wait.yml @@ -0,0 +1,68 @@ +version: '2.1' + +services: + cassandra: + extends: + file: docker-compose.yml + service: cassandra + elasticsearch: + extends: + file: docker-compose.yml + service: elasticsearch + memcached: + extends: + file: docker-compose.yml + service: memcached + mongodb: + extends: + file: docker-compose.yml + service: mongodb + mssql: + extends: + file: docker-compose.yml + service: mssql + mysql: + extends: + file: docker-compose.yml + service: mysql + postgres: + extends: + file: docker-compose.yml + service: postgres + redis: + extends: + file: docker-compose.yml + service: redis + wait: + image: busybox + depends_on: + cassandra: + condition: service_healthy + elasticsearch: + condition: service_healthy + memcached: + condition: service_healthy + mongodb: + condition: service_healthy + mssql: + condition: service_healthy + mysql: + condition: service_healthy + postgres: + condition: service_healthy + redis: + condition: service_healthy + +volumes: + nodepgdata: + driver: local + nodemongodata: + driver: local + nodemssqldata: + driver: local + nodemysqldata: + driver: local + nodeesdata: + driver: local + nodecassandradata: + driver: local diff --git a/.ci/scripts/run-services.sh b/.ci/scripts/run-services.sh index 8e6093da34..19c94d1d19 100755 --- a/.ci/scripts/run-services.sh +++ b/.ci/scripts/run-services.sh @@ -5,7 +5,7 @@ USER_ID="$(id -u):$(id -g)" \ docker-compose \ --no-ansi \ --log-level ERROR \ - --file .ci/docker/docker-compose.yml \ + --file .ci/docker/docker-compose-wait.yml \ up \ --build \ --remove-orphans \ diff --git a/.ci/scripts/stop-services.sh b/.ci/scripts/stop-services.sh index d7561241bb..55fe60f362 100755 --- a/.ci/scripts/stop-services.sh +++ b/.ci/scripts/stop-services.sh @@ -4,7 +4,7 @@ set -exo pipefail docker-compose \ --no-ansi \ --log-level ERROR \ - --file .ci/docker/docker-compose.yml \ + --file .ci/docker/docker-compose-wait.yml \ logs \ --timestamps \ --tail=100 @@ -12,7 +12,7 @@ docker-compose \ docker-compose \ --no-ansi \ --log-level ERROR \ - --file .ci/docker/docker-compose.yml \ + --file .ci/docker/docker-compose-wait.yml \ down \ --volumes \ --remove-orphans diff --git a/Jenkinsfile b/Jenkinsfile index dd581bb156..7f896ce43a 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -70,9 +70,8 @@ pipeline { } post { always { - dir("${BASE_DIR}"){ - sh label: 'Stop docker', returnStatus: true, script: '.ci/scripts/stop-services.sh' - } + sh label: 'Docker ps', script: 'docker ps -a || true' + sh label: 'Stop docker', script: "${BASE_DIR}/.ci/scripts/stop-services.sh || true" } } } @@ -103,7 +102,7 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - powershell label: 'Ping', script: "Test-Connection $env:host -IPv4 -TimeoutSeconds 30" + powershell label: 'Ping', script: 'Test-Connection $env:host' powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" /**bat label: 'Run cassandra', script: ''' cd .ci/scripts/windows/docker/cassandra From 438dc934489f11797ca01589948da347db2decf5 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 12:26:11 +0100 Subject: [PATCH 060/117] ci(jenkins): debug and interpolate --- .ci/scripts/windows/install-tools.ps1 | 3 +++ Jenkinsfile | 3 ++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index cb771ebd12..aa1a7039d2 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -1,6 +1,9 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" +Write-Host "List environment variables..." +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize + Write-Host "Getting latest Nodejs version..." $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 diff --git a/Jenkinsfile b/Jenkinsfile index 7f896ce43a..4aa0a55cba 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -60,6 +60,7 @@ pipeline { // Prepare context for running all the services in the linux agent sh label: 'Run required services', script: '.ci/scripts/run-services.sh' def hostService = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true) + echo "Running services in the host: ${hostService}" def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12', host: hostService) @@ -102,7 +103,7 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - powershell label: 'Ping', script: 'Test-Connection $env:host' + powershell label: 'Ping', script: "Test-Connection ${host}" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" /**bat label: 'Run cassandra', script: ''' cd .ci/scripts/windows/docker/cassandra From ed8040390d41a0745ec93e938c89766f2d18e71b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 13:29:56 +0100 Subject: [PATCH 061/117] ci(jenkins): enable windows docker --- Jenkinsfile | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 4aa0a55cba..be2b413d8b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -105,7 +105,7 @@ def generateStepForWindows(Map params = [:]){ dir(BASE_DIR) { powershell label: 'Ping', script: "Test-Connection ${host}" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - /**bat label: 'Run cassandra', script: ''' + bat label: 'Run cassandra', script: ''' cd .ci/scripts/windows/docker/cassandra docker build --tag=cassandra . docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra @@ -138,7 +138,7 @@ def generateStepForWindows(Map params = [:]){ bat label: 'Run mssql', script: ''' docker run -d -p 1433:1433 -e sa_password=Very(!)Secure -e ACCEPT_EULA=Y --name mssql microsoft/mssql-server-windows-developer docker ps - ''', returnStatus: true */ + ''', returnStatus: true bat label: 'Tool versions', script: ''' npm --version node --version @@ -150,13 +150,12 @@ def generateStepForWindows(Map params = [:]){ error(e.toString()) } finally { bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' - /**bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' + bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' - */ } } } From a55745c01b3a3c85e0b3e6c1f70749664a14f070 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 15:20:50 +0100 Subject: [PATCH 062/117] ci(jenkins): not supported yet --- Jenkinsfile | 21 +-------------------- 1 file changed, 1 insertion(+), 20 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index be2b413d8b..aeafae6967 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -57,31 +57,20 @@ pipeline { unstash 'source' dir("${BASE_DIR}"){ script { - // Prepare context for running all the services in the linux agent - sh label: 'Run required services', script: '.ci/scripts/run-services.sh' - def hostService = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true) - echo "Running services in the host: ${hostService}" def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] - parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12', host: hostService) + parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') parallel(parallelTasks) } } } } - post { - always { - sh label: 'Docker ps', script: 'docker ps -a || true' - sh label: 'Stop docker', script: "${BASE_DIR}/.ci/scripts/stop-services.sh || true" - } - } } } } def generateStepForWindows(Map params = [:]){ def version = params?.version - def host = params?.host def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('windows-2019-docker-immutable'){ @@ -93,17 +82,9 @@ def generateStepForWindows(Map params = [:]){ if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' } - env.CASSANDRA_HOST = host - env.ES_HOST = host - env.MONGODB_HOST = host - env.MSSQL_HOST = host - env.MYSQL_HOST = host - env.PGHOST = host - env.REDIS_HOST = host deleteDir() unstash 'source' dir(BASE_DIR) { - powershell label: 'Ping', script: "Test-Connection ${host}" powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" bat label: 'Run cassandra', script: ''' cd .ci/scripts/windows/docker/cassandra From 7d1952adf0624bbb4a5372a12b6b4a23d7403f57 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 15:36:30 +0100 Subject: [PATCH 063/117] ci(jenkins): mssql docker --- .ci/scripts/windows/docker/mssql/Dockerfile | 31 +++++++++ .ci/scripts/windows/docker/mssql/start.ps1 | 77 +++++++++++++++++++++ Jenkinsfile | 11 ++- 3 files changed, 116 insertions(+), 3 deletions(-) create mode 100644 .ci/scripts/windows/docker/mssql/Dockerfile create mode 100644 .ci/scripts/windows/docker/mssql/start.ps1 diff --git a/.ci/scripts/windows/docker/mssql/Dockerfile b/.ci/scripts/windows/docker/mssql/Dockerfile new file mode 100644 index 0000000000..9446dd5a90 --- /dev/null +++ b/.ci/scripts/windows/docker/mssql/Dockerfile @@ -0,0 +1,31 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +# Download Links: +ENV exe "https://go.microsoft.com/fwlink/?linkid=840945" +ENV box "https://go.microsoft.com/fwlink/?linkid=840944" + +ENV sa_password="_" ` + attach_dbs="[]" ` + ACCEPT_EULA="_" ` + sa_password_path="C:\ProgramData\Docker\secrets\sa-password" + +EXPOSE 1433 +COPY start.ps1 / +WORKDIR / + +RUN Invoke-WebRequest -Uri $env:box -OutFile SQL.box ; ` + Invoke-WebRequest -Uri $env:exe -OutFile SQL.exe ; ` + Start-Process -Wait -FilePath .\SQL.exe -ArgumentList /qs, /x:setup ; ` + .\setup\setup.exe /q /ACTION=Install /INSTANCENAME=MSSQLSERVER /FEATURES=SQLEngine /UPDATEENABLED=0 /SQLSVCACCOUNT='NT AUTHORITY\NETWORK SERVICE' /SQLSYSADMINACCOUNTS='BUILTIN\ADMINISTRATORS' /TCPENABLED=1 /NPENABLED=0 /IACCEPTSQLSERVERLICENSETERMS ; ` + Remove-Item -Recurse -Force SQL.exe, SQL.box, setup + +RUN stop-service MSSQLSERVER ; ` + set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\supersocketnetlib\tcp\ipall' -name tcpdynamicports -value '' ; ` + set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\supersocketnetlib\tcp\ipall' -name tcpport -value 1433 ; ` + set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\' -name LoginMode -value 2 ; + +HEALTHCHECK CMD [ "sqlcmd", "-Q", "select 1" ] + +CMD .\start -sa_password $env:sa_password -ACCEPT_EULA $env:ACCEPT_EULA -attach_dbs \"$env:attach_dbs\" -Verbose diff --git a/.ci/scripts/windows/docker/mssql/start.ps1 b/.ci/scripts/windows/docker/mssql/start.ps1 new file mode 100644 index 0000000000..090f9eb0c9 --- /dev/null +++ b/.ci/scripts/windows/docker/mssql/start.ps1 @@ -0,0 +1,77 @@ +# The script sets the sa password and start the SQL Service +# Also it attaches additional database from the disk +# The format for attach_dbs + +param( +[Parameter(Mandatory=$false)] +[string]$sa_password, + +[Parameter(Mandatory=$false)] +[string]$ACCEPT_EULA, + +[Parameter(Mandatory=$false)] +[string]$attach_dbs +) + + +if($ACCEPT_EULA -ne "Y" -And $ACCEPT_EULA -ne "y") +{ + Write-Verbose "ERROR: You must accept the End User License Agreement before this container can start." + Write-Verbose "Set the environment variable ACCEPT_EULA to 'Y' if you accept the agreement." + + exit 1 +} + +# start the service +Write-Verbose "Starting SQL Server" +start-service MSSQLSERVER + +if($sa_password -eq "_") { + if (Test-Path $env:sa_password_path) { + $sa_password = Get-Content -Raw $secretPath + } + else { + Write-Verbose "WARN: Using default SA password, secret file not found at: $secretPath" + } +} + +if($sa_password -ne "_") +{ + Write-Verbose "Changing SA login credentials" + $sqlcmd = "ALTER LOGIN sa with password=" +"'" + $sa_password + "'" + ";ALTER LOGIN sa ENABLE;" + & sqlcmd -Q $sqlcmd +} + +$attach_dbs_cleaned = $attach_dbs.TrimStart('\\').TrimEnd('\\') + +$dbs = $attach_dbs_cleaned | ConvertFrom-Json + +if ($null -ne $dbs -And $dbs.Length -gt 0) +{ + Write-Verbose "Attaching $($dbs.Length) database(s)" + + Foreach($db in $dbs) + { + $files = @(); + Foreach($file in $db.dbFiles) + { + $files += "(FILENAME = N'$($file)')"; + } + + $files = $files -join "," + $sqlcmd = "IF EXISTS (SELECT 1 FROM SYS.DATABASES WHERE NAME = '" + $($db.dbName) + "') BEGIN EXEC sp_detach_db [$($db.dbName)] END;CREATE DATABASE [$($db.dbName)] ON $($files) FOR ATTACH;" + + Write-Verbose "Invoke-Sqlcmd -Query $($sqlcmd)" + & sqlcmd -Q $sqlcmd + } +} + +Write-Verbose "Started SQL Server." + +$lastCheck = (Get-Date).AddSeconds(-2) +while ($true) +{ + Get-EventLog -LogName Application -Source "MSSQL*" -After $lastCheck | Select-Object TimeGenerated, EntryType, Message + $lastCheck = Get-Date + Start-Sleep -Seconds 2 +} diff --git a/Jenkinsfile b/Jenkinsfile index aeafae6967..c413aeba23 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -117,15 +117,20 @@ def generateStepForWindows(Map params = [:]){ docker ps ''' bat label: 'Run mssql', script: ''' - docker run -d -p 1433:1433 -e sa_password=Very(!)Secure -e ACCEPT_EULA=Y --name mssql microsoft/mssql-server-windows-developer + cd .ci/scripts/windows/docker/mssql + docker build --tag=mssql . + docker run -d -p 1433:1433 -e sa_password='Very(!)Secure' -e ACCEPT_EULA=Y --name mssql mssql docker ps - ''', returnStatus: true + ''', returnStatus: true // TODO: for the time being bat label: 'Tool versions', script: ''' npm --version node --version ''' bat 'npm install' - bat 'node test/test.js' + bat ''' + docker ps + node test/test.js + ''' } } catch(e){ error(e.toString()) From f07a316093754a8ed23d5c22e50704f7d126c51c Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 8 Oct 2019 16:27:48 +0100 Subject: [PATCH 064/117] ci(jenkins): mysql docker --- .ci/scripts/windows/docker/mysql/Dockerfile | 18 ++++++++++++++++++ .ci/scripts/windows/docker/mysql/my.ini | 5 +++++ Jenkinsfile | 9 ++++++++- 3 files changed, 31 insertions(+), 1 deletion(-) create mode 100644 .ci/scripts/windows/docker/mysql/Dockerfile create mode 100644 .ci/scripts/windows/docker/mysql/my.ini diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile new file mode 100644 index 0000000000..909b0eacdc --- /dev/null +++ b/.ci/scripts/windows/docker/mysql/Dockerfile @@ -0,0 +1,18 @@ +# escape=` +FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 +SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] + +RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) + +ARG VERSION="8.0.17" +ENV MYSQL_HOME="C:\tools\mysql\current" +RUN choco install mysql --version=${env:VERSION} --no-progress -y + +EXPOSE 3306 +WORKDIR $MYSQL_HOME +COPY my.ini . + +HEALTHCHECK CMD [ "mysql", "-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] + +# Keep running the container with the event logs in the stdout. +CMD ["powershell", "Get-Content", "mysql.log", "-Wait"] diff --git a/.ci/scripts/windows/docker/mysql/my.ini b/.ci/scripts/windows/docker/mysql/my.ini new file mode 100644 index 0000000000..b26af85c90 --- /dev/null +++ b/.ci/scripts/windows/docker/mysql/my.ini @@ -0,0 +1,5 @@ +[mysqld] +basedir=C:\\tools\\mysql\\current +datadir=C:\\ProgramData\\MySQL\\data +log_error=C:\\tools\\mysql\\current\\error.log +log_error_verbosity=3 diff --git a/Jenkinsfile b/Jenkinsfile index c413aeba23..cd41f24e3b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -121,6 +121,12 @@ def generateStepForWindows(Map params = [:]){ docker build --tag=mssql . docker run -d -p 1433:1433 -e sa_password='Very(!)Secure' -e ACCEPT_EULA=Y --name mssql mssql docker ps + ''' + bat label: 'Run mysql', script: ''' + cd .ci/scripts/windows/docker/mysql + docker build --tag=mysql . + docker run -d -p 3306:3306 --name mysql mysql + docker ps ''', returnStatus: true // TODO: for the time being bat label: 'Tool versions', script: ''' npm --version @@ -138,8 +144,9 @@ def generateStepForWindows(Map params = [:]){ bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' - bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' + bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' + bat label: 'Gather mysql logs', returnStatus: true, script: 'docker logs mysql' bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' } From 11d3d5cd176cf761c7d49654e958da6e964cca2b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 12:27:15 +0100 Subject: [PATCH 065/117] ci(jenkins): docker-compose --- .ci/scripts/windows/docker/docker-compose.yml | 87 +++++++++++++++++++ Jenkinsfile | 59 +++---------- 2 files changed, 97 insertions(+), 49 deletions(-) create mode 100644 .ci/scripts/windows/docker/docker-compose.yml diff --git a/.ci/scripts/windows/docker/docker-compose.yml b/.ci/scripts/windows/docker/docker-compose.yml new file mode 100644 index 0000000000..e5919e1bd5 --- /dev/null +++ b/.ci/scripts/windows/docker/docker-compose.yml @@ -0,0 +1,87 @@ +version: '2.1' + +services: + cassandra: + build: + context: cassandra + dockerfile: Dockerfile + environment: + MAX_HEAP_SIZE: "1G" + HEAP_NEWSIZE: 400m + ports: + - "9042:9042" + - "7000:7000" + + elasticsearch: + build: + context: elasticsearch + dockerfile: Dockerfile + environment: + - "ES_JAVA_OPTS=-Xms512m -Xmx512m" + - "network.host=" + - "transport.host=127.0.0.1" + - "http.host=0.0.0.0" + - "xpack.security.enabled=false" + ports: + - "9200:9200" + - "9230:9300" + + mongodb: + build: + context: mongodb + dockerfile: Dockerfile + ports: + - "27017:27017" + healthcheck: + test: ["CMD", "mongo", "--quiet"] + interval: 1s + timeout: 10s + retries: 30 + + mssql: + build: + context: mssql + dockerfile: Dockerfile + environment: + - ACCEPT_EULA=Y + - sa_password=Very(!)Secure + ports: + - "1433:1433" + + mysql: + build: + context: mysql + dockerfile: Dockerfile + environment: + MYSQL_ALLOW_EMPTY_PASSWORD: 1 + ports: + - "3306:3306" + healthcheck: + test: ["CMD", "mysql" ,"-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] + interval: 1s + timeout: 10s + retries: 30 + + postgres: + build: + context: postgres + dockerfile: Dockerfile + ports: + - "5432:5432" + healthcheck: + test: ["CMD", "pg_isready"] + interval: 1s + timeout: 10s + retries: 30 + + redis: + build: + context: redis + dockerfile: Dockerfile + ports: + - "6379:6379" + healthcheck: + test: ["CMD", "redis-cli", "ping"] + interval: 1s + timeout: 10s + retries: 30 diff --git a/Jenkinsfile b/Jenkinsfile index cd41f24e3b..70f74b3744 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -86,48 +86,10 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat label: 'Run cassandra', script: ''' - cd .ci/scripts/windows/docker/cassandra - docker build --tag=cassandra . - docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra - docker ps - ''' - bat label: 'Run redis', script: ''' - cd .ci/scripts/windows/docker/redis - docker build --tag=redis . - docker run -d -p 6379:6379 --name redis redis - docker ps - ''' - bat label: 'Run elasticsearch', script: ''' - cd .ci/scripts/windows/docker/elasticsearch - docker build --tag=elasticsearch . - docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch - docker ps - ''' - bat label: 'Run mongodb', script: ''' - cd .ci/scripts/windows/docker/mongodb - docker build --tag=mongodb . - docker run -d -p 27017:27017 --name mongodb mongodb - docker ps + bat label: 'Run docker-compose', script: ''' + cd .ci/scripts/windows/docker + docker-compose --no-ansi up --build --detach ''' - bat label: 'Run postgres', script: ''' - cd .ci/scripts/windows/docker/postgres - docker build --tag=postgres . - docker run -d -p 5432:5432 --name postgres postgres - docker ps - ''' - bat label: 'Run mssql', script: ''' - cd .ci/scripts/windows/docker/mssql - docker build --tag=mssql . - docker run -d -p 1433:1433 -e sa_password='Very(!)Secure' -e ACCEPT_EULA=Y --name mssql mssql - docker ps - ''' - bat label: 'Run mysql', script: ''' - cd .ci/scripts/windows/docker/mysql - docker build --tag=mysql . - docker run -d -p 3306:3306 --name mysql mysql - docker ps - ''', returnStatus: true // TODO: for the time being bat label: 'Tool versions', script: ''' npm --version node --version @@ -141,14 +103,13 @@ def generateStepForWindows(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - bat label: 'Docker ps', returnStatus: true, script: 'docker ps -a' - bat label: 'Gather cassandra logs', returnStatus: true, script: 'docker logs cassandra' - bat label: 'Gather elasticsearch logs', returnStatus: true, script: 'docker logs elasticsearch' - bat label: 'Gather mongodb logs', returnStatus: true, script: 'docker logs mongodb' - bat label: 'Gather mssql logs', returnStatus: true, script: 'docker logs mssql' - bat label: 'Gather mysql logs', returnStatus: true, script: 'docker logs mysql' - bat label: 'Gather postgres logs', returnStatus: true, script: 'docker logs postgres' - bat label: 'Gather redis logs', returnStatus: true, script: 'docker logs redis' + dir(BASE_DIR) { + bat label: 'Gather docker-compose logs', returnStatus: true, script: ''' + docker ps -a + cd .ci/scripts/windows/docker + docker-compose logs --no-color --timestamps + ''' + } } } } From 9314a382c9ab398cadf71443e13239c3873d561f Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 14:45:19 +0100 Subject: [PATCH 066/117] ci(jenkins): traditional docker --- .ci/scripts/windows/docker/log-services.bat | 8 ++++++++ .ci/scripts/windows/docker/run-services.bat | 15 +++++++++++++++ Jenkinsfile | 15 +++++---------- 3 files changed, 28 insertions(+), 10 deletions(-) create mode 100644 .ci/scripts/windows/docker/log-services.bat create mode 100644 .ci/scripts/windows/docker/run-services.bat diff --git a/.ci/scripts/windows/docker/log-services.bat b/.ci/scripts/windows/docker/log-services.bat new file mode 100644 index 0000000000..ec21c7f86c --- /dev/null +++ b/.ci/scripts/windows/docker/log-services.bat @@ -0,0 +1,8 @@ +docker ps -a +docker logs cassandra +docker logs elasticsearch +docker logs mongodb +docker logs mssql +docker logs mysql +docker logs postgres +docker logs redis diff --git a/.ci/scripts/windows/docker/run-services.bat b/.ci/scripts/windows/docker/run-services.bat new file mode 100644 index 0000000000..601a36d729 --- /dev/null +++ b/.ci/scripts/windows/docker/run-services.bat @@ -0,0 +1,15 @@ +docker build --tag cassandra cassandra/ +docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra +docker build --tag=elasticsearch elasticsearch/ +docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch +docker build --tag=mongodb mongodb/ +docker run -d -p 27017:27017 --name mongodb mongodb +docker build --tag=mssql mssql/ +docker run -d -p 1433:1433 -e sa_password='Very(!)Secure' -e ACCEPT_EULA=Y --name mssql mssql +docker build --tag=mysql mysql/ +docker run -d -p 3306:3306 --name mysql mysql +docker build --tag=postgres postgres/ +docker run -d -p 5432:5432 --name postgres postgres +docker build --tag=redis redis/ +docker run -d -p 6379:6379 --name redis redis +docker ps -a diff --git a/Jenkinsfile b/Jenkinsfile index 70f74b3744..23c4952b98 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -86,10 +86,9 @@ def generateStepForWindows(Map params = [:]){ unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - bat label: 'Run docker-compose', script: ''' - cd .ci/scripts/windows/docker - docker-compose --no-ansi up --build --detach - ''' + dir('.ci/scripts/windows/docker') { + bat label: 'Prepare services', script: 'run-services.bat' + } bat label: 'Tool versions', script: ''' npm --version node --version @@ -103,12 +102,8 @@ def generateStepForWindows(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - dir(BASE_DIR) { - bat label: 'Gather docker-compose logs', returnStatus: true, script: ''' - docker ps -a - cd .ci/scripts/windows/docker - docker-compose logs --no-color --timestamps - ''' + dir("${BASE_DIR}/.ci/scripts/windows/docker") { + bat label: 'Gather logs', returnStatus: true, script: 'log-services.bat' } } } From 99c3f12193b3af4df3056d1350e29165e31cf69e Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 16:45:14 +0100 Subject: [PATCH 067/117] ci(jenkins): override SA password --- .ci/scripts/windows/docker/docker-compose.yml | 2 +- .ci/scripts/windows/docker/run-services.bat | 2 +- Jenkinsfile | 1 + 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/.ci/scripts/windows/docker/docker-compose.yml b/.ci/scripts/windows/docker/docker-compose.yml index e5919e1bd5..a7ce865c90 100644 --- a/.ci/scripts/windows/docker/docker-compose.yml +++ b/.ci/scripts/windows/docker/docker-compose.yml @@ -44,7 +44,7 @@ services: dockerfile: Dockerfile environment: - ACCEPT_EULA=Y - - sa_password=Very(!)Secure + - sa_password=${SA_PASSWORD} ports: - "1433:1433" diff --git a/.ci/scripts/windows/docker/run-services.bat b/.ci/scripts/windows/docker/run-services.bat index 601a36d729..9c9013ca07 100644 --- a/.ci/scripts/windows/docker/run-services.bat +++ b/.ci/scripts/windows/docker/run-services.bat @@ -5,7 +5,7 @@ docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch docker build --tag=mongodb mongodb/ docker run -d -p 27017:27017 --name mongodb mongodb docker build --tag=mssql mssql/ -docker run -d -p 1433:1433 -e sa_password='Very(!)Secure' -e ACCEPT_EULA=Y --name mssql mssql +docker run -d -p 1433:1433 -e sa_password=%SA_PASSWORD% -e ACCEPT_EULA=Y --name mssql mssql docker build --tag=mysql mysql/ docker run -d -p 3306:3306 --name mysql mysql docker build --tag=postgres postgres/ diff --git a/Jenkinsfile b/Jenkinsfile index 23c4952b98..1b69fdd7f3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -82,6 +82,7 @@ def generateStepForWindows(Map params = [:]){ if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' } + env.SA_PASSWORD = 'password123_' deleteDir() unstash 'source' dir(BASE_DIR) { From 6be12a3efc5529c71b5beb3e260ab68b8b159e91 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 16:47:13 +0100 Subject: [PATCH 068/117] ci(jenkins): mysql warm up --- .ci/scripts/windows/docker/mysql/Dockerfile | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile index 909b0eacdc..d9c2758309 100644 --- a/.ci/scripts/windows/docker/mysql/Dockerfile +++ b/.ci/scripts/windows/docker/mysql/Dockerfile @@ -14,5 +14,7 @@ COPY my.ini . HEALTHCHECK CMD [ "mysql", "-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] +# Warm up might take a bit of time... so let's touch the log file +RUN type nul >> mysql.log # Keep running the container with the event logs in the stdout. CMD ["powershell", "Get-Content", "mysql.log", "-Wait"] From 1b7744b134a0896f9fa1713d099392f951bb20e2 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 17:41:23 +0100 Subject: [PATCH 069/117] ci(jenkins): change mysql warm up --- .ci/scripts/windows/docker/mysql/Dockerfile | 4 +--- .ci/scripts/windows/docker/mysql/my.ini | 2 +- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile index d9c2758309..62fac3e647 100644 --- a/.ci/scripts/windows/docker/mysql/Dockerfile +++ b/.ci/scripts/windows/docker/mysql/Dockerfile @@ -14,7 +14,5 @@ COPY my.ini . HEALTHCHECK CMD [ "mysql", "-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] -# Warm up might take a bit of time... so let's touch the log file -RUN type nul >> mysql.log # Keep running the container with the event logs in the stdout. -CMD ["powershell", "Get-Content", "mysql.log", "-Wait"] +CMD ["powershell", "Get-Content", "C:\\mysql.log", "-Wait"] diff --git a/.ci/scripts/windows/docker/mysql/my.ini b/.ci/scripts/windows/docker/mysql/my.ini index b26af85c90..2ec753e155 100644 --- a/.ci/scripts/windows/docker/mysql/my.ini +++ b/.ci/scripts/windows/docker/mysql/my.ini @@ -1,5 +1,5 @@ [mysqld] basedir=C:\\tools\\mysql\\current datadir=C:\\ProgramData\\MySQL\\data -log_error=C:\\tools\\mysql\\current\\error.log +log_error=C:\\mysql.log log_error_verbosity=3 From e54cd4e8120ff9bc861a4bf7bb8960bc0d1047d7 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 17:50:12 +0100 Subject: [PATCH 070/117] ci(jenkins): tweak java memalloc --- .ci/scripts/windows/docker/cassandra/Dockerfile | 1 + .ci/scripts/windows/docker/docker-compose.yml | 3 --- .ci/scripts/windows/docker/elasticsearch/Dockerfile | 2 +- 3 files changed, 2 insertions(+), 4 deletions(-) diff --git a/.ci/scripts/windows/docker/cassandra/Dockerfile b/.ci/scripts/windows/docker/cassandra/Dockerfile index 4fae0ecf6b..768a84f01e 100644 --- a/.ci/scripts/windows/docker/cassandra/Dockerfile +++ b/.ci/scripts/windows/docker/cassandra/Dockerfile @@ -21,6 +21,7 @@ RUN Write-Host "Downloading: ${env:ROOT_URL}/${env:VERSION}/apache-cassandra-${e FROM openjdk:8-windowsservercore-1809 ENV CASSANDRA_HOME="C:\cassandra" ENV VERSION="3.11.3" +ENV JAVA_OPTS="-Xms256m -Xmx1024m" WORKDIR $CASSANDRA_HOME COPY --from=installer ${CASSANDRA_HOME}\apache-cassandra-${VERSION}\ . COPY cassandra.yaml .\conf\cassandra.yaml diff --git a/.ci/scripts/windows/docker/docker-compose.yml b/.ci/scripts/windows/docker/docker-compose.yml index a7ce865c90..3e9a7f6d1e 100644 --- a/.ci/scripts/windows/docker/docker-compose.yml +++ b/.ci/scripts/windows/docker/docker-compose.yml @@ -5,9 +5,6 @@ services: build: context: cassandra dockerfile: Dockerfile - environment: - MAX_HEAP_SIZE: "1G" - HEAP_NEWSIZE: 400m ports: - "9042:9042" - "7000:7000" diff --git a/.ci/scripts/windows/docker/elasticsearch/Dockerfile b/.ci/scripts/windows/docker/elasticsearch/Dockerfile index 5b1eb3b392..2104910250 100644 --- a/.ci/scripts/windows/docker/elasticsearch/Dockerfile +++ b/.ci/scripts/windows/docker/elasticsearch/Dockerfile @@ -21,7 +21,7 @@ SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop';"] ARG ES_VERSION="6.7.2" ENV ES_VERSION=${ES_VERSION} ` ES_HOME="C:\elasticsearch" ` - ES_JAVA_OPTS="-Xms1024m -Xmx1024m" + ES_JAVA_OPTS="-Xms512m -Xmx512m" VOLUME C:\data EXPOSE 9200 9300 From d38a6a5bfd7177b7f882f361b939ad07c550a695 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Wed, 9 Oct 2019 22:13:39 +0100 Subject: [PATCH 071/117] ci(jenkins): bind mysql --- .ci/scripts/windows/docker/mysql/my.ini | 2 ++ .ci/scripts/windows/docker/run-services.bat | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.ci/scripts/windows/docker/mysql/my.ini b/.ci/scripts/windows/docker/mysql/my.ini index 2ec753e155..6144f516ca 100644 --- a/.ci/scripts/windows/docker/mysql/my.ini +++ b/.ci/scripts/windows/docker/mysql/my.ini @@ -3,3 +3,5 @@ basedir=C:\\tools\\mysql\\current datadir=C:\\ProgramData\\MySQL\\data log_error=C:\\mysql.log log_error_verbosity=3 +bind-address=0.0.0.0 +skip-networking diff --git a/.ci/scripts/windows/docker/run-services.bat b/.ci/scripts/windows/docker/run-services.bat index 9c9013ca07..b1609ce63b 100644 --- a/.ci/scripts/windows/docker/run-services.bat +++ b/.ci/scripts/windows/docker/run-services.bat @@ -7,7 +7,7 @@ docker run -d -p 27017:27017 --name mongodb mongodb docker build --tag=mssql mssql/ docker run -d -p 1433:1433 -e sa_password=%SA_PASSWORD% -e ACCEPT_EULA=Y --name mssql mssql docker build --tag=mysql mysql/ -docker run -d -p 3306:3306 --name mysql mysql +docker run -d -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=1 --name mysql mysql docker build --tag=postgres postgres/ docker run -d -p 5432:5432 --name postgres postgres docker build --tag=redis redis/ From 782a76b56779385bb1e184aedb705749af1c0f2d Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 10 Oct 2019 17:01:06 +0100 Subject: [PATCH 072/117] ci(jenkins): enable remote mysql access --- .ci/scripts/windows/docker/mysql/Dockerfile | 4 ++-- .ci/scripts/windows/docker/mysql/entrypoint.ps1 | 14 ++++++++++++++ .ci/scripts/windows/docker/mysql/my.ini | 1 - 3 files changed, 16 insertions(+), 3 deletions(-) create mode 100644 .ci/scripts/windows/docker/mysql/entrypoint.ps1 diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile index 62fac3e647..a8b46f93b7 100644 --- a/.ci/scripts/windows/docker/mysql/Dockerfile +++ b/.ci/scripts/windows/docker/mysql/Dockerfile @@ -14,5 +14,5 @@ COPY my.ini . HEALTHCHECK CMD [ "mysql", "-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] -# Keep running the container with the event logs in the stdout. -CMD ["powershell", "Get-Content", "C:\\mysql.log", "-Wait"] +COPY entrypoint.ps1 . +CMD .\entrypoint diff --git a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 new file mode 100644 index 0000000000..45db99a11d --- /dev/null +++ b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 @@ -0,0 +1,14 @@ +Write-Host "Wait a few seconds until the mysql is ready..." +sleep 15 +Write-Host "List current users..." +mysql -h 127.0.0.1 -P 3306 -u root -e "select user,host from mysql.user;" +Write-Host "Create users for remote access..." +mysql -h 127.0.0.1 -P 3306 -u root -e @" + CREATE USER root@'%'; + GRANT ALL PRIVILEGES ON *.* TO root@'%'; +"@ +mysql -h 127.0.0.1 -P 3306 -u root -e "select user,host from mysql.user;" + +Write-Host "Show mysql log output in the console..." +# Keep running the container with the event logs in the stdout. +Get-Content C:\\mysql.log -Wait diff --git a/.ci/scripts/windows/docker/mysql/my.ini b/.ci/scripts/windows/docker/mysql/my.ini index 6144f516ca..6350ec92f5 100644 --- a/.ci/scripts/windows/docker/mysql/my.ini +++ b/.ci/scripts/windows/docker/mysql/my.ini @@ -4,4 +4,3 @@ datadir=C:\\ProgramData\\MySQL\\data log_error=C:\\mysql.log log_error_verbosity=3 bind-address=0.0.0.0 -skip-networking From aa6b82d5dd52623d0cb8641b57aa4b0e0f7ac4b4 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 10 Oct 2019 18:41:19 +0100 Subject: [PATCH 073/117] ci(jenkins): mysql user elastic for windows --- .ci/scripts/windows/docker/mysql/entrypoint.ps1 | 10 ++++------ Jenkinsfile | 2 ++ 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 index 45db99a11d..2bc28c6444 100644 --- a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 +++ b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 @@ -1,14 +1,12 @@ Write-Host "Wait a few seconds until the mysql is ready..." sleep 15 -Write-Host "List current users..." -mysql -h 127.0.0.1 -P 3306 -u root -e "select user,host from mysql.user;" Write-Host "Create users for remote access..." mysql -h 127.0.0.1 -P 3306 -u root -e @" - CREATE USER root@'%'; - GRANT ALL PRIVILEGES ON *.* TO root@'%'; + SELECT user,host FROM mysql.user; + CREATE USER 'elastic'@'%' IDENTIFIED WITH mysql_native_password BY 'password123_'; + GRANT ALL PRIVILEGES ON *.* TO elastic@'%'; + SELECT user,host FROM mysql.user; "@ -mysql -h 127.0.0.1 -P 3306 -u root -e "select user,host from mysql.user;" - Write-Host "Show mysql log output in the console..." # Keep running the container with the event logs in the stdout. Get-Content C:\\mysql.log -Wait diff --git a/Jenkinsfile b/Jenkinsfile index 1b69fdd7f3..a5d8269d8c 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -83,6 +83,8 @@ def generateStepForWindows(Map params = [:]){ env.ELASTIC_APM_ASYNC_HOOKS = 'false' } env.SA_PASSWORD = 'password123_' + env.MYSQL_USER = 'elastic' + env.MYSQL_PASSWORD = 'password123_' deleteDir() unstash 'source' dir(BASE_DIR) { From 44a76282a97565cf58a89781a70419caf5370202 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 10 Oct 2019 19:19:37 +0100 Subject: [PATCH 074/117] ci(jenkins): postgres remote access --- .ci/scripts/windows/docker/postgres/Dockerfile | 5 +++-- .ci/scripts/windows/docker/postgres/entrypoint.ps1 | 8 ++++++++ .ci/scripts/windows/docker/postgres/pg_hba.conf | 10 ++++++++++ 3 files changed, 21 insertions(+), 2 deletions(-) create mode 100644 .ci/scripts/windows/docker/postgres/entrypoint.ps1 create mode 100644 .ci/scripts/windows/docker/postgres/pg_hba.conf diff --git a/.ci/scripts/windows/docker/postgres/Dockerfile b/.ci/scripts/windows/docker/postgres/Dockerfile index 088aa20076..c4fd66e6f2 100644 --- a/.ci/scripts/windows/docker/postgres/Dockerfile +++ b/.ci/scripts/windows/docker/postgres/Dockerfile @@ -12,6 +12,7 @@ RUN choco install postgresql10 --version=${env:VERSION} --params '/Password:Pass EXPOSE 5432 COPY postgresql.conf . +COPY pg_hba.conf . +COPY entrypoint.ps1 . -# Keep running the container with the event logs in the stdout. -CMD ["powershell", "Get-Content", "log/postgresql.log", "-Wait"] +CMD .\entrypoint diff --git a/.ci/scripts/windows/docker/postgres/entrypoint.ps1 b/.ci/scripts/windows/docker/postgres/entrypoint.ps1 new file mode 100644 index 0000000000..008549acc7 --- /dev/null +++ b/.ci/scripts/windows/docker/postgres/entrypoint.ps1 @@ -0,0 +1,8 @@ +Write-Host "Wait a few seconds until the postgres is ready..." +sleep 5 +Write-Host "Create users for remote access..." +psql -U postgres -c "CREATE ROLE jenkins WITH LOGIN SUPERUSER INHERIT CREATEDB CREATEROLE REPLICATION;" + +Write-Host "Show postgres log output in the console..." +# Keep running the container with the event logs in the stdout. +Get-Content log/postgresql.log -Wait diff --git a/.ci/scripts/windows/docker/postgres/pg_hba.conf b/.ci/scripts/windows/docker/postgres/pg_hba.conf new file mode 100644 index 0000000000..0959bf3165 --- /dev/null +++ b/.ci/scripts/windows/docker/postgres/pg_hba.conf @@ -0,0 +1,10 @@ +# PostgreSQL Client Authentication Configuration File +# =================================================== +# + +# TYPE DATABASE USER CIDR-ADDRESS METHOD +host all all 0.0.0.0/0 trust +# IPv4 local connections: +host all all 127.0.0.1/32 trust +# IPv6 local connections: +host all all ::1/128 trust From d7ddb6264995558dad0f89bbb94a6b06b6b1bc3a Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Thu, 10 Oct 2019 20:12:57 +0100 Subject: [PATCH 075/117] ci(jenkins): linux docker unsupported --- .ci/docker/docker-compose-wait.yml | 68 ------------------------------ .ci/scripts/run-services.sh | 12 ------ .ci/scripts/stop-services.sh | 18 -------- 3 files changed, 98 deletions(-) delete mode 100644 .ci/docker/docker-compose-wait.yml delete mode 100755 .ci/scripts/run-services.sh delete mode 100755 .ci/scripts/stop-services.sh diff --git a/.ci/docker/docker-compose-wait.yml b/.ci/docker/docker-compose-wait.yml deleted file mode 100644 index d62d19c313..0000000000 --- a/.ci/docker/docker-compose-wait.yml +++ /dev/null @@ -1,68 +0,0 @@ -version: '2.1' - -services: - cassandra: - extends: - file: docker-compose.yml - service: cassandra - elasticsearch: - extends: - file: docker-compose.yml - service: elasticsearch - memcached: - extends: - file: docker-compose.yml - service: memcached - mongodb: - extends: - file: docker-compose.yml - service: mongodb - mssql: - extends: - file: docker-compose.yml - service: mssql - mysql: - extends: - file: docker-compose.yml - service: mysql - postgres: - extends: - file: docker-compose.yml - service: postgres - redis: - extends: - file: docker-compose.yml - service: redis - wait: - image: busybox - depends_on: - cassandra: - condition: service_healthy - elasticsearch: - condition: service_healthy - memcached: - condition: service_healthy - mongodb: - condition: service_healthy - mssql: - condition: service_healthy - mysql: - condition: service_healthy - postgres: - condition: service_healthy - redis: - condition: service_healthy - -volumes: - nodepgdata: - driver: local - nodemongodata: - driver: local - nodemssqldata: - driver: local - nodemysqldata: - driver: local - nodeesdata: - driver: local - nodecassandradata: - driver: local diff --git a/.ci/scripts/run-services.sh b/.ci/scripts/run-services.sh deleted file mode 100755 index 19c94d1d19..0000000000 --- a/.ci/scripts/run-services.sh +++ /dev/null @@ -1,12 +0,0 @@ -#!/usr/bin/env bash -set -exo pipefail - -USER_ID="$(id -u):$(id -g)" \ -docker-compose \ - --no-ansi \ - --log-level ERROR \ - --file .ci/docker/docker-compose-wait.yml \ - up \ - --build \ - --remove-orphans \ - --detach diff --git a/.ci/scripts/stop-services.sh b/.ci/scripts/stop-services.sh deleted file mode 100755 index 55fe60f362..0000000000 --- a/.ci/scripts/stop-services.sh +++ /dev/null @@ -1,18 +0,0 @@ -#!/usr/bin/env bash -set -exo pipefail - -docker-compose \ - --no-ansi \ - --log-level ERROR \ - --file .ci/docker/docker-compose-wait.yml \ - logs \ - --timestamps \ - --tail=100 - -docker-compose \ - --no-ansi \ - --log-level ERROR \ - --file .ci/docker/docker-compose-wait.yml \ - down \ - --volumes \ - --remove-orphans From e599c75cb1e71d5d54542e4d7b14a9ae68b97629 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 11:05:21 +0100 Subject: [PATCH 076/117] ci(jenkins): docker-compose unused --- .ci/scripts/windows/docker/docker-compose.yml | 84 ------------------- 1 file changed, 84 deletions(-) delete mode 100644 .ci/scripts/windows/docker/docker-compose.yml diff --git a/.ci/scripts/windows/docker/docker-compose.yml b/.ci/scripts/windows/docker/docker-compose.yml deleted file mode 100644 index 3e9a7f6d1e..0000000000 --- a/.ci/scripts/windows/docker/docker-compose.yml +++ /dev/null @@ -1,84 +0,0 @@ -version: '2.1' - -services: - cassandra: - build: - context: cassandra - dockerfile: Dockerfile - ports: - - "9042:9042" - - "7000:7000" - - elasticsearch: - build: - context: elasticsearch - dockerfile: Dockerfile - environment: - - "ES_JAVA_OPTS=-Xms512m -Xmx512m" - - "network.host=" - - "transport.host=127.0.0.1" - - "http.host=0.0.0.0" - - "xpack.security.enabled=false" - ports: - - "9200:9200" - - "9230:9300" - - mongodb: - build: - context: mongodb - dockerfile: Dockerfile - ports: - - "27017:27017" - healthcheck: - test: ["CMD", "mongo", "--quiet"] - interval: 1s - timeout: 10s - retries: 30 - - mssql: - build: - context: mssql - dockerfile: Dockerfile - environment: - - ACCEPT_EULA=Y - - sa_password=${SA_PASSWORD} - ports: - - "1433:1433" - - mysql: - build: - context: mysql - dockerfile: Dockerfile - environment: - MYSQL_ALLOW_EMPTY_PASSWORD: 1 - ports: - - "3306:3306" - healthcheck: - test: ["CMD", "mysql" ,"-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] - interval: 1s - timeout: 10s - retries: 30 - - postgres: - build: - context: postgres - dockerfile: Dockerfile - ports: - - "5432:5432" - healthcheck: - test: ["CMD", "pg_isready"] - interval: 1s - timeout: 10s - retries: 30 - - redis: - build: - context: redis - dockerfile: Dockerfile - ports: - - "6379:6379" - healthcheck: - test: ["CMD", "redis-cli", "ping"] - interval: 1s - timeout: 10s - retries: 30 From 04842114df89336813a7eb10111159622bbb6459 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 11:11:19 +0100 Subject: [PATCH 077/117] ci(jenkins): passwords env var --- .ci/scripts/windows/docker/mysql/Dockerfile | 2 ++ .ci/scripts/windows/docker/mysql/entrypoint.ps1 | 4 ++-- .ci/scripts/windows/docker/run-services.bat | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile index a8b46f93b7..e1e20357d4 100644 --- a/.ci/scripts/windows/docker/mysql/Dockerfile +++ b/.ci/scripts/windows/docker/mysql/Dockerfile @@ -6,6 +6,8 @@ RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Ne ARG VERSION="8.0.17" ENV MYSQL_HOME="C:\tools\mysql\current" +ENV MYSQL_USER="elastic" +ENV MYSQL_PASSWORD="password123_" RUN choco install mysql --version=${env:VERSION} --no-progress -y EXPOSE 3306 diff --git a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 index 2bc28c6444..218f45514f 100644 --- a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 +++ b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 @@ -3,8 +3,8 @@ sleep 15 Write-Host "Create users for remote access..." mysql -h 127.0.0.1 -P 3306 -u root -e @" SELECT user,host FROM mysql.user; - CREATE USER 'elastic'@'%' IDENTIFIED WITH mysql_native_password BY 'password123_'; - GRANT ALL PRIVILEGES ON *.* TO elastic@'%'; + CREATE USER '$env:MYSQL_USER'@'%' IDENTIFIED WITH mysql_native_password BY '$env:MYSQL_PASSWORD'; + GRANT ALL PRIVILEGES ON *.* TO $env:MYSQL_USER@'%'; SELECT user,host FROM mysql.user; "@ Write-Host "Show mysql log output in the console..." diff --git a/.ci/scripts/windows/docker/run-services.bat b/.ci/scripts/windows/docker/run-services.bat index b1609ce63b..521e9b72dc 100644 --- a/.ci/scripts/windows/docker/run-services.bat +++ b/.ci/scripts/windows/docker/run-services.bat @@ -7,7 +7,7 @@ docker run -d -p 27017:27017 --name mongodb mongodb docker build --tag=mssql mssql/ docker run -d -p 1433:1433 -e sa_password=%SA_PASSWORD% -e ACCEPT_EULA=Y --name mssql mssql docker build --tag=mysql mysql/ -docker run -d -p 3306:3306 -e MYSQL_ALLOW_EMPTY_PASSWORD=1 --name mysql mysql +docker run -d -p 3306:3306 -e MYSQL_USER=%MYSQL_USER% -e MYSQL_PASSWORD=%MYSQL_PASSWORD% --name mysql mysql docker build --tag=postgres postgres/ docker run -d -p 5432:5432 --name postgres postgres docker build --tag=redis redis/ From e42d4b4c03858c7c4d377c4c1625f03a6bd5698a Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 11:13:46 +0100 Subject: [PATCH 078/117] Revert "chore: testing purposes" This reverts commit a82931b50ad92e7e3c971e957de3178ee64e5848. --- Jenkinsfile | 355 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 355 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index a5d8269d8c..9984950dcc 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -23,9 +23,15 @@ pipeline { rateLimitBuilds(throttle: [count: 60, durationName: 'hour', userBoost: true]) quietPeriod(10) } + triggers { + issueCommentTrigger('(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?(?:module\\W+)?tests(?:\\W+please)?.*') + } parameters { booleanParam(name: 'Run_As_Master_Branch', defaultValue: false, description: 'Allow to run any steps on a PR, some steps normally only run on master branch.') + booleanParam(name: 'bench_ci', defaultValue: true, description: 'Enable benchmarks.') + booleanParam(name: 'tav_ci', defaultValue: true, description: 'Enable TAV tests.') booleanParam(name: 'tests_ci', defaultValue: true, description: 'Enable tests.') + booleanParam(name: 'test_edge_ci', defaultValue: true, description: 'Enable tests for edge versions of nodejs.') } stages { /** @@ -37,6 +43,15 @@ pipeline { deleteDir() gitCheckout(basedir: "${BASE_DIR}", githubNotifyFirstTimeContributor: true) stash allowEmpty: true, name: 'source', useDefaultExcludes: false + script { + dir("${BASE_DIR}"){ + def regexps =[ + "^lib/instrumentation/modules/", + "^test/instrumentation/modules/" + ] + env.TAV_UPDATED = isGitRegionMatch(regexps: regexps) + } + } } } /** @@ -59,13 +74,353 @@ pipeline { script { def node = readYaml(file: '.ci/.jenkins_nodejs.yml') def parallelTasks = [:] + def parallelTasksWithoutAsyncHooks = [:] + node['NODEJS_VERSION'].each{ version -> + parallelTasks["Node.js-${version}"] = generateStep(version: version) + parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) + // TODO: to be enabled if required. + // parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) + } + + // Only 12 for the time being parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') + + // PRs don't require to run here as it's now managed within the linting pipeline + if (!env.CHANGE_ID) { + // Linting in parallel with the test stage + parallelTasks['linting'] = linting() + } + parallel(parallelTasks) } } } } } + /** + Run TAV tests. + */ + stage('TAV Test') { + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + } + when { + beforeAgent true + allOf { + not { + branch '^greenkeeper/.*' + } + anyOf { + expression { return params.Run_As_Master_Branch } + triggeredBy 'TimerTrigger' + changeRequest() + expression { return env.TAV_UPDATED != "false" } + } + expression { return params.tav_ci } + } + } + steps { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def tavContext = getSmartTAVContext() + withGithubNotify(context: tavContext.ghContextName, description: tavContext.ghDescription, tab: 'tests') { + def parallelTasks = [:] + tavContext.node['NODEJS_VERSION'].each{ version -> + tavContext.tav['TAV'].each{ tav_item -> + parallelTasks["Node.js-${version}-${tav_item}"] = generateStep(version: version, tav: tav_item) + } + } + parallel(parallelTasks) + } + } + } + } + } + /** + Run Edge tests. + */ + stage('Edge Test') { + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + } + when { + beforeAgent true + allOf { + anyOf { + expression { return params.Run_As_Master_Branch } + triggeredBy 'TimerTrigger' + } + expression { return params.test_edge_ci } + } + } + parallel { + stage('Nightly Test') { + agent { label 'linux && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" + } + steps { + withGithubNotify(context: 'Nightly Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-nightly"] = generateStep(version: version, edge: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('Nightly Test - No async hooks') { + agent { label 'linux && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/nightly/" + } + steps { + withGithubNotify(context: 'Nightly No Async Hooks Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_nightly_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-nightly-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('RC Test') { + agent { label 'linux && immutablee' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" + } + steps { + withGithubNotify(context: 'RC Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-rc"] = generateStep(version: version, edge: true) + } + parallel(parallelTasks) + } + } + } + } + } + stage('RC Test - No async hooks') { + agent { label 'linux && immutable' } + environment { + NVM_NODEJS_ORG_MIRROR = "https://nodejs.org/download/rc/" + } + steps { + withGithubNotify(context: 'RC No Async Hooks Test', tab: 'tests') { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + script { + def node = readYaml(file: '.ci/.jenkins_rc_nodejs.yml') + def parallelTasks = [:] + node['NODEJS_VERSION'].each { version -> + parallelTasks["Node.js-${version}-rc-no-async-hooks"] = generateStep(version: version, edge: true, disableAsyncHooks: true) + } + parallel(parallelTasks) + } + } + } + } + } + } + } + stage('Integration Tests') { + agent none + when { + beforeAgent true + allOf { + anyOf { + environment name: 'GIT_BUILD_CAUSE', value: 'pr' + expression { return !params.Run_As_Master_Branch } + } + } + } + steps { + log(level: 'INFO', text: 'Launching Async ITs') + build(job: env.ITS_PIPELINE, propagate: false, wait: false, + parameters: [string(name: 'AGENT_INTEGRATION_TEST', value: 'Node.js'), + string(name: 'BUILD_OPTS', value: "--nodejs-agent-package ${env.CHANGE_FORK?.trim() ?: 'elastic' }/${env.REPO}#${env.GIT_BASE_COMMIT}"), + string(name: 'GITHUB_CHECK_NAME', value: env.GITHUB_CHECK_ITS_NAME), + string(name: 'GITHUB_CHECK_REPO', value: env.REPO), + string(name: 'GITHUB_CHECK_SHA1', value: env.GIT_BASE_COMMIT)]) + githubNotify(context: "${env.GITHUB_CHECK_ITS_NAME}", description: "${env.GITHUB_CHECK_ITS_NAME} ...", status: 'PENDING', targetUrl: "${env.JENKINS_URL}search/?q=${env.ITS_PIPELINE.replaceAll('/','+')}") + } + } + /** + Run the benchmarks and store the results on ES. + The result JSON files are also archive into Jenkins. + */ + stage('Benchmarks') { + agent { label 'metal' } + options { skipDefaultCheckout() } + environment { + HOME = "${env.WORKSPACE}" + RESULT_FILE = 'apm-agent-benchmark-results.json' + NODE_VERSION = '12' + } + when { + beforeAgent true + allOf { + anyOf { + branch 'master' + tag pattern: 'v\\d+\\.\\d+\\.\\d+.*', comparator: 'REGEXP' + expression { return params.Run_As_Master_Branch } + } + expression { return params.bench_ci } + } + } + steps { + withGithubNotify(context: 'Benchmarks', tab: 'artifacts') { + dir(env.BUILD_NUMBER) { + deleteDir() + unstash 'source' + dir(BASE_DIR){ + sh '.ci/scripts/run-benchmarks.sh "${RESULT_FILE}"' + } + } + } + } + post { + always { + catchError(message: 'sendBenchmarks failed', buildResult: 'FAILURE') { + sendBenchmarks(file: "${BUILD_NUMBER}/${BASE_DIR}/${RESULT_FILE}", + index: 'benchmark-nodejs', archive: true) + } + catchError(message: 'deleteDir failed', buildResult: 'SUCCESS', stageResult: 'UNSTABLE') { + deleteDir() + } + } + } + } + } + post { + cleanup { + notifyBuildResult() + } + } +} + +def generateStep(Map params = [:]){ + def version = params?.version + def tav = params.containsKey('tav') ? params.tav : '' + def edge = params.containsKey('edge') ? params.edge : false + def disableAsyncHooks = params.get('disableAsyncHooks', false) + return { + node('linux && immutable'){ + try { + env.HOME = "${WORKSPACE}" + if (disableAsyncHooks) { + env.ELASTIC_APM_ASYNC_HOOKS = 'false' + } + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + retry(2){ + sleep randomNumber(min:10, max: 30) + sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + } + } + } catch(e){ + error(e.toString()) + } finally { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") + } + } + } +} + +/** +* Gather the TAV context for the current execution. Then the TAV stage will execute +* the TAV using a smarter approach. +*/ +def getSmartTAVContext() { + context = [:] + context.ghContextName = 'TAV Test' + context.ghDescription = context.ghContextName + context.node = readYaml(file: '.ci/.jenkins_tav_nodejs.yml') + + // Hard to debug what's going on as there are a few nested conditions. Let's then add more verbose output + echo """\ + env.GITHUB_COMMENT=${env.GITHUB_COMMENT} + params.Run_As_Master_Branch=${params.Run_As_Master_Branch} + env.CHANGE_ID=${env.CHANGE_ID} + env.TAV_UPDATED=${env.TAV_UPDATED}""".stripIndent() + + if (env.GITHUB_COMMENT) { + def modules = getModulesFromCommentTrigger(regex: '(?i).*(?:jenkins\\W+)?run\\W+(?:the\\W+)?module\\W+tests\\W+for\\W+(.+)') + if (modules.isEmpty()) { + context.ghDescription = 'TAV Test disabled' + context.tav = readYaml(text: 'TAV:') + context.node = readYaml(text: 'NODEJS_VERSION:') + } else { + if (modules.find{ it == 'ALL' }) { + context.tav = readYaml(file: '.ci/.jenkins_tav.yml') + } else { + context.ghContextName = 'TAV Test Subset' + context.ghDescription = 'TAV Test comment-triggered' + context.tav = readYaml(text: """TAV:${modules.collect{ it.replaceAll('"', '').replaceAll("'", '') }.collect{ "\n - '${it}'"}.join("") }""") + } + } + } else if (params.Run_As_Master_Branch) { + context.ghDescription = 'TAV Test param-triggered' + context.tav = readYaml(file: '.ci/.jenkins_tav.yml') + } else if (env.CHANGE_ID && env.TAV_UPDATED != "false") { + context.ghContextName = 'TAV Test Subset' + context.ghDescription = 'TAV Test changes-triggered' + sh '.ci/scripts/get_tav.sh .ci/.jenkins_generated_tav.yml' + context.tav = readYaml(file: '.ci/.jenkins_generated_tav.yml') + } else { + context.ghDescription = 'TAV Test disabled' + context.tav = readYaml(text: 'TAV:') + context.node = readYaml(text: 'NODEJS_VERSION:') + } + return context + } + + def linting(){ + return { + node('linux && immutable') { + catchError(stageResult: 'UNSTABLE', message: 'Linting failures') { + withGithubNotify(context: 'Linting') { + deleteDir() + unstash 'source' + script { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: 'Basic tests I', script: 'cd /app && .ci/scripts/test_basic.sh') + sh(label: 'Basic tests II', script: 'cd /app && .ci/scripts/test_types_babel_esm.sh') + } + } + } + } + } } } From 8d49a9fc936d1321aab6e9377cfd5a10b742bb7b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 20:19:05 +0100 Subject: [PATCH 079/117] ci(jenkins): gather env details --- Jenkinsfile | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Jenkinsfile b/Jenkinsfile index 9984950dcc..3c15072c8a 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -347,6 +347,9 @@ def generateStep(Map params = [:]){ } catch(e){ error(e.toString()) } finally { + sh label: 'Environment', script: 'env | sort' + sh label: 'Gather node:12', script: 'docker pull node:12' + sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From 23558e60a6980113298c63cc5a1021e328142752 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 20:35:49 +0100 Subject: [PATCH 080/117] ci(jenkins): if windows --- Jenkinsfile | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 3c15072c8a..0c13c2d830 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -347,9 +347,13 @@ def generateStep(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - sh label: 'Environment', script: 'env | sort' - sh label: 'Gather node:12', script: 'docker pull node:12' - sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' + if (isUnix()) { + sh label: 'Environment', script: 'env | sort' + sh label: 'Gather node:12', script: 'docker pull node:12' + sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' + } else { + bat 'set' + } docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From af7a21580104775d851495fc3dc28451496ba7bb Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 20:56:40 +0100 Subject: [PATCH 081/117] ci(jenkins): sh before the finally --- Jenkinsfile | 1 + 1 file changed, 1 insertion(+) diff --git a/Jenkinsfile b/Jenkinsfile index 0c13c2d830..aba76481b3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -344,6 +344,7 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } + sh label: 'Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { From 94931b61f7a54e273fdaa8d325f35b6dcbc05049 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 21:17:38 +0100 Subject: [PATCH 082/117] ci(jenkins): more debug --- Jenkinsfile | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index aba76481b3..772abecfb3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -332,6 +332,7 @@ def generateStep(Map params = [:]){ return { node('linux && immutable'){ try { + sh label: 'Pre-Environment', script: 'env | sort' env.HOME = "${WORKSPACE}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -344,12 +345,12 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } - sh label: 'Environment', script: 'env | sort' + sh label: 'Post-Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { if (isUnix()) { - sh label: 'Environment', script: 'env | sort' + sh label: 'Finally-Environment', script: 'env | sort' sh label: 'Gather node:12', script: 'docker pull node:12' sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' } else { From ea7c4cfa3c83a4c33aa258f9ef8b8be35308753e Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 21:47:54 +0100 Subject: [PATCH 083/117] ci(jenkins): enforce PATH --- Jenkinsfile | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 772abecfb3..fa2284f37b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -332,7 +332,6 @@ def generateStep(Map params = [:]){ return { node('linux && immutable'){ try { - sh label: 'Pre-Environment', script: 'env | sort' env.HOME = "${WORKSPACE}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -345,22 +344,16 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } - sh label: 'Post-Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { - if (isUnix()) { - sh label: 'Finally-Environment', script: 'env | sort' - sh label: 'Gather node:12', script: 'docker pull node:12' - sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' - } else { - bat 'set' - } - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") - codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") } } } From 0a1d38e942646d12248d37d6c78308dcc6ecff2c Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Fri, 11 Oct 2019 22:27:17 +0100 Subject: [PATCH 084/117] ci(jenkins): use withEnv toplevel --- Jenkinsfile | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index fa2284f37b..4cc93bc47e 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -331,23 +331,23 @@ def generateStep(Map params = [:]){ def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('linux && immutable'){ - try { - env.HOME = "${WORKSPACE}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - retry(2){ - sleep randomNumber(min:10, max: 30) - sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { + try { + env.HOME = "${WORKSPACE}" + if (disableAsyncHooks) { + env.ELASTIC_APM_ASYNC_HOOKS = 'false' } - } - } catch(e){ - error(e.toString()) - } finally { - withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + retry(2){ + sleep randomNumber(min:10, max: 30) + sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + } + } + } catch(e){ + error(e.toString()) + } finally { docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From 8bb0493d12c81dc7e55c0fa40e5d51c49dd35eb6 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 09:57:15 +0100 Subject: [PATCH 085/117] Revert "ci(jenkins): use withEnv toplevel" This reverts commit 0a1d38e942646d12248d37d6c78308dcc6ecff2c. --- Jenkinsfile | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 4cc93bc47e..fa2284f37b 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -331,23 +331,23 @@ def generateStep(Map params = [:]){ def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('linux && immutable'){ - withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { - try { - env.HOME = "${WORKSPACE}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - retry(2){ - sleep randomNumber(min:10, max: 30) - sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) - } + try { + env.HOME = "${WORKSPACE}" + if (disableAsyncHooks) { + env.ELASTIC_APM_ASYNC_HOOKS = 'false' + } + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + retry(2){ + sleep randomNumber(min:10, max: 30) + sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } - } catch(e){ - error(e.toString()) - } finally { + } + } catch(e){ + error(e.toString()) + } finally { + withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From 8a3d00cceea727e787a3186929f5f0f29834b94f Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:00:28 +0100 Subject: [PATCH 086/117] Revert "ci(jenkins): enforce PATH" This reverts commit ea7c4cfa3c83a4c33aa258f9ef8b8be35308753e. --- Jenkinsfile | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index fa2284f37b..772abecfb3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -332,6 +332,7 @@ def generateStep(Map params = [:]){ return { node('linux && immutable'){ try { + sh label: 'Pre-Environment', script: 'env | sort' env.HOME = "${WORKSPACE}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -344,16 +345,22 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } + sh label: 'Post-Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { - withEnv(["PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin"]) { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") - codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") + if (isUnix()) { + sh label: 'Finally-Environment', script: 'env | sort' + sh label: 'Gather node:12', script: 'docker pull node:12' + sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' + } else { + bat 'set' + } + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") } } } From 4fbcf03600f4da760b30857295b783eef9528681 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:00:51 +0100 Subject: [PATCH 087/117] Revert "ci(jenkins): more debug" This reverts commit 94931b61f7a54e273fdaa8d325f35b6dcbc05049. --- Jenkinsfile | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 772abecfb3..aba76481b3 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -332,7 +332,6 @@ def generateStep(Map params = [:]){ return { node('linux && immutable'){ try { - sh label: 'Pre-Environment', script: 'env | sort' env.HOME = "${WORKSPACE}" if (disableAsyncHooks) { env.ELASTIC_APM_ASYNC_HOOKS = 'false' @@ -345,12 +344,12 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } - sh label: 'Post-Environment', script: 'env | sort' + sh label: 'Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { if (isUnix()) { - sh label: 'Finally-Environment', script: 'env | sort' + sh label: 'Environment', script: 'env | sort' sh label: 'Gather node:12', script: 'docker pull node:12' sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' } else { From 5ab6c83863509c1d347dc33f74045830435b0783 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:02:14 +0100 Subject: [PATCH 088/117] Revert "ci(jenkins): sh before the finally" This reverts commit af7a21580104775d851495fc3dc28451496ba7bb. --- Jenkinsfile | 1 - 1 file changed, 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index aba76481b3..0c13c2d830 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -344,7 +344,6 @@ def generateStep(Map params = [:]){ sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) } } - sh label: 'Environment', script: 'env | sort' } catch(e){ error(e.toString()) } finally { From b032aec9771df51008eeee428105d3993237a026 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:02:26 +0100 Subject: [PATCH 089/117] Revert "ci(jenkins): if windows" This reverts commit 23558e60a6980113298c63cc5a1021e328142752. --- Jenkinsfile | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 0c13c2d830..3c15072c8a 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -347,13 +347,9 @@ def generateStep(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - if (isUnix()) { - sh label: 'Environment', script: 'env | sort' - sh label: 'Gather node:12', script: 'docker pull node:12' - sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' - } else { - bat 'set' - } + sh label: 'Environment', script: 'env | sort' + sh label: 'Gather node:12', script: 'docker pull node:12' + sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From d9119321e0f4977dc221dfdba4baee727824aec4 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:02:35 +0100 Subject: [PATCH 090/117] Revert "ci(jenkins): gather env details" This reverts commit 8d49a9fc936d1321aab6e9377cfd5a10b742bb7b. --- Jenkinsfile | 3 --- 1 file changed, 3 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 3c15072c8a..9984950dcc 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -347,9 +347,6 @@ def generateStep(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - sh label: 'Environment', script: 'env | sort' - sh label: 'Gather node:12', script: 'docker pull node:12' - sh label: 'Run node:12', script: 'docker run --rm -t node:12 echo hi' docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') } From da21916a976e1b4a3d2bc3cc41365f2d9f980171 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Mon, 14 Oct 2019 10:10:23 +0100 Subject: [PATCH 091/117] ci(jenkins): withEnv to avoid env clashes --- Jenkinsfile | 96 +++++++++++++++++++++++++---------------------------- 1 file changed, 45 insertions(+), 51 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 9984950dcc..37c8b836e5 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -331,27 +331,25 @@ def generateStep(Map params = [:]){ def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('linux && immutable'){ - try { - env.HOME = "${WORKSPACE}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - deleteDir() - unstash 'source' - dir("${BASE_DIR}"){ - retry(2){ - sleep randomNumber(min:10, max: 30) - sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + withEnv(["VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}"]) { + try { + deleteDir() + unstash 'source' + dir("${BASE_DIR}"){ + retry(2){ + sleep randomNumber(min:5, max: 10) + sh(label: "Run Tests", script: """.ci/scripts/test.sh "${version}" "${tav}" "${edge}" """) + } } + } catch(e){ + error(e.toString()) + } finally { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") } - } catch(e){ - error(e.toString()) - } finally { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") - codecov(repo: env.REPO, basedir: "${BASE_DIR}", secret: "${CODECOV_SECRET}") } } } @@ -429,39 +427,35 @@ def generateStepForWindows(Map params = [:]){ def disableAsyncHooks = params.get('disableAsyncHooks', false) return { node('windows-2019-docker-immutable'){ - try { - env.HOME = "${WORKSPACE}" - // When installing with choco the PATH might not be updated within the already connected worker. - env.PATH = "${PATH};C:\\Program Files\\nodejs" - env.VERSION = "${version}" - if (disableAsyncHooks) { - env.ELASTIC_APM_ASYNC_HOOKS = 'false' - } - env.SA_PASSWORD = 'password123_' - env.MYSQL_USER = 'elastic' - env.MYSQL_PASSWORD = 'password123_' - deleteDir() - unstash 'source' - dir(BASE_DIR) { - powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - dir('.ci/scripts/windows/docker') { - bat label: 'Prepare services', script: 'run-services.bat' + // When installing with choco the PATH might not be updated within the already connected worker. + withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", "VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}"]) { + try { + env.SA_PASSWORD = 'password123_' + env.MYSQL_USER = 'elastic' + env.MYSQL_PASSWORD = 'password123_' + deleteDir() + unstash 'source' + dir(BASE_DIR) { + powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" + dir('.ci/scripts/windows/docker') { + bat label: 'Prepare services', script: 'run-services.bat' + } + bat label: 'Tool versions', script: ''' + npm --version + node --version + ''' + bat 'npm install' + bat ''' + docker ps + node test/test.js + ''' + } + } catch(e){ + error(e.toString()) + } finally { + dir("${BASE_DIR}/.ci/scripts/windows/docker") { + bat label: 'Gather logs', returnStatus: true, script: 'log-services.bat' } - bat label: 'Tool versions', script: ''' - npm --version - node --version - ''' - bat 'npm install' - bat ''' - docker ps - node test/test.js - ''' - } - } catch(e){ - error(e.toString()) - } finally { - dir("${BASE_DIR}/.ci/scripts/windows/docker") { - bat label: 'Gather logs', returnStatus: true, script: 'log-services.bat' } } } From 126da47f4f3bd4aa08a695d712b93581b6fe452f Mon Sep 17 00:00:00 2001 From: Stephen Belanger Date: Fri, 18 Oct 2019 19:23:37 -0700 Subject: [PATCH 092/117] test(bluebird): properly handle Windows line breaks --- test/instrumentation/modules/bluebird/bluebird.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/instrumentation/modules/bluebird/bluebird.js b/test/instrumentation/modules/bluebird/bluebird.js index eee89c9b63..77dd5dbfab 100644 --- a/test/instrumentation/modules/bluebird/bluebird.js +++ b/test/instrumentation/modules/bluebird/bluebird.js @@ -927,7 +927,7 @@ test('Promise.promisify', function (t) { readFile(__filename, 'utf8').then(function (contents) { var firstLine = contents.split('\n')[0] - t.equal(firstLine, '\'use strict\'') + t.ok(/use strict/.test(firstLine)) t.equal(ins.currentTransaction.id, trans.id) }) }) From 86210ccc92ba675d3e6e37edd95a8a662b2daf4f Mon Sep 17 00:00:00 2001 From: Stephen Belanger Date: Fri, 18 Oct 2019 19:26:07 -0700 Subject: [PATCH 093/117] test(pg): set fallback when PGUSER is absent --- test/instrumentation/modules/pg/_utils.js | 10 ++++++++-- test/instrumentation/modules/pg/knex.js | 5 ++++- test/instrumentation/modules/pg/pg.js | 11 ++++++++--- 3 files changed, 20 insertions(+), 6 deletions(-) diff --git a/test/instrumentation/modules/pg/_utils.js b/test/instrumentation/modules/pg/_utils.js index a675157599..1bef25531f 100644 --- a/test/instrumentation/modules/pg/_utils.js +++ b/test/instrumentation/modules/pg/_utils.js @@ -6,7 +6,10 @@ exports.reset = reset exports.loadData = loadData function reset (cb) { - var client = new Client({ database: 'postgres' }) + var client = new Client({ + database: 'postgres', + user: process.env.PGUSER || 'postgres' + }) client.connect(function (err) { if (err) throw err @@ -22,7 +25,10 @@ function reset (cb) { } function loadData (cb) { - var client = new Client({ database: 'test_elastic_apm' }) + var client = new Client({ + database: 'test_elastic_apm', + user: process.env.PGUSER || 'postgres' + }) client.connect(function (err) { if (err) throw err diff --git a/test/instrumentation/modules/pg/knex.js b/test/instrumentation/modules/pg/knex.js index cb6f702112..90ee1b7d33 100644 --- a/test/instrumentation/modules/pg/knex.js +++ b/test/instrumentation/modules/pg/knex.js @@ -134,7 +134,10 @@ function createClient (cb) { setup(function () { knex = Knex({ client: 'pg', - connection: 'postgres:///test_elastic_apm' + connection: { + database: 'test_elastic_apm', + user: process.env.PGUSER || 'postgres' + } }) cb() }) diff --git a/test/instrumentation/modules/pg/pg.js b/test/instrumentation/modules/pg/pg.js index c8132f9ceb..c59adbf7a5 100644 --- a/test/instrumentation/modules/pg/pg.js +++ b/test/instrumentation/modules/pg/pg.js @@ -497,7 +497,8 @@ function assertSpan (t, span, sql) { function createClient (cb) { setup(function () { queryable = new pg.Client({ - database: 'test_elastic_apm' + database: 'test_elastic_apm', + user: process.env.PGUSER || 'postgres' }) queryable.connect(function (err) { if (err) throw err @@ -513,11 +514,15 @@ function createPool (cb) { if (semver.satisfies(pgVersion, '<6.0.0')) { queryable = pg connector = function connector (cb) { - return pg.connect('postgres:///test_elastic_apm', cb) + return pg.connect({ + database: 'test_elastic_apm', + user: process.env.PGUSER || 'postgres' + }, cb) } } else { var pool = new pg.Pool({ - database: 'test_elastic_apm' + database: 'test_elastic_apm', + user: process.env.PGUSER || 'postgres' }) queryable = pool connector = function connector (cb) { From 731f14476b2ba8c5921550dc6bb2ac4a8daa4bc7 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 10:35:51 +0000 Subject: [PATCH 094/117] ci(jenkins): run docker services in linux --- .ci/Jenkinsfile | 29 +++++++++++++++++------------ .ci/scripts/windows/prepare-test.sh | 15 +++++++++++++++ .ci/scripts/windows/stop-test.sh | 10 ++++++++++ 3 files changed, 42 insertions(+), 12 deletions(-) create mode 100755 .ci/scripts/windows/prepare-test.sh create mode 100755 .ci/scripts/windows/stop-test.sh diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 63cd86ccaf..cbc92cb8cf 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -455,38 +455,43 @@ def generateStepForWindows(Map params = [:]){ def version = params?.version def disableAsyncHooks = params.get('disableAsyncHooks', false) return { + sh label: 'Prepare services', script: '.ci/scripts/windows/prepare-test.sh' + def linuxIp = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true)?.trim() node('windows-2019-docker-immutable'){ // When installing with choco the PATH might not be updated within the already connected worker. - withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", "VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}"]) { + withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", + "VERSION=${version}", + "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}", + "SA_PASSWORD=password123_", + "MYSQL_USER=elastic", + "MYSQL_PASSWORD=password123_", + "CASSANDRA_HOST=${linuxIp}", + "ES_HOST=${linuxIp}", + "MEMCACHED_HOST=${linuxIp}", + "MONGODB_HOST=${linuxIp}", + "MSSQL_HOST=${linuxIp}", + "MYSQL_HOST=${linuxIp}", + "PGHOST=${linuxIp}", + "REDIS_HOST=${linuxIp}"]) { try { - env.SA_PASSWORD = 'password123_' - env.MYSQL_USER = 'elastic' - env.MYSQL_PASSWORD = 'password123_' deleteDir() unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - dir('.ci/scripts/windows/docker') { - bat label: 'Prepare services', script: 'run-services.bat' - } bat label: 'Tool versions', script: ''' npm --version node --version ''' bat 'npm install' bat ''' - docker ps node test/test.js ''' } } catch(e){ error(e.toString()) - } finally { - dir("${BASE_DIR}/.ci/scripts/windows/docker") { - bat label: 'Gather logs', returnStatus: true, script: 'log-services.bat' - } } } } + sh label: 'Stop services', script: '.ci/scripts/windows/stop-test.sh' } } diff --git a/.ci/scripts/windows/prepare-test.sh b/.ci/scripts/windows/prepare-test.sh new file mode 100755 index 0000000000..2e3d912f5c --- /dev/null +++ b/.ci/scripts/windows/prepare-test.sh @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +set -exo pipefail + +NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} + +NODE_VERSION=${NODE_VERSION} \ +USER_ID="$(id -u):$(id -g)" \ +docker-compose \ + --no-ansi \ + --log-level ERROR \ + -f .ci/docker/docker-compose-all.yml \ + up \ + --build \ + --remove-orphans \ + --abort-on-container-exit diff --git a/.ci/scripts/windows/stop-test.sh b/.ci/scripts/windows/stop-test.sh new file mode 100755 index 0000000000..9959e0049d --- /dev/null +++ b/.ci/scripts/windows/stop-test.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env bash +set -exo pipefail + +NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} + +NODE_VERSION=${NODE_VERSION} docker-compose \ + --no-ansi \ + --log-level ERROR \ + -f .ci/docker/docker-compose-all.yml \ + down -v From 01c747ccdce6c559efc3a7a2b90be68ece0f285f Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 10:40:02 +0000 Subject: [PATCH 095/117] ci(jenkins): add verbose for the install in windows --- .ci/scripts/windows/install-tools.ps1 | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index aa1a7039d2..e7a8b64cbd 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -1,11 +1,12 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Write-Host "List environment variables..." +Write-Host "List environment variables ..." Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize -Write-Host "Getting latest Nodejs version..." +Write-Host("Getting latest Nodejs version for {0} ..." -f $env:VERSION) +choco list nodejs --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 -Write-Host "Installing Nodejs..." +Write-Host("Installing Nodejs {0} ..." -f $Version) & choco install nodejs --no-progress -y --version "$Version" From 8e8bbe1430e3f2e55c6fef7447193a232b8e2261 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:08:39 +0000 Subject: [PATCH 096/117] ci(jenkins): debug the ps1 --- .ci/scripts/windows/install-tools.ps1 | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index e7a8b64cbd..62774d38a1 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -5,7 +5,11 @@ Write-Host "List environment variables ..." Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host("Getting latest Nodejs version for {0} ..." -f $env:VERSION) +choco list nodejs --by-id-only --all choco list nodejs --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" +& choco list nodejs --by-id-only --all +& choco list nodejs --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" + $Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 Write-Host("Installing Nodejs {0} ..." -f $Version) From 53cec38f8d73d1839e52f3cbed15826d3ed11813 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:30:36 +0000 Subject: [PATCH 097/117] ci(jenkins): some leftovers --- .ci/Jenkinsfile | 2 +- .gitignore | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index cbc92cb8cf..b6f439b44a 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -455,7 +455,7 @@ def generateStepForWindows(Map params = [:]){ def version = params?.version def disableAsyncHooks = params.get('disableAsyncHooks', false) return { - sh label: 'Prepare services', script: '.ci/scripts/windows/prepare-test.sh' + sh label: 'Prepare services', script: ".ci/scripts/windows/prepare-test.sh ${version}" def linuxIp = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true)?.trim() node('windows-2019-docker-immutable'){ // When installing with choco the PATH might not be updated within the already connected worker. diff --git a/.gitignore b/.gitignore index bf09eabe3e..0d29481732 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ build coverage node_modules test/benchmarks/.tmp +coverage.lcov +test-suite-output.tap From 3de38cc434b4a0e367b16c59d641fa5a93cd232b Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:32:58 +0000 Subject: [PATCH 098/117] ci(jenkins): run quietly and detached --- .ci/scripts/windows/prepare-test.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.ci/scripts/windows/prepare-test.sh b/.ci/scripts/windows/prepare-test.sh index 2e3d912f5c..7f3513c099 100755 --- a/.ci/scripts/windows/prepare-test.sh +++ b/.ci/scripts/windows/prepare-test.sh @@ -12,4 +12,5 @@ docker-compose \ up \ --build \ --remove-orphans \ - --abort-on-container-exit + --quiet-pull \ + --detach From dd2a260c0726760f09158a2e72c31836b714fee0 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:37:09 +0000 Subject: [PATCH 099/117] ci(jenkins): redirect logs to a file --- .ci/Jenkinsfile | 4 +++- .ci/scripts/windows/stop-test.sh | 6 ++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index b6f439b44a..d24579d5fd 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -492,6 +492,8 @@ def generateStepForWindows(Map params = [:]){ } } } - sh label: 'Stop services', script: '.ci/scripts/windows/stop-test.sh' + + // If the above execution failed, then it will not reach this section. TBD + sh label: 'Stop services', script: ".ci/scripts/windows/stop-test.sh ${version}" } } diff --git a/.ci/scripts/windows/stop-test.sh b/.ci/scripts/windows/stop-test.sh index 9959e0049d..0b0a065304 100755 --- a/.ci/scripts/windows/stop-test.sh +++ b/.ci/scripts/windows/stop-test.sh @@ -3,6 +3,12 @@ set -exo pipefail NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} +NODE_VERSION=${NODE_VERSION} docker-compose \ + --no-ansi \ + -f .ci/docker/docker-compose-all.yml \ + logs \ + --timestamps > docker-compose-logs.txt + NODE_VERSION=${NODE_VERSION} docker-compose \ --no-ansi \ --log-level ERROR \ From dcb584c46c7ad3a5ccb938caa6ffea54295ce924 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:41:21 +0000 Subject: [PATCH 100/117] ci(jenkins): otherwise uses nodejs.commandline --- .ci/scripts/windows/install-tools.ps1 | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 index 62774d38a1..3d9c44e6c1 100644 --- a/.ci/scripts/windows/install-tools.ps1 +++ b/.ci/scripts/windows/install-tools.ps1 @@ -5,12 +5,8 @@ Write-Host "List environment variables ..." Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host("Getting latest Nodejs version for {0} ..." -f $env:VERSION) -choco list nodejs --by-id-only --all -choco list nodejs --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" -& choco list nodejs --by-id-only --all -& choco list nodejs --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" - -$Version = $(choco list nodejs --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 +& choco list nodejs --exact --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" +$Version = $(choco list nodejs --exact --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 Write-Host("Installing Nodejs {0} ..." -f $Version) & choco install nodejs --no-progress -y --version "$Version" From 8ba3d6eadb6b34c1a2c0116fae833112c7ede095 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 10:35:51 +0000 Subject: [PATCH 101/117] ci(jenkins): run docker services in linux --- .ci/Jenkinsfile | 29 +++++++++++++++++------------ .ci/scripts/windows/prepare-test.sh | 15 +++++++++++++++ .ci/scripts/windows/stop-test.sh | 10 ++++++++++ 3 files changed, 42 insertions(+), 12 deletions(-) create mode 100755 .ci/scripts/windows/prepare-test.sh create mode 100755 .ci/scripts/windows/stop-test.sh diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 63cd86ccaf..cbc92cb8cf 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -455,38 +455,43 @@ def generateStepForWindows(Map params = [:]){ def version = params?.version def disableAsyncHooks = params.get('disableAsyncHooks', false) return { + sh label: 'Prepare services', script: '.ci/scripts/windows/prepare-test.sh' + def linuxIp = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true)?.trim() node('windows-2019-docker-immutable'){ // When installing with choco the PATH might not be updated within the already connected worker. - withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", "VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}"]) { + withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", + "VERSION=${version}", + "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}", + "SA_PASSWORD=password123_", + "MYSQL_USER=elastic", + "MYSQL_PASSWORD=password123_", + "CASSANDRA_HOST=${linuxIp}", + "ES_HOST=${linuxIp}", + "MEMCACHED_HOST=${linuxIp}", + "MONGODB_HOST=${linuxIp}", + "MSSQL_HOST=${linuxIp}", + "MYSQL_HOST=${linuxIp}", + "PGHOST=${linuxIp}", + "REDIS_HOST=${linuxIp}"]) { try { - env.SA_PASSWORD = 'password123_' - env.MYSQL_USER = 'elastic' - env.MYSQL_PASSWORD = 'password123_' deleteDir() unstash 'source' dir(BASE_DIR) { powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" - dir('.ci/scripts/windows/docker') { - bat label: 'Prepare services', script: 'run-services.bat' - } bat label: 'Tool versions', script: ''' npm --version node --version ''' bat 'npm install' bat ''' - docker ps node test/test.js ''' } } catch(e){ error(e.toString()) - } finally { - dir("${BASE_DIR}/.ci/scripts/windows/docker") { - bat label: 'Gather logs', returnStatus: true, script: 'log-services.bat' - } } } } + sh label: 'Stop services', script: '.ci/scripts/windows/stop-test.sh' } } diff --git a/.ci/scripts/windows/prepare-test.sh b/.ci/scripts/windows/prepare-test.sh new file mode 100755 index 0000000000..2e3d912f5c --- /dev/null +++ b/.ci/scripts/windows/prepare-test.sh @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +set -exo pipefail + +NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} + +NODE_VERSION=${NODE_VERSION} \ +USER_ID="$(id -u):$(id -g)" \ +docker-compose \ + --no-ansi \ + --log-level ERROR \ + -f .ci/docker/docker-compose-all.yml \ + up \ + --build \ + --remove-orphans \ + --abort-on-container-exit diff --git a/.ci/scripts/windows/stop-test.sh b/.ci/scripts/windows/stop-test.sh new file mode 100755 index 0000000000..9959e0049d --- /dev/null +++ b/.ci/scripts/windows/stop-test.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env bash +set -exo pipefail + +NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} + +NODE_VERSION=${NODE_VERSION} docker-compose \ + --no-ansi \ + --log-level ERROR \ + -f .ci/docker/docker-compose-all.yml \ + down -v From 225b2967b5352e1121e18d45130dfa1bebb9c1bd Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:30:36 +0000 Subject: [PATCH 102/117] ci(jenkins): some leftovers --- .ci/Jenkinsfile | 2 +- .gitignore | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index cbc92cb8cf..b6f439b44a 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -455,7 +455,7 @@ def generateStepForWindows(Map params = [:]){ def version = params?.version def disableAsyncHooks = params.get('disableAsyncHooks', false) return { - sh label: 'Prepare services', script: '.ci/scripts/windows/prepare-test.sh' + sh label: 'Prepare services', script: ".ci/scripts/windows/prepare-test.sh ${version}" def linuxIp = sh(label: 'Get IP', script: '''hostname -I | awk '{print $1}' ''', returnStdout: true)?.trim() node('windows-2019-docker-immutable'){ // When installing with choco the PATH might not be updated within the already connected worker. diff --git a/.gitignore b/.gitignore index bf09eabe3e..0d29481732 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ build coverage node_modules test/benchmarks/.tmp +coverage.lcov +test-suite-output.tap From 1608f8821732135b258907aeaf891dfafae8c760 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:32:58 +0000 Subject: [PATCH 103/117] ci(jenkins): run quietly and detached --- .ci/scripts/windows/prepare-test.sh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.ci/scripts/windows/prepare-test.sh b/.ci/scripts/windows/prepare-test.sh index 2e3d912f5c..7f3513c099 100755 --- a/.ci/scripts/windows/prepare-test.sh +++ b/.ci/scripts/windows/prepare-test.sh @@ -12,4 +12,5 @@ docker-compose \ up \ --build \ --remove-orphans \ - --abort-on-container-exit + --quiet-pull \ + --detach From 6e8ba8b4b07e70f1e4b228572eff533a60b06827 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 11:37:09 +0000 Subject: [PATCH 104/117] ci(jenkins): redirect logs to a file --- .ci/Jenkinsfile | 4 +++- .ci/scripts/windows/stop-test.sh | 6 ++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index b6f439b44a..d24579d5fd 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -492,6 +492,8 @@ def generateStepForWindows(Map params = [:]){ } } } - sh label: 'Stop services', script: '.ci/scripts/windows/stop-test.sh' + + // If the above execution failed, then it will not reach this section. TBD + sh label: 'Stop services', script: ".ci/scripts/windows/stop-test.sh ${version}" } } diff --git a/.ci/scripts/windows/stop-test.sh b/.ci/scripts/windows/stop-test.sh index 9959e0049d..0b0a065304 100755 --- a/.ci/scripts/windows/stop-test.sh +++ b/.ci/scripts/windows/stop-test.sh @@ -3,6 +3,12 @@ set -exo pipefail NODE_VERSION=${1:?Nodejs version missing NODE_VERSION is not set} +NODE_VERSION=${NODE_VERSION} docker-compose \ + --no-ansi \ + -f .ci/docker/docker-compose-all.yml \ + logs \ + --timestamps > docker-compose-logs.txt + NODE_VERSION=${NODE_VERSION} docker-compose \ --no-ansi \ --log-level ERROR \ From 18084e9ff3e8a9fdbf20e3ba9176475e4fc6208c Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 12:22:04 +0000 Subject: [PATCH 105/117] ci(jenkins): default mssql password --- .ci/Jenkinsfile | 1 - 1 file changed, 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index d24579d5fd..f1d8e4f18c 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -462,7 +462,6 @@ def generateStepForWindows(Map params = [:]){ withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", "VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}", - "SA_PASSWORD=password123_", "MYSQL_USER=elastic", "MYSQL_PASSWORD=password123_", "CASSANDRA_HOST=${linuxIp}", From 859caae0a1707697e7ecff31d1a4249973985b48 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 13:22:27 +0000 Subject: [PATCH 106/117] ci(jenkins): default mysql user/password --- .ci/Jenkinsfile | 2 -- 1 file changed, 2 deletions(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index f1d8e4f18c..19fe6f1395 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -462,8 +462,6 @@ def generateStepForWindows(Map params = [:]){ withEnv(["PATH=${PATH};C:\\Program Files\\nodejs", "VERSION=${version}", "ELASTIC_APM_ASYNC_HOOKS=${disableAsyncHooks}", - "MYSQL_USER=elastic", - "MYSQL_PASSWORD=password123_", "CASSANDRA_HOST=${linuxIp}", "ES_HOST=${linuxIp}", "MEMCACHED_HOST=${linuxIp}", From c21dc480331d7a5a6e808d1be65442facb8cd7e2 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 13:29:20 +0000 Subject: [PATCH 107/117] ci(jenkins): docker for windows unrequired --- .ci/scripts/windows/docker/README.md | 6 - .../windows/docker/cassandra/Dockerfile | 32 - .../windows/docker/cassandra/cassandra.yaml | 1237 ----------------- .../windows/docker/elasticsearch/Dockerfile | 43 - .../docker/elasticsearch/elasticsearch.yml | 8 - .ci/scripts/windows/docker/log-services.bat | 8 - .ci/scripts/windows/docker/mongodb/Dockerfile | 21 - .ci/scripts/windows/docker/mongodb/mongod.cfg | 21 - .ci/scripts/windows/docker/mssql/Dockerfile | 31 - .ci/scripts/windows/docker/mssql/start.ps1 | 77 - .ci/scripts/windows/docker/mysql/Dockerfile | 20 - .../windows/docker/mysql/entrypoint.ps1 | 12 - .ci/scripts/windows/docker/mysql/my.ini | 6 - .../windows/docker/postgres/Dockerfile | 18 - .../windows/docker/postgres/entrypoint.ps1 | 8 - .../windows/docker/postgres/pg_hba.conf | 10 - .../windows/docker/postgres/postgresql.conf | 658 --------- .ci/scripts/windows/docker/redis/Dockerfile | 18 - .ci/scripts/windows/docker/redis/redis.conf | 887 ------------ .ci/scripts/windows/docker/run-services.bat | 15 - 20 files changed, 3136 deletions(-) delete mode 100644 .ci/scripts/windows/docker/README.md delete mode 100644 .ci/scripts/windows/docker/cassandra/Dockerfile delete mode 100644 .ci/scripts/windows/docker/cassandra/cassandra.yaml delete mode 100644 .ci/scripts/windows/docker/elasticsearch/Dockerfile delete mode 100644 .ci/scripts/windows/docker/elasticsearch/elasticsearch.yml delete mode 100644 .ci/scripts/windows/docker/log-services.bat delete mode 100644 .ci/scripts/windows/docker/mongodb/Dockerfile delete mode 100644 .ci/scripts/windows/docker/mongodb/mongod.cfg delete mode 100644 .ci/scripts/windows/docker/mssql/Dockerfile delete mode 100644 .ci/scripts/windows/docker/mssql/start.ps1 delete mode 100644 .ci/scripts/windows/docker/mysql/Dockerfile delete mode 100644 .ci/scripts/windows/docker/mysql/entrypoint.ps1 delete mode 100644 .ci/scripts/windows/docker/mysql/my.ini delete mode 100644 .ci/scripts/windows/docker/postgres/Dockerfile delete mode 100644 .ci/scripts/windows/docker/postgres/entrypoint.ps1 delete mode 100644 .ci/scripts/windows/docker/postgres/pg_hba.conf delete mode 100644 .ci/scripts/windows/docker/postgres/postgresql.conf delete mode 100644 .ci/scripts/windows/docker/redis/Dockerfile delete mode 100644 .ci/scripts/windows/docker/redis/redis.conf delete mode 100644 .ci/scripts/windows/docker/run-services.bat diff --git a/.ci/scripts/windows/docker/README.md b/.ci/scripts/windows/docker/README.md deleted file mode 100644 index 8de3a4bd92..0000000000 --- a/.ci/scripts/windows/docker/README.md +++ /dev/null @@ -1,6 +0,0 @@ -## Version compatibility - -https://docs.microsoft.com/en-us/virtualization/windowscontainers/deploy-containers/version-compatibility#matching-container-host-version-with-container-image-versions - -### Further docs -- [ES for Windows](https://github.com/sixeyed/dockerfiles-windows/tree/master/elasticsearch) diff --git a/.ci/scripts/windows/docker/cassandra/Dockerfile b/.ci/scripts/windows/docker/cassandra/Dockerfile deleted file mode 100644 index 768a84f01e..0000000000 --- a/.ci/scripts/windows/docker/cassandra/Dockerfile +++ /dev/null @@ -1,32 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 AS installer -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) - -RUN choco install 7zip.install --no-progress -y - -ARG VERSION="3.11.3" -ENV CASSANDRA_HOME="C:\cassandra" -ENV ROOT_URL="http://archive.apache.org/dist/cassandra" -WORKDIR $CASSANDRA_HOME - -RUN Write-Host "Downloading: ${env:ROOT_URL}/${env:VERSION}/apache-cassandra-${env:VERSION}-bin.tar.gz"; ` - Invoke-WebRequest "${env:ROOT_URL}/${env:VERSION}/apache-cassandra-${env:VERSION}-bin.tar.gz" -OutFile 'cassandra.tar.gz' -UseBasicParsing; ` - Write-Host "Installing: cassandra.tar.gz"; ` - 7z e cassandra.tar.gz -tgzip -y | Out-Null; ` - 7z x cassandra.tar -ttar -r -aou | Out-Null; ` - del cassandra.tar.gz; - -FROM openjdk:8-windowsservercore-1809 -ENV CASSANDRA_HOME="C:\cassandra" -ENV VERSION="3.11.3" -ENV JAVA_OPTS="-Xms256m -Xmx1024m" -WORKDIR $CASSANDRA_HOME -COPY --from=installer ${CASSANDRA_HOME}\apache-cassandra-${VERSION}\ . -COPY cassandra.yaml .\conf\cassandra.yaml - -EXPOSE 9042 7000 - -SHELL ["cmd", "/S", "/C"] -CMD "bin\cassandra.bat" diff --git a/.ci/scripts/windows/docker/cassandra/cassandra.yaml b/.ci/scripts/windows/docker/cassandra/cassandra.yaml deleted file mode 100644 index 98fc006099..0000000000 --- a/.ci/scripts/windows/docker/cassandra/cassandra.yaml +++ /dev/null @@ -1,1237 +0,0 @@ -# Cassandra storage config YAML - -# NOTE: -# See http://wiki.apache.org/cassandra/StorageConfiguration for -# full explanations of configuration directives -# /NOTE - -# The name of the cluster. This is mainly used to prevent machines in -# one logical cluster from joining another. -cluster_name: 'Test Cluster' - -# This defines the number of tokens randomly assigned to this node on the ring -# The more tokens, relative to other nodes, the larger the proportion of data -# that this node will store. You probably want all nodes to have the same number -# of tokens assuming they have equal hardware capability. -# -# If you leave this unspecified, Cassandra will use the default of 1 token for legacy compatibility, -# and will use the initial_token as described below. -# -# Specifying initial_token will override this setting on the node's initial start, -# on subsequent starts, this setting will apply even if initial token is set. -# -# If you already have a cluster with 1 token per node, and wish to migrate to -# multiple tokens per node, see http://wiki.apache.org/cassandra/Operations -num_tokens: 256 - -# Triggers automatic allocation of num_tokens tokens for this node. The allocation -# algorithm attempts to choose tokens in a way that optimizes replicated load over -# the nodes in the datacenter for the replication strategy used by the specified -# keyspace. -# -# The load assigned to each node will be close to proportional to its number of -# vnodes. -# -# Only supported with the Murmur3Partitioner. -# allocate_tokens_for_keyspace: KEYSPACE - -# initial_token allows you to specify tokens manually. While you can use it with -# vnodes (num_tokens > 1, above) -- in which case you should provide a -# comma-separated list -- it's primarily used when adding nodes to legacy clusters -# that do not have vnodes enabled. -# initial_token: - -# See http://wiki.apache.org/cassandra/HintedHandoff -# May either be "true" or "false" to enable globally -hinted_handoff_enabled: true - -# When hinted_handoff_enabled is true, a black list of data centers that will not -# perform hinted handoff -# hinted_handoff_disabled_datacenters: -# - DC1 -# - DC2 - -# this defines the maximum amount of time a dead host will have hints -# generated. After it has been dead this long, new hints for it will not be -# created until it has been seen alive and gone down again. -max_hint_window_in_ms: 10800000 # 3 hours - -# Maximum throttle in KBs per second, per delivery thread. This will be -# reduced proportionally to the number of nodes in the cluster. (If there -# are two nodes in the cluster, each delivery thread will use the maximum -# rate; if there are three, each will throttle to half of the maximum, -# since we expect two nodes to be delivering hints simultaneously.) -hinted_handoff_throttle_in_kb: 1024 - -# Number of threads with which to deliver hints; -# Consider increasing this number when you have multi-dc deployments, since -# cross-dc handoff tends to be slower -max_hints_delivery_threads: 2 - -# Directory where Cassandra should store hints. -# If not set, the default directory is $CASSANDRA_HOME/data/hints. -# hints_directory: /var/lib/cassandra/hints - -# How often hints should be flushed from the internal buffers to disk. -# Will *not* trigger fsync. -hints_flush_period_in_ms: 10000 - -# Maximum size for a single hints file, in megabytes. -max_hints_file_size_in_mb: 128 - -# Compression to apply to the hint files. If omitted, hints files -# will be written uncompressed. LZ4, Snappy, and Deflate compressors -# are supported. -#hints_compression: -# - class_name: LZ4Compressor -# parameters: -# - - -# Maximum throttle in KBs per second, total. This will be -# reduced proportionally to the number of nodes in the cluster. -batchlog_replay_throttle_in_kb: 1024 - -# Authentication backend, implementing IAuthenticator; used to identify users -# Out of the box, Cassandra provides org.apache.cassandra.auth.{AllowAllAuthenticator, -# PasswordAuthenticator}. -# -# - AllowAllAuthenticator performs no checks - set it to disable authentication. -# - PasswordAuthenticator relies on username/password pairs to authenticate -# users. It keeps usernames and hashed passwords in system_auth.roles table. -# Please increase system_auth keyspace replication factor if you use this authenticator. -# If using PasswordAuthenticator, CassandraRoleManager must also be used (see below) -authenticator: AllowAllAuthenticator - -# Authorization backend, implementing IAuthorizer; used to limit access/provide permissions -# Out of the box, Cassandra provides org.apache.cassandra.auth.{AllowAllAuthorizer, -# CassandraAuthorizer}. -# -# - AllowAllAuthorizer allows any action to any user - set it to disable authorization. -# - CassandraAuthorizer stores permissions in system_auth.role_permissions table. Please -# increase system_auth keyspace replication factor if you use this authorizer. -authorizer: AllowAllAuthorizer - -# Part of the Authentication & Authorization backend, implementing IRoleManager; used -# to maintain grants and memberships between roles. -# Out of the box, Cassandra provides org.apache.cassandra.auth.CassandraRoleManager, -# which stores role information in the system_auth keyspace. Most functions of the -# IRoleManager require an authenticated login, so unless the configured IAuthenticator -# actually implements authentication, most of this functionality will be unavailable. -# -# - CassandraRoleManager stores role data in the system_auth keyspace. Please -# increase system_auth keyspace replication factor if you use this role manager. -role_manager: CassandraRoleManager - -# Validity period for roles cache (fetching granted roles can be an expensive -# operation depending on the role manager, CassandraRoleManager is one example) -# Granted roles are cached for authenticated sessions in AuthenticatedUser and -# after the period specified here, become eligible for (async) reload. -# Defaults to 2000, set to 0 to disable caching entirely. -# Will be disabled automatically for AllowAllAuthenticator. -roles_validity_in_ms: 2000 - -# Refresh interval for roles cache (if enabled). -# After this interval, cache entries become eligible for refresh. Upon next -# access, an async reload is scheduled and the old value returned until it -# completes. If roles_validity_in_ms is non-zero, then this must be -# also. -# Defaults to the same value as roles_validity_in_ms. -# roles_update_interval_in_ms: 2000 - -# Validity period for permissions cache (fetching permissions can be an -# expensive operation depending on the authorizer, CassandraAuthorizer is -# one example). Defaults to 2000, set to 0 to disable. -# Will be disabled automatically for AllowAllAuthorizer. -permissions_validity_in_ms: 2000 - -# Refresh interval for permissions cache (if enabled). -# After this interval, cache entries become eligible for refresh. Upon next -# access, an async reload is scheduled and the old value returned until it -# completes. If permissions_validity_in_ms is non-zero, then this must be -# also. -# Defaults to the same value as permissions_validity_in_ms. -# permissions_update_interval_in_ms: 2000 - -# Validity period for credentials cache. This cache is tightly coupled to -# the provided PasswordAuthenticator implementation of IAuthenticator. If -# another IAuthenticator implementation is configured, this cache will not -# be automatically used and so the following settings will have no effect. -# Please note, credentials are cached in their encrypted form, so while -# activating this cache may reduce the number of queries made to the -# underlying table, it may not bring a significant reduction in the -# latency of individual authentication attempts. -# Defaults to 2000, set to 0 to disable credentials caching. -credentials_validity_in_ms: 2000 - -# Refresh interval for credentials cache (if enabled). -# After this interval, cache entries become eligible for refresh. Upon next -# access, an async reload is scheduled and the old value returned until it -# completes. If credentials_validity_in_ms is non-zero, then this must be -# also. -# Defaults to the same value as credentials_validity_in_ms. -# credentials_update_interval_in_ms: 2000 - -# The partitioner is responsible for distributing groups of rows (by -# partition key) across nodes in the cluster. You should leave this -# alone for new clusters. The partitioner can NOT be changed without -# reloading all data, so when upgrading you should set this to the -# same partitioner you were already using. -# -# Besides Murmur3Partitioner, partitioners included for backwards -# compatibility include RandomPartitioner, ByteOrderedPartitioner, and -# OrderPreservingPartitioner. -# -partitioner: org.apache.cassandra.dht.Murmur3Partitioner - -# Directories where Cassandra should store data on disk. Cassandra -# will spread data evenly across them, subject to the granularity of -# the configured compaction strategy. -# If not set, the default directory is $CASSANDRA_HOME/data/data. -# data_file_directories: -# - /var/lib/cassandra/data - -# commit log. when running on magnetic HDD, this should be a -# separate spindle than the data directories. -# If not set, the default directory is $CASSANDRA_HOME/data/commitlog. -# commitlog_directory: /var/lib/cassandra/commitlog - -# Enable / disable CDC functionality on a per-node basis. This modifies the logic used -# for write path allocation rejection (standard: never reject. cdc: reject Mutation -# containing a CDC-enabled table if at space limit in cdc_raw_directory). -cdc_enabled: false - -# CommitLogSegments are moved to this directory on flush if cdc_enabled: true and the -# segment contains mutations for a CDC-enabled table. This should be placed on a -# separate spindle than the data directories. If not set, the default directory is -# $CASSANDRA_HOME/data/cdc_raw. -# cdc_raw_directory: /var/lib/cassandra/cdc_raw - -# Policy for data disk failures: -# -# die -# shut down gossip and client transports and kill the JVM for any fs errors or -# single-sstable errors, so the node can be replaced. -# -# stop_paranoid -# shut down gossip and client transports even for single-sstable errors, -# kill the JVM for errors during startup. -# -# stop -# shut down gossip and client transports, leaving the node effectively dead, but -# can still be inspected via JMX, kill the JVM for errors during startup. -# -# best_effort -# stop using the failed disk and respond to requests based on -# remaining available sstables. This means you WILL see obsolete -# data at CL.ONE! -# -# ignore -# ignore fatal errors and let requests fail, as in pre-1.2 Cassandra -disk_failure_policy: stop - -# Policy for commit disk failures: -# -# die -# shut down gossip and Thrift and kill the JVM, so the node can be replaced. -# -# stop -# shut down gossip and Thrift, leaving the node effectively dead, but -# can still be inspected via JMX. -# -# stop_commit -# shutdown the commit log, letting writes collect but -# continuing to service reads, as in pre-2.0.5 Cassandra -# -# ignore -# ignore fatal errors and let the batches fail -commit_failure_policy: stop - -# Maximum size of the native protocol prepared statement cache -# -# Valid values are either "auto" (omitting the value) or a value greater 0. -# -# Note that specifying a too large value will result in long running GCs and possbily -# out-of-memory errors. Keep the value at a small fraction of the heap. -# -# If you constantly see "prepared statements discarded in the last minute because -# cache limit reached" messages, the first step is to investigate the root cause -# of these messages and check whether prepared statements are used correctly - -# i.e. use bind markers for variable parts. -# -# Do only change the default value, if you really have more prepared statements than -# fit in the cache. In most cases it is not neccessary to change this value. -# Constantly re-preparing statements is a performance penalty. -# -# Default value ("auto") is 1/256th of the heap or 10MB, whichever is greater -prepared_statements_cache_size_mb: - -# Maximum size of the Thrift prepared statement cache -# -# If you do not use Thrift at all, it is safe to leave this value at "auto". -# -# See description of 'prepared_statements_cache_size_mb' above for more information. -# -# Default value ("auto") is 1/256th of the heap or 10MB, whichever is greater -thrift_prepared_statements_cache_size_mb: - -# Maximum size of the key cache in memory. -# -# Each key cache hit saves 1 seek and each row cache hit saves 2 seeks at the -# minimum, sometimes more. The key cache is fairly tiny for the amount of -# time it saves, so it's worthwhile to use it at large numbers. -# The row cache saves even more time, but must contain the entire row, -# so it is extremely space-intensive. It's best to only use the -# row cache if you have hot rows or static rows. -# -# NOTE: if you reduce the size, you may not get you hottest keys loaded on startup. -# -# Default value is empty to make it "auto" (min(5% of Heap (in MB), 100MB)). Set to 0 to disable key cache. -key_cache_size_in_mb: - -# Duration in seconds after which Cassandra should -# save the key cache. Caches are saved to saved_caches_directory as -# specified in this configuration file. -# -# Saved caches greatly improve cold-start speeds, and is relatively cheap in -# terms of I/O for the key cache. Row cache saving is much more expensive and -# has limited use. -# -# Default is 14400 or 4 hours. -key_cache_save_period: 14400 - -# Number of keys from the key cache to save -# Disabled by default, meaning all keys are going to be saved -# key_cache_keys_to_save: 100 - -# Row cache implementation class name. Available implementations: -# -# org.apache.cassandra.cache.OHCProvider -# Fully off-heap row cache implementation (default). -# -# org.apache.cassandra.cache.SerializingCacheProvider -# This is the row cache implementation availabile -# in previous releases of Cassandra. -# row_cache_class_name: org.apache.cassandra.cache.OHCProvider - -# Maximum size of the row cache in memory. -# Please note that OHC cache implementation requires some additional off-heap memory to manage -# the map structures and some in-flight memory during operations before/after cache entries can be -# accounted against the cache capacity. This overhead is usually small compared to the whole capacity. -# Do not specify more memory that the system can afford in the worst usual situation and leave some -# headroom for OS block level cache. Do never allow your system to swap. -# -# Default value is 0, to disable row caching. -row_cache_size_in_mb: 0 - -# Duration in seconds after which Cassandra should save the row cache. -# Caches are saved to saved_caches_directory as specified in this configuration file. -# -# Saved caches greatly improve cold-start speeds, and is relatively cheap in -# terms of I/O for the key cache. Row cache saving is much more expensive and -# has limited use. -# -# Default is 0 to disable saving the row cache. -row_cache_save_period: 0 - -# Number of keys from the row cache to save. -# Specify 0 (which is the default), meaning all keys are going to be saved -# row_cache_keys_to_save: 100 - -# Maximum size of the counter cache in memory. -# -# Counter cache helps to reduce counter locks' contention for hot counter cells. -# In case of RF = 1 a counter cache hit will cause Cassandra to skip the read before -# write entirely. With RF > 1 a counter cache hit will still help to reduce the duration -# of the lock hold, helping with hot counter cell updates, but will not allow skipping -# the read entirely. Only the local (clock, count) tuple of a counter cell is kept -# in memory, not the whole counter, so it's relatively cheap. -# -# NOTE: if you reduce the size, you may not get you hottest keys loaded on startup. -# -# Default value is empty to make it "auto" (min(2.5% of Heap (in MB), 50MB)). Set to 0 to disable counter cache. -# NOTE: if you perform counter deletes and rely on low gcgs, you should disable the counter cache. -counter_cache_size_in_mb: - -# Duration in seconds after which Cassandra should -# save the counter cache (keys only). Caches are saved to saved_caches_directory as -# specified in this configuration file. -# -# Default is 7200 or 2 hours. -counter_cache_save_period: 7200 - -# Number of keys from the counter cache to save -# Disabled by default, meaning all keys are going to be saved -# counter_cache_keys_to_save: 100 - -# saved caches -# If not set, the default directory is $CASSANDRA_HOME/data/saved_caches. -# saved_caches_directory: /var/lib/cassandra/saved_caches - -# commitlog_sync may be either "periodic" or "batch." -# -# When in batch mode, Cassandra won't ack writes until the commit log -# has been fsynced to disk. It will wait -# commitlog_sync_batch_window_in_ms milliseconds between fsyncs. -# This window should be kept short because the writer threads will -# be unable to do extra work while waiting. (You may need to increase -# concurrent_writes for the same reason.) -# -# commitlog_sync: batch -# commitlog_sync_batch_window_in_ms: 2 -# -# the other option is "periodic" where writes may be acked immediately -# and the CommitLog is simply synced every commitlog_sync_period_in_ms -# milliseconds. -commitlog_sync: periodic -commitlog_sync_period_in_ms: 10000 - -# The size of the individual commitlog file segments. A commitlog -# segment may be archived, deleted, or recycled once all the data -# in it (potentially from each columnfamily in the system) has been -# flushed to sstables. -# -# The default size is 32, which is almost always fine, but if you are -# archiving commitlog segments (see commitlog_archiving.properties), -# then you probably want a finer granularity of archiving; 8 or 16 MB -# is reasonable. -# Max mutation size is also configurable via max_mutation_size_in_kb setting in -# cassandra.yaml. The default is half the size commitlog_segment_size_in_mb * 1024. -# This should be positive and less than 2048. -# -# NOTE: If max_mutation_size_in_kb is set explicitly then commitlog_segment_size_in_mb must -# be set to at least twice the size of max_mutation_size_in_kb / 1024 -# -commitlog_segment_size_in_mb: 32 - -# Compression to apply to the commit log. If omitted, the commit log -# will be written uncompressed. LZ4, Snappy, and Deflate compressors -# are supported. -# commitlog_compression: -# - class_name: LZ4Compressor -# parameters: -# - - -# any class that implements the SeedProvider interface and has a -# constructor that takes a Map of parameters will do. -seed_provider: - # Addresses of hosts that are deemed contact points. - # Cassandra nodes use this list of hosts to find each other and learn - # the topology of the ring. You must change this if you are running - # multiple nodes! - - class_name: org.apache.cassandra.locator.SimpleSeedProvider - parameters: - # seeds is actually a comma-delimited list of addresses. - # Ex: ",," - - seeds: "127.0.0.1" - -# For workloads with more data than can fit in memory, Cassandra's -# bottleneck will be reads that need to fetch data from -# disk. "concurrent_reads" should be set to (16 * number_of_drives) in -# order to allow the operations to enqueue low enough in the stack -# that the OS and drives can reorder them. Same applies to -# "concurrent_counter_writes", since counter writes read the current -# values before incrementing and writing them back. -# -# On the other hand, since writes are almost never IO bound, the ideal -# number of "concurrent_writes" is dependent on the number of cores in -# your system; (8 * number_of_cores) is a good rule of thumb. -concurrent_reads: 32 -concurrent_writes: 32 -concurrent_counter_writes: 32 - -# For materialized view writes, as there is a read involved, so this should -# be limited by the less of concurrent reads or concurrent writes. -concurrent_materialized_view_writes: 32 - -# Maximum memory to use for sstable chunk cache and buffer pooling. -# 32MB of this are reserved for pooling buffers, the rest is used as an -# cache that holds uncompressed sstable chunks. -# Defaults to the smaller of 1/4 of heap or 512MB. This pool is allocated off-heap, -# so is in addition to the memory allocated for heap. The cache also has on-heap -# overhead which is roughly 128 bytes per chunk (i.e. 0.2% of the reserved size -# if the default 64k chunk size is used). -# Memory is only allocated when needed. -# file_cache_size_in_mb: 512 - -# Flag indicating whether to allocate on or off heap when the sstable buffer -# pool is exhausted, that is when it has exceeded the maximum memory -# file_cache_size_in_mb, beyond which it will not cache buffers but allocate on request. - -# buffer_pool_use_heap_if_exhausted: true - -# The strategy for optimizing disk read -# Possible values are: -# ssd (for solid state disks, the default) -# spinning (for spinning disks) -# disk_optimization_strategy: ssd - -# Total permitted memory to use for memtables. Cassandra will stop -# accepting writes when the limit is exceeded until a flush completes, -# and will trigger a flush based on memtable_cleanup_threshold -# If omitted, Cassandra will set both to 1/4 the size of the heap. -# memtable_heap_space_in_mb: 2048 -# memtable_offheap_space_in_mb: 2048 - -# memtable_cleanup_threshold is deprecated. The default calculation -# is the only reasonable choice. See the comments on memtable_flush_writers -# for more information. -# -# Ratio of occupied non-flushing memtable size to total permitted size -# that will trigger a flush of the largest memtable. Larger mct will -# mean larger flushes and hence less compaction, but also less concurrent -# flush activity which can make it difficult to keep your disks fed -# under heavy write load. -# -# memtable_cleanup_threshold defaults to 1 / (memtable_flush_writers + 1) -# memtable_cleanup_threshold: 0.11 - -# Specify the way Cassandra allocates and manages memtable memory. -# Options are: -# -# heap_buffers -# on heap nio buffers -# -# offheap_buffers -# off heap (direct) nio buffers -# -# offheap_objects -# off heap objects -memtable_allocation_type: heap_buffers - -# Total space to use for commit logs on disk. -# -# If space gets above this value, Cassandra will flush every dirty CF -# in the oldest segment and remove it. So a small total commitlog space -# will tend to cause more flush activity on less-active columnfamilies. -# -# The default value is the smaller of 8192, and 1/4 of the total space -# of the commitlog volume. -# -# commitlog_total_space_in_mb: 8192 - -# This sets the number of memtable flush writer threads per disk -# as well as the total number of memtables that can be flushed concurrently. -# These are generally a combination of compute and IO bound. -# -# Memtable flushing is more CPU efficient than memtable ingest and a single thread -# can keep up with the ingest rate of a whole server on a single fast disk -# until it temporarily becomes IO bound under contention typically with compaction. -# At that point you need multiple flush threads. At some point in the future -# it may become CPU bound all the time. -# -# You can tell if flushing is falling behind using the MemtablePool.BlockedOnAllocation -# metric which should be 0, but will be non-zero if threads are blocked waiting on flushing -# to free memory. -# -# memtable_flush_writers defaults to two for a single data directory. -# This means that two memtables can be flushed concurrently to the single data directory. -# If you have multiple data directories the default is one memtable flushing at a time -# but the flush will use a thread per data directory so you will get two or more writers. -# -# Two is generally enough to flush on a fast disk [array] mounted as a single data directory. -# Adding more flush writers will result in smaller more frequent flushes that introduce more -# compaction overhead. -# -# There is a direct tradeoff between number of memtables that can be flushed concurrently -# and flush size and frequency. More is not better you just need enough flush writers -# to never stall waiting for flushing to free memory. -# -#memtable_flush_writers: 2 - -# Total space to use for change-data-capture logs on disk. -# -# If space gets above this value, Cassandra will throw WriteTimeoutException -# on Mutations including tables with CDC enabled. A CDCCompactor is responsible -# for parsing the raw CDC logs and deleting them when parsing is completed. -# -# The default value is the min of 4096 mb and 1/8th of the total space -# of the drive where cdc_raw_directory resides. -# cdc_total_space_in_mb: 4096 - -# When we hit our cdc_raw limit and the CDCCompactor is either running behind -# or experiencing backpressure, we check at the following interval to see if any -# new space for cdc-tracked tables has been made available. Default to 250ms -# cdc_free_space_check_interval_ms: 250 - -# A fixed memory pool size in MB for for SSTable index summaries. If left -# empty, this will default to 5% of the heap size. If the memory usage of -# all index summaries exceeds this limit, SSTables with low read rates will -# shrink their index summaries in order to meet this limit. However, this -# is a best-effort process. In extreme conditions Cassandra may need to use -# more than this amount of memory. -index_summary_capacity_in_mb: - -# How frequently index summaries should be resampled. This is done -# periodically to redistribute memory from the fixed-size pool to sstables -# proportional their recent read rates. Setting to -1 will disable this -# process, leaving existing index summaries at their current sampling level. -index_summary_resize_interval_in_minutes: 60 - -# Whether to, when doing sequential writing, fsync() at intervals in -# order to force the operating system to flush the dirty -# buffers. Enable this to avoid sudden dirty buffer flushing from -# impacting read latencies. Almost always a good idea on SSDs; not -# necessarily on platters. -trickle_fsync: false -trickle_fsync_interval_in_kb: 10240 - -# TCP port, for commands and data -# For security reasons, you should not expose this port to the internet. Firewall it if needed. -storage_port: 7000 - -# SSL port, for encrypted communication. Unused unless enabled in -# encryption_options -# For security reasons, you should not expose this port to the internet. Firewall it if needed. -ssl_storage_port: 7001 - -# Address or interface to bind to and tell other Cassandra nodes to connect to. -# You _must_ change this if you want multiple nodes to be able to communicate! -# -# Set listen_address OR listen_interface, not both. -# -# Leaving it blank leaves it up to InetAddress.getLocalHost(). This -# will always do the Right Thing _if_ the node is properly configured -# (hostname, name resolution, etc), and the Right Thing is to use the -# address associated with the hostname (it might not be). -# -# Setting listen_address to 0.0.0.0 is always wrong. -# -listen_address: 127.0.0.1 - -# Set listen_address OR listen_interface, not both. Interfaces must correspond -# to a single address, IP aliasing is not supported. -# listen_interface: eth0 - -# If you choose to specify the interface by name and the interface has an ipv4 and an ipv6 address -# you can specify which should be chosen using listen_interface_prefer_ipv6. If false the first ipv4 -# address will be used. If true the first ipv6 address will be used. Defaults to false preferring -# ipv4. If there is only one address it will be selected regardless of ipv4/ipv6. -# listen_interface_prefer_ipv6: false - -# Address to broadcast to other Cassandra nodes -# Leaving this blank will set it to the same value as listen_address -# broadcast_address: 1.2.3.4 - -# When using multiple physical network interfaces, set this -# to true to listen on broadcast_address in addition to -# the listen_address, allowing nodes to communicate in both -# interfaces. -# Ignore this property if the network configuration automatically -# routes between the public and private networks such as EC2. -# listen_on_broadcast_address: false - -# Internode authentication backend, implementing IInternodeAuthenticator; -# used to allow/disallow connections from peer nodes. -# internode_authenticator: org.apache.cassandra.auth.AllowAllInternodeAuthenticator - -# Whether to start the native transport server. -# Please note that the address on which the native transport is bound is the -# same as the rpc_address. The port however is different and specified below. -start_native_transport: true -# port for the CQL native transport to listen for clients on -# For security reasons, you should not expose this port to the internet. Firewall it if needed. -native_transport_port: 9042 -# Enabling native transport encryption in client_encryption_options allows you to either use -# encryption for the standard port or to use a dedicated, additional port along with the unencrypted -# standard native_transport_port. -# Enabling client encryption and keeping native_transport_port_ssl disabled will use encryption -# for native_transport_port. Setting native_transport_port_ssl to a different value -# from native_transport_port will use encryption for native_transport_port_ssl while -# keeping native_transport_port unencrypted. -# native_transport_port_ssl: 9142 -# The maximum threads for handling requests when the native transport is used. -# This is similar to rpc_max_threads though the default differs slightly (and -# there is no native_transport_min_threads, idle threads will always be stopped -# after 30 seconds). -# native_transport_max_threads: 128 -# -# The maximum size of allowed frame. Frame (requests) larger than this will -# be rejected as invalid. The default is 256MB. If you're changing this parameter, -# you may want to adjust max_value_size_in_mb accordingly. This should be positive and less than 2048. -# native_transport_max_frame_size_in_mb: 256 - -# The maximum number of concurrent client connections. -# The default is -1, which means unlimited. -# native_transport_max_concurrent_connections: -1 - -# The maximum number of concurrent client connections per source ip. -# The default is -1, which means unlimited. -# native_transport_max_concurrent_connections_per_ip: -1 - -# Whether to start the thrift rpc server. -start_rpc: true - -# The address or interface to bind the Thrift RPC service and native transport -# server to. -# -# Set rpc_address OR rpc_interface, not both. -# -# Leaving rpc_address blank has the same effect as on listen_address -# (i.e. it will be based on the configured hostname of the node). -# -# Note that unlike listen_address, you can specify 0.0.0.0, but you must also -# set broadcast_rpc_address to a value other than 0.0.0.0. -# -# For security reasons, you should not expose this port to the internet. Firewall it if needed. -rpc_address: 0.0.0.0 - -# Set rpc_address OR rpc_interface, not both. Interfaces must correspond -# to a single address, IP aliasing is not supported. -# rpc_interface: eth1 - -# If you choose to specify the interface by name and the interface has an ipv4 and an ipv6 address -# you can specify which should be chosen using rpc_interface_prefer_ipv6. If false the first ipv4 -# address will be used. If true the first ipv6 address will be used. Defaults to false preferring -# ipv4. If there is only one address it will be selected regardless of ipv4/ipv6. -# rpc_interface_prefer_ipv6: false - -# port for Thrift to listen for clients on -rpc_port: 9160 - -# RPC address to broadcast to drivers and other Cassandra nodes. This cannot -# be set to 0.0.0.0. If left blank, this will be set to the value of -# rpc_address. If rpc_address is set to 0.0.0.0, broadcast_rpc_address must -# be set. -broadcast_rpc_address: 127.0.0.1 - -# enable or disable keepalive on rpc/native connections -rpc_keepalive: true - -# Cassandra provides two out-of-the-box options for the RPC Server: -# -# sync -# One thread per thrift connection. For a very large number of clients, memory -# will be your limiting factor. On a 64 bit JVM, 180KB is the minimum stack size -# per thread, and that will correspond to your use of virtual memory (but physical memory -# may be limited depending on use of stack space). -# -# hsha -# Stands for "half synchronous, half asynchronous." All thrift clients are handled -# asynchronously using a small number of threads that does not vary with the amount -# of thrift clients (and thus scales well to many clients). The rpc requests are still -# synchronous (one thread per active request). If hsha is selected then it is essential -# that rpc_max_threads is changed from the default value of unlimited. -# -# The default is sync because on Windows hsha is about 30% slower. On Linux, -# sync/hsha performance is about the same, with hsha of course using less memory. -# -# Alternatively, can provide your own RPC server by providing the fully-qualified class name -# of an o.a.c.t.TServerFactory that can create an instance of it. -rpc_server_type: sync - -# Uncomment rpc_min|max_thread to set request pool size limits. -# -# Regardless of your choice of RPC server (see above), the number of maximum requests in the -# RPC thread pool dictates how many concurrent requests are possible (but if you are using the sync -# RPC server, it also dictates the number of clients that can be connected at all). -# -# The default is unlimited and thus provides no protection against clients overwhelming the server. You are -# encouraged to set a maximum that makes sense for you in production, but do keep in mind that -# rpc_max_threads represents the maximum number of client requests this server may execute concurrently. -# -# rpc_min_threads: 16 -# rpc_max_threads: 2048 - -# uncomment to set socket buffer sizes on rpc connections -# rpc_send_buff_size_in_bytes: -# rpc_recv_buff_size_in_bytes: - -# Uncomment to set socket buffer size for internode communication -# Note that when setting this, the buffer size is limited by net.core.wmem_max -# and when not setting it it is defined by net.ipv4.tcp_wmem -# See also: -# /proc/sys/net/core/wmem_max -# /proc/sys/net/core/rmem_max -# /proc/sys/net/ipv4/tcp_wmem -# /proc/sys/net/ipv4/tcp_wmem -# and 'man tcp' -# internode_send_buff_size_in_bytes: - -# Uncomment to set socket buffer size for internode communication -# Note that when setting this, the buffer size is limited by net.core.wmem_max -# and when not setting it it is defined by net.ipv4.tcp_wmem -# internode_recv_buff_size_in_bytes: - -# Frame size for thrift (maximum message length). -thrift_framed_transport_size_in_mb: 15 - -# Set to true to have Cassandra create a hard link to each sstable -# flushed or streamed locally in a backups/ subdirectory of the -# keyspace data. Removing these links is the operator's -# responsibility. -incremental_backups: false - -# Whether or not to take a snapshot before each compaction. Be -# careful using this option, since Cassandra won't clean up the -# snapshots for you. Mostly useful if you're paranoid when there -# is a data format change. -snapshot_before_compaction: false - -# Whether or not a snapshot is taken of the data before keyspace truncation -# or dropping of column families. The STRONGLY advised default of true -# should be used to provide data safety. If you set this flag to false, you will -# lose data on truncation or drop. -auto_snapshot: true - -# Granularity of the collation index of rows within a partition. -# Increase if your rows are large, or if you have a very large -# number of rows per partition. The competing goals are these: -# -# - a smaller granularity means more index entries are generated -# and looking up rows withing the partition by collation column -# is faster -# - but, Cassandra will keep the collation index in memory for hot -# rows (as part of the key cache), so a larger granularity means -# you can cache more hot rows -column_index_size_in_kb: 64 - -# Per sstable indexed key cache entries (the collation index in memory -# mentioned above) exceeding this size will not be held on heap. -# This means that only partition information is held on heap and the -# index entries are read from disk. -# -# Note that this size refers to the size of the -# serialized index information and not the size of the partition. -column_index_cache_size_in_kb: 2 - -# Number of simultaneous compactions to allow, NOT including -# validation "compactions" for anti-entropy repair. Simultaneous -# compactions can help preserve read performance in a mixed read/write -# workload, by mitigating the tendency of small sstables to accumulate -# during a single long running compactions. The default is usually -# fine and if you experience problems with compaction running too -# slowly or too fast, you should look at -# compaction_throughput_mb_per_sec first. -# -# concurrent_compactors defaults to the smaller of (number of disks, -# number of cores), with a minimum of 2 and a maximum of 8. -# -# If your data directories are backed by SSD, you should increase this -# to the number of cores. -#concurrent_compactors: 1 - -# Throttles compaction to the given total throughput across the entire -# system. The faster you insert data, the faster you need to compact in -# order to keep the sstable count down, but in general, setting this to -# 16 to 32 times the rate you are inserting data is more than sufficient. -# Setting this to 0 disables throttling. Note that this account for all types -# of compaction, including validation compaction. -compaction_throughput_mb_per_sec: 16 - -# When compacting, the replacement sstable(s) can be opened before they -# are completely written, and used in place of the prior sstables for -# any range that has been written. This helps to smoothly transfer reads -# between the sstables, reducing page cache churn and keeping hot rows hot -sstable_preemptive_open_interval_in_mb: 50 - -# Throttles all outbound streaming file transfers on this node to the -# given total throughput in Mbps. This is necessary because Cassandra does -# mostly sequential IO when streaming data during bootstrap or repair, which -# can lead to saturating the network connection and degrading rpc performance. -# When unset, the default is 200 Mbps or 25 MB/s. -# stream_throughput_outbound_megabits_per_sec: 200 - -# Throttles all streaming file transfer between the datacenters, -# this setting allows users to throttle inter dc stream throughput in addition -# to throttling all network stream traffic as configured with -# stream_throughput_outbound_megabits_per_sec -# When unset, the default is 200 Mbps or 25 MB/s -# inter_dc_stream_throughput_outbound_megabits_per_sec: 200 - -# How long the coordinator should wait for read operations to complete -read_request_timeout_in_ms: 5000 -# How long the coordinator should wait for seq or index scans to complete -range_request_timeout_in_ms: 10000 -# How long the coordinator should wait for writes to complete -write_request_timeout_in_ms: 2000 -# How long the coordinator should wait for counter writes to complete -counter_write_request_timeout_in_ms: 5000 -# How long a coordinator should continue to retry a CAS operation -# that contends with other proposals for the same row -cas_contention_timeout_in_ms: 1000 -# How long the coordinator should wait for truncates to complete -# (This can be much longer, because unless auto_snapshot is disabled -# we need to flush first so we can snapshot before removing the data.) -truncate_request_timeout_in_ms: 60000 -# The default timeout for other, miscellaneous operations -request_timeout_in_ms: 10000 - -# How long before a node logs slow queries. Select queries that take longer than -# this timeout to execute, will generate an aggregated log message, so that slow queries -# can be identified. Set this value to zero to disable slow query logging. -slow_query_log_timeout_in_ms: 500 - -# Enable operation timeout information exchange between nodes to accurately -# measure request timeouts. If disabled, replicas will assume that requests -# were forwarded to them instantly by the coordinator, which means that -# under overload conditions we will waste that much extra time processing -# already-timed-out requests. -# -# Warning: before enabling this property make sure to ntp is installed -# and the times are synchronized between the nodes. -cross_node_timeout: false - -# Set keep-alive period for streaming -# This node will send a keep-alive message periodically with this period. -# If the node does not receive a keep-alive message from the peer for -# 2 keep-alive cycles the stream session times out and fail -# Default value is 300s (5 minutes), which means stalled stream -# times out in 10 minutes by default -# streaming_keep_alive_period_in_secs: 300 - -# phi value that must be reached for a host to be marked down. -# most users should never need to adjust this. -# phi_convict_threshold: 8 - -# endpoint_snitch -- Set this to a class that implements -# IEndpointSnitch. The snitch has two functions: -# -# - it teaches Cassandra enough about your network topology to route -# requests efficiently -# - it allows Cassandra to spread replicas around your cluster to avoid -# correlated failures. It does this by grouping machines into -# "datacenters" and "racks." Cassandra will do its best not to have -# more than one replica on the same "rack" (which may not actually -# be a physical location) -# -# CASSANDRA WILL NOT ALLOW YOU TO SWITCH TO AN INCOMPATIBLE SNITCH -# ONCE DATA IS INSERTED INTO THE CLUSTER. This would cause data loss. -# This means that if you start with the default SimpleSnitch, which -# locates every node on "rack1" in "datacenter1", your only options -# if you need to add another datacenter are GossipingPropertyFileSnitch -# (and the older PFS). From there, if you want to migrate to an -# incompatible snitch like Ec2Snitch you can do it by adding new nodes -# under Ec2Snitch (which will locate them in a new "datacenter") and -# decommissioning the old ones. -# -# Out of the box, Cassandra provides: -# -# SimpleSnitch: -# Treats Strategy order as proximity. This can improve cache -# locality when disabling read repair. Only appropriate for -# single-datacenter deployments. -# -# GossipingPropertyFileSnitch -# This should be your go-to snitch for production use. The rack -# and datacenter for the local node are defined in -# cassandra-rackdc.properties and propagated to other nodes via -# gossip. If cassandra-topology.properties exists, it is used as a -# fallback, allowing migration from the PropertyFileSnitch. -# -# PropertyFileSnitch: -# Proximity is determined by rack and data center, which are -# explicitly configured in cassandra-topology.properties. -# -# Ec2Snitch: -# Appropriate for EC2 deployments in a single Region. Loads Region -# and Availability Zone information from the EC2 API. The Region is -# treated as the datacenter, and the Availability Zone as the rack. -# Only private IPs are used, so this will not work across multiple -# Regions. -# -# Ec2MultiRegionSnitch: -# Uses public IPs as broadcast_address to allow cross-region -# connectivity. (Thus, you should set seed addresses to the public -# IP as well.) You will need to open the storage_port or -# ssl_storage_port on the public IP firewall. (For intra-Region -# traffic, Cassandra will switch to the private IP after -# establishing a connection.) -# -# RackInferringSnitch: -# Proximity is determined by rack and data center, which are -# assumed to correspond to the 3rd and 2nd octet of each node's IP -# address, respectively. Unless this happens to match your -# deployment conventions, this is best used as an example of -# writing a custom Snitch class and is provided in that spirit. -# -# You can use a custom Snitch by setting this to the full class name -# of the snitch, which will be assumed to be on your classpath. -endpoint_snitch: SimpleSnitch - -# controls how often to perform the more expensive part of host score -# calculation -dynamic_snitch_update_interval_in_ms: 100 -# controls how often to reset all host scores, allowing a bad host to -# possibly recover -dynamic_snitch_reset_interval_in_ms: 600000 -# if set greater than zero and read_repair_chance is < 1.0, this will allow -# 'pinning' of replicas to hosts in order to increase cache capacity. -# The badness threshold will control how much worse the pinned host has to be -# before the dynamic snitch will prefer other replicas over it. This is -# expressed as a double which represents a percentage. Thus, a value of -# 0.2 means Cassandra would continue to prefer the static snitch values -# until the pinned host was 20% worse than the fastest. -dynamic_snitch_badness_threshold: 0.1 - -# request_scheduler -- Set this to a class that implements -# RequestScheduler, which will schedule incoming client requests -# according to the specific policy. This is useful for multi-tenancy -# with a single Cassandra cluster. -# NOTE: This is specifically for requests from the client and does -# not affect inter node communication. -# org.apache.cassandra.scheduler.NoScheduler - No scheduling takes place -# org.apache.cassandra.scheduler.RoundRobinScheduler - Round robin of -# client requests to a node with a separate queue for each -# request_scheduler_id. The scheduler is further customized by -# request_scheduler_options as described below. -request_scheduler: org.apache.cassandra.scheduler.NoScheduler - -# Scheduler Options vary based on the type of scheduler -# -# NoScheduler -# Has no options -# -# RoundRobin -# throttle_limit -# The throttle_limit is the number of in-flight -# requests per client. Requests beyond -# that limit are queued up until -# running requests can complete. -# The value of 80 here is twice the number of -# concurrent_reads + concurrent_writes. -# default_weight -# default_weight is optional and allows for -# overriding the default which is 1. -# weights -# Weights are optional and will default to 1 or the -# overridden default_weight. The weight translates into how -# many requests are handled during each turn of the -# RoundRobin, based on the scheduler id. -# -# request_scheduler_options: -# throttle_limit: 80 -# default_weight: 5 -# weights: -# Keyspace1: 1 -# Keyspace2: 5 - -# request_scheduler_id -- An identifier based on which to perform -# the request scheduling. Currently the only valid option is keyspace. -# request_scheduler_id: keyspace - -# Enable or disable inter-node encryption -# JVM defaults for supported SSL socket protocols and cipher suites can -# be replaced using custom encryption options. This is not recommended -# unless you have policies in place that dictate certain settings, or -# need to disable vulnerable ciphers or protocols in case the JVM cannot -# be updated. -# FIPS compliant settings can be configured at JVM level and should not -# involve changing encryption settings here: -# https://docs.oracle.com/javase/8/docs/technotes/guides/security/jsse/FIPS.html -# *NOTE* No custom encryption options are enabled at the moment -# The available internode options are : all, none, dc, rack -# -# If set to dc cassandra will encrypt the traffic between the DCs -# If set to rack cassandra will encrypt the traffic between the racks -# -# The passwords used in these options must match the passwords used when generating -# the keystore and truststore. For instructions on generating these files, see: -# http://download.oracle.com/javase/6/docs/technotes/guides/security/jsse/JSSERefGuide.html#CreateKeystore -# -server_encryption_options: - internode_encryption: none - keystore: conf/.keystore - keystore_password: cassandra - truststore: conf/.truststore - truststore_password: cassandra - # More advanced defaults below: - # protocol: TLS - # algorithm: SunX509 - # store_type: JKS - # cipher_suites: [TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_DHE_RSA_WITH_AES_128_CBC_SHA,TLS_DHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA] - # require_client_auth: false - # require_endpoint_verification: false - -# enable or disable client/server encryption. -client_encryption_options: - enabled: false - # If enabled and optional is set to true encrypted and unencrypted connections are handled. - optional: false - keystore: conf/.keystore - keystore_password: cassandra - # require_client_auth: false - # Set trustore and truststore_password if require_client_auth is true - # truststore: conf/.truststore - # truststore_password: cassandra - # More advanced defaults below: - # protocol: TLS - # algorithm: SunX509 - # store_type: JKS - # cipher_suites: [TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_DHE_RSA_WITH_AES_128_CBC_SHA,TLS_DHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA] - -# internode_compression controls whether traffic between nodes is -# compressed. -# Can be: -# -# all -# all traffic is compressed -# -# dc -# traffic between different datacenters is compressed -# -# none -# nothing is compressed. -internode_compression: dc - -# Enable or disable tcp_nodelay for inter-dc communication. -# Disabling it will result in larger (but fewer) network packets being sent, -# reducing overhead from the TCP protocol itself, at the cost of increasing -# latency if you block for cross-datacenter responses. -inter_dc_tcp_nodelay: false - -# TTL for different trace types used during logging of the repair process. -tracetype_query_ttl: 86400 -tracetype_repair_ttl: 604800 - -# By default, Cassandra logs GC Pauses greater than 200 ms at INFO level -# This threshold can be adjusted to minimize logging if necessary -# gc_log_threshold_in_ms: 200 - -# If unset, all GC Pauses greater than gc_log_threshold_in_ms will log at -# INFO level -# UDFs (user defined functions) are disabled by default. -# As of Cassandra 3.0 there is a sandbox in place that should prevent execution of evil code. -enable_user_defined_functions: false - -# Enables scripted UDFs (JavaScript UDFs). -# Java UDFs are always enabled, if enable_user_defined_functions is true. -# Enable this option to be able to use UDFs with "language javascript" or any custom JSR-223 provider. -# This option has no effect, if enable_user_defined_functions is false. -enable_scripted_user_defined_functions: false - -# Enables materialized view creation on this node. -# Materialized views are considered experimental and are not recommended for production use. -enable_materialized_views: true - -# The default Windows kernel timer and scheduling resolution is 15.6ms for power conservation. -# Lowering this value on Windows can provide much tighter latency and better throughput, however -# some virtualized environments may see a negative performance impact from changing this setting -# below their system default. The sysinternals 'clockres' tool can confirm your system's default -# setting. -windows_timer_interval: 1 - - -# Enables encrypting data at-rest (on disk). Different key providers can be plugged in, but the default reads from -# a JCE-style keystore. A single keystore can hold multiple keys, but the one referenced by -# the "key_alias" is the only key that will be used for encrypt opertaions; previously used keys -# can still (and should!) be in the keystore and will be used on decrypt operations -# (to handle the case of key rotation). -# -# It is strongly recommended to download and install Java Cryptography Extension (JCE) -# Unlimited Strength Jurisdiction Policy Files for your version of the JDK. -# (current link: http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html) -# -# Currently, only the following file types are supported for transparent data encryption, although -# more are coming in future cassandra releases: commitlog, hints -transparent_data_encryption_options: - enabled: false - chunk_length_kb: 64 - cipher: AES/CBC/PKCS5Padding - key_alias: testing:1 - # CBC IV length for AES needs to be 16 bytes (which is also the default size) - # iv_length: 16 - key_provider: - - class_name: org.apache.cassandra.security.JKSKeyProvider - parameters: - - keystore: conf/.keystore - keystore_password: cassandra - store_type: JCEKS - key_password: cassandra - - -##################### -# SAFETY THRESHOLDS # -##################### - -# When executing a scan, within or across a partition, we need to keep the -# tombstones seen in memory so we can return them to the coordinator, which -# will use them to make sure other replicas also know about the deleted rows. -# With workloads that generate a lot of tombstones, this can cause performance -# problems and even exaust the server heap. -# (http://www.datastax.com/dev/blog/cassandra-anti-patterns-queues-and-queue-like-datasets) -# Adjust the thresholds here if you understand the dangers and want to -# scan more tombstones anyway. These thresholds may also be adjusted at runtime -# using the StorageService mbean. -tombstone_warn_threshold: 1000 -tombstone_failure_threshold: 100000 - -# Log WARN on any multiple-partition batch size exceeding this value. 5kb per batch by default. -# Caution should be taken on increasing the size of this threshold as it can lead to node instability. -batch_size_warn_threshold_in_kb: 5 - -# Fail any multiple-partition batch exceeding this value. 50kb (10x warn threshold) by default. -batch_size_fail_threshold_in_kb: 50 - -# Log WARN on any batches not of type LOGGED than span across more partitions than this limit -unlogged_batch_across_partitions_warn_threshold: 10 - -# Log a warning when compacting partitions larger than this value -compaction_large_partition_warning_threshold_mb: 100 - -# GC Pauses greater than gc_warn_threshold_in_ms will be logged at WARN level -# Adjust the threshold based on your application throughput requirement -# By default, Cassandra logs GC Pauses greater than 200 ms at INFO level -gc_warn_threshold_in_ms: 1000 - -# Maximum size of any value in SSTables. Safety measure to detect SSTable corruption -# early. Any value size larger than this threshold will result into marking an SSTable -# as corrupted. This should be positive and less than 2048. -# max_value_size_in_mb: 256 - -# Back-pressure settings # -# If enabled, the coordinator will apply the back-pressure strategy specified below to each mutation -# sent to replicas, with the aim of reducing pressure on overloaded replicas. -back_pressure_enabled: false -# The back-pressure strategy applied. -# The default implementation, RateBasedBackPressure, takes three arguments: -# high ratio, factor, and flow type, and uses the ratio between incoming mutation responses and outgoing mutation requests. -# If below high ratio, outgoing mutations are rate limited according to the incoming rate decreased by the given factor; -# if above high ratio, the rate limiting is increased by the given factor; -# such factor is usually best configured between 1 and 10, use larger values for a faster recovery -# at the expense of potentially more dropped mutations; -# the rate limiting is applied according to the flow type: if FAST, it's rate limited at the speed of the fastest replica, -# if SLOW at the speed of the slowest one. -# New strategies can be added. Implementors need to implement org.apache.cassandra.net.BackpressureStrategy and -# provide a public constructor accepting a Map. -back_pressure_strategy: - - class_name: org.apache.cassandra.net.RateBasedBackPressure - parameters: - - high_ratio: 0.90 - factor: 5 - flow: FAST - -# Coalescing Strategies # -# Coalescing multiples messages turns out to significantly boost message processing throughput (think doubling or more). -# On bare metal, the floor for packet processing throughput is high enough that many applications won't notice, but in -# virtualized environments, the point at which an application can be bound by network packet processing can be -# surprisingly low compared to the throughput of task processing that is possible inside a VM. It's not that bare metal -# doesn't benefit from coalescing messages, it's that the number of packets a bare metal network interface can process -# is sufficient for many applications such that no load starvation is experienced even without coalescing. -# There are other benefits to coalescing network messages that are harder to isolate with a simple metric like messages -# per second. By coalescing multiple tasks together, a network thread can process multiple messages for the cost of one -# trip to read from a socket, and all the task submission work can be done at the same time reducing context switching -# and increasing cache friendliness of network message processing. -# See CASSANDRA-8692 for details. - -# Strategy to use for coalescing messages in OutboundTcpConnection. -# Can be fixed, movingaverage, timehorizon, disabled (default). -# You can also specify a subclass of CoalescingStrategies.CoalescingStrategy by name. -# otc_coalescing_strategy: DISABLED - -# How many microseconds to wait for coalescing. For fixed strategy this is the amount of time after the first -# message is received before it will be sent with any accompanying messages. For moving average this is the -# maximum amount of time that will be waited as well as the interval at which messages must arrive on average -# for coalescing to be enabled. -# otc_coalescing_window_us: 200 - -# Do not try to coalesce messages if we already got that many messages. This should be more than 2 and less than 128. -# otc_coalescing_enough_coalesced_messages: 8 - -# How many milliseconds to wait between two expiration runs on the backlog (queue) of the OutboundTcpConnection. -# Expiration is done if messages are piling up in the backlog. Droppable messages are expired to free the memory -# taken by expired messages. The interval should be between 0 and 1000, and in most installations the default value -# will be appropriate. A smaller value could potentially expire messages slightly sooner at the expense of more CPU -# time and queue contention while iterating the backlog of messages. -# An interval of 0 disables any wait time, which is the behavior of former Cassandra versions. -# -# otc_backlog_expiration_interval_ms: 200 diff --git a/.ci/scripts/windows/docker/elasticsearch/Dockerfile b/.ci/scripts/windows/docker/elasticsearch/Dockerfile deleted file mode 100644 index 2104910250..0000000000 --- a/.ci/scripts/windows/docker/elasticsearch/Dockerfile +++ /dev/null @@ -1,43 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 AS installer -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -ARG ES_VERSION="6.7.2" -ENV ES_HOME="C:\elasticsearch" ` - ES_ROOT_URL="https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch" - -RUN Write-Host "Downloading: $env:ES_ROOT_URL-$env:ES_VERSION.zip"; ` - Invoke-WebRequest "$env:ES_ROOT_URL-$env:ES_VERSION.zip.sha512" -OutFile 'elasticsearch.zip.sha' -UseBasicParsing; ` - $env:ES_SHA = (Get-Content -Raw elasticsearch.zip.sha).Split(' ')[0]; ` - Invoke-WebRequest "$env:ES_ROOT_URL-$env:ES_VERSION.zip" -OutFile 'elasticsearch.zip' -UseBasicParsing; ` - if ((Get-FileHash elasticsearch.zip -Algorithm sha512).Hash.ToLower() -ne $env:ES_SHA) {exit 1}; ` - Expand-Archive elasticsearch.zip -DestinationPath C:\ ; ` - Move-Item c:/elasticsearch-$($env:ES_VERSION) $env:ES_HOME; - -# Elasticsearch -FROM openjdk:8-windowsservercore-1809 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop';"] - -ARG ES_VERSION="6.7.2" -ENV ES_VERSION=${ES_VERSION} ` - ES_HOME="C:\elasticsearch" ` - ES_JAVA_OPTS="-Xms512m -Xmx512m" - -VOLUME C:\data -EXPOSE 9200 9300 - -SHELL ["cmd", "/S", "/C"] -CMD ".\bin\elasticsearch.bat" - -WORKDIR $ES_HOME -COPY --from=installer C:\elasticsearch\ . -COPY elasticsearch.yml ./config/elasticsearch.yml - -HEALTHCHECK --interval=5s ` - CMD powershell -command ` - try { ` - $content = (iwr -useb http://localhost:9200/_cat/health).Content; ` - $health = $content.Split(' ')[3]; ` - if ($health -eq 'green' -or $health -eq 'yellow') { return 0 } ` - else { return 1 }; ` - } catch { return 1 } diff --git a/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml b/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml deleted file mode 100644 index d43c03a8c7..0000000000 --- a/.ci/scripts/windows/docker/elasticsearch/elasticsearch.yml +++ /dev/null @@ -1,8 +0,0 @@ -network.host: 0.0.0.0 - -# this value is required because we set "network.host" -# be sure to modify it appropriately for a production cluster deployment -discovery.zen.minimum_master_nodes: 1 - -path: - data: C:\data diff --git a/.ci/scripts/windows/docker/log-services.bat b/.ci/scripts/windows/docker/log-services.bat deleted file mode 100644 index ec21c7f86c..0000000000 --- a/.ci/scripts/windows/docker/log-services.bat +++ /dev/null @@ -1,8 +0,0 @@ -docker ps -a -docker logs cassandra -docker logs elasticsearch -docker logs mongodb -docker logs mssql -docker logs mysql -docker logs postgres -docker logs redis diff --git a/.ci/scripts/windows/docker/mongodb/Dockerfile b/.ci/scripts/windows/docker/mongodb/Dockerfile deleted file mode 100644 index 559017e576..0000000000 --- a/.ci/scripts/windows/docker/mongodb/Dockerfile +++ /dev/null @@ -1,21 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) - -ARG VERSION="4.2.0" -ENV MONGODB_HOME="C:\ProgramData\MongoDB\log" -WORKDIR $MONGODB_HOME -RUN choco install mongodb --version=${env:VERSION} --no-progress -y - -EXPOSE 27017 - -# Override confgs to enable the remote access -ENV MONGODB_BIN="C:\Program Files\MongoDB\Server\4.2\bin" -WORKDIR $MONGODB_BIN -COPY mongod.cfg . -WORKDIR $MONGODB_HOME - -# Keep running the container with the event logs in the stdout. -CMD ["powershell", "Get-Content", "mongod.log", "-Wait"] diff --git a/.ci/scripts/windows/docker/mongodb/mongod.cfg b/.ci/scripts/windows/docker/mongodb/mongod.cfg deleted file mode 100644 index 35402f0a13..0000000000 --- a/.ci/scripts/windows/docker/mongodb/mongod.cfg +++ /dev/null @@ -1,21 +0,0 @@ -# mongod.conf - -# for documentation of all options, see: -# http://docs.mongodb.org/manual/reference/configuration-options/ - -# Where and how to store data. -storage: - dbPath: C:\ProgramData\MongoDB\data\db - journal: - enabled: true - -# where to write logging data. -systemLog: - destination: file - logAppend: true - path: C:\ProgramData\MongoDB\log\mongod.log - -# network interfaces -net: - port: 27017 - bindIp: 0.0.0.0 diff --git a/.ci/scripts/windows/docker/mssql/Dockerfile b/.ci/scripts/windows/docker/mssql/Dockerfile deleted file mode 100644 index 9446dd5a90..0000000000 --- a/.ci/scripts/windows/docker/mssql/Dockerfile +++ /dev/null @@ -1,31 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -# Download Links: -ENV exe "https://go.microsoft.com/fwlink/?linkid=840945" -ENV box "https://go.microsoft.com/fwlink/?linkid=840944" - -ENV sa_password="_" ` - attach_dbs="[]" ` - ACCEPT_EULA="_" ` - sa_password_path="C:\ProgramData\Docker\secrets\sa-password" - -EXPOSE 1433 -COPY start.ps1 / -WORKDIR / - -RUN Invoke-WebRequest -Uri $env:box -OutFile SQL.box ; ` - Invoke-WebRequest -Uri $env:exe -OutFile SQL.exe ; ` - Start-Process -Wait -FilePath .\SQL.exe -ArgumentList /qs, /x:setup ; ` - .\setup\setup.exe /q /ACTION=Install /INSTANCENAME=MSSQLSERVER /FEATURES=SQLEngine /UPDATEENABLED=0 /SQLSVCACCOUNT='NT AUTHORITY\NETWORK SERVICE' /SQLSYSADMINACCOUNTS='BUILTIN\ADMINISTRATORS' /TCPENABLED=1 /NPENABLED=0 /IACCEPTSQLSERVERLICENSETERMS ; ` - Remove-Item -Recurse -Force SQL.exe, SQL.box, setup - -RUN stop-service MSSQLSERVER ; ` - set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\supersocketnetlib\tcp\ipall' -name tcpdynamicports -value '' ; ` - set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\supersocketnetlib\tcp\ipall' -name tcpport -value 1433 ; ` - set-itemproperty -path 'HKLM:\software\microsoft\microsoft sql server\mssql14.MSSQLSERVER\mssqlserver\' -name LoginMode -value 2 ; - -HEALTHCHECK CMD [ "sqlcmd", "-Q", "select 1" ] - -CMD .\start -sa_password $env:sa_password -ACCEPT_EULA $env:ACCEPT_EULA -attach_dbs \"$env:attach_dbs\" -Verbose diff --git a/.ci/scripts/windows/docker/mssql/start.ps1 b/.ci/scripts/windows/docker/mssql/start.ps1 deleted file mode 100644 index 090f9eb0c9..0000000000 --- a/.ci/scripts/windows/docker/mssql/start.ps1 +++ /dev/null @@ -1,77 +0,0 @@ -# The script sets the sa password and start the SQL Service -# Also it attaches additional database from the disk -# The format for attach_dbs - -param( -[Parameter(Mandatory=$false)] -[string]$sa_password, - -[Parameter(Mandatory=$false)] -[string]$ACCEPT_EULA, - -[Parameter(Mandatory=$false)] -[string]$attach_dbs -) - - -if($ACCEPT_EULA -ne "Y" -And $ACCEPT_EULA -ne "y") -{ - Write-Verbose "ERROR: You must accept the End User License Agreement before this container can start." - Write-Verbose "Set the environment variable ACCEPT_EULA to 'Y' if you accept the agreement." - - exit 1 -} - -# start the service -Write-Verbose "Starting SQL Server" -start-service MSSQLSERVER - -if($sa_password -eq "_") { - if (Test-Path $env:sa_password_path) { - $sa_password = Get-Content -Raw $secretPath - } - else { - Write-Verbose "WARN: Using default SA password, secret file not found at: $secretPath" - } -} - -if($sa_password -ne "_") -{ - Write-Verbose "Changing SA login credentials" - $sqlcmd = "ALTER LOGIN sa with password=" +"'" + $sa_password + "'" + ";ALTER LOGIN sa ENABLE;" - & sqlcmd -Q $sqlcmd -} - -$attach_dbs_cleaned = $attach_dbs.TrimStart('\\').TrimEnd('\\') - -$dbs = $attach_dbs_cleaned | ConvertFrom-Json - -if ($null -ne $dbs -And $dbs.Length -gt 0) -{ - Write-Verbose "Attaching $($dbs.Length) database(s)" - - Foreach($db in $dbs) - { - $files = @(); - Foreach($file in $db.dbFiles) - { - $files += "(FILENAME = N'$($file)')"; - } - - $files = $files -join "," - $sqlcmd = "IF EXISTS (SELECT 1 FROM SYS.DATABASES WHERE NAME = '" + $($db.dbName) + "') BEGIN EXEC sp_detach_db [$($db.dbName)] END;CREATE DATABASE [$($db.dbName)] ON $($files) FOR ATTACH;" - - Write-Verbose "Invoke-Sqlcmd -Query $($sqlcmd)" - & sqlcmd -Q $sqlcmd - } -} - -Write-Verbose "Started SQL Server." - -$lastCheck = (Get-Date).AddSeconds(-2) -while ($true) -{ - Get-EventLog -LogName Application -Source "MSSQL*" -After $lastCheck | Select-Object TimeGenerated, EntryType, Message - $lastCheck = Get-Date - Start-Sleep -Seconds 2 -} diff --git a/.ci/scripts/windows/docker/mysql/Dockerfile b/.ci/scripts/windows/docker/mysql/Dockerfile deleted file mode 100644 index e1e20357d4..0000000000 --- a/.ci/scripts/windows/docker/mysql/Dockerfile +++ /dev/null @@ -1,20 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) - -ARG VERSION="8.0.17" -ENV MYSQL_HOME="C:\tools\mysql\current" -ENV MYSQL_USER="elastic" -ENV MYSQL_PASSWORD="password123_" -RUN choco install mysql --version=${env:VERSION} --no-progress -y - -EXPOSE 3306 -WORKDIR $MYSQL_HOME -COPY my.ini . - -HEALTHCHECK CMD [ "mysql", "-h", "127.0.0.1", "-P", "3306", "-u", "root", "-e", "SELECT 1"] - -COPY entrypoint.ps1 . -CMD .\entrypoint diff --git a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 b/.ci/scripts/windows/docker/mysql/entrypoint.ps1 deleted file mode 100644 index 218f45514f..0000000000 --- a/.ci/scripts/windows/docker/mysql/entrypoint.ps1 +++ /dev/null @@ -1,12 +0,0 @@ -Write-Host "Wait a few seconds until the mysql is ready..." -sleep 15 -Write-Host "Create users for remote access..." -mysql -h 127.0.0.1 -P 3306 -u root -e @" - SELECT user,host FROM mysql.user; - CREATE USER '$env:MYSQL_USER'@'%' IDENTIFIED WITH mysql_native_password BY '$env:MYSQL_PASSWORD'; - GRANT ALL PRIVILEGES ON *.* TO $env:MYSQL_USER@'%'; - SELECT user,host FROM mysql.user; -"@ -Write-Host "Show mysql log output in the console..." -# Keep running the container with the event logs in the stdout. -Get-Content C:\\mysql.log -Wait diff --git a/.ci/scripts/windows/docker/mysql/my.ini b/.ci/scripts/windows/docker/mysql/my.ini deleted file mode 100644 index 6350ec92f5..0000000000 --- a/.ci/scripts/windows/docker/mysql/my.ini +++ /dev/null @@ -1,6 +0,0 @@ -[mysqld] -basedir=C:\\tools\\mysql\\current -datadir=C:\\ProgramData\\MySQL\\data -log_error=C:\\mysql.log -log_error_verbosity=3 -bind-address=0.0.0.0 diff --git a/.ci/scripts/windows/docker/postgres/Dockerfile b/.ci/scripts/windows/docker/postgres/Dockerfile deleted file mode 100644 index c4fd66e6f2..0000000000 --- a/.ci/scripts/windows/docker/postgres/Dockerfile +++ /dev/null @@ -1,18 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -RUN Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) - -ARG VERSION="10.6.0.0" -ENV POSTGRES_HOME="C:\Program Files\PostgreSQL\10\data" -WORKDIR $POSTGRES_HOME -RUN choco install postgresql10 --version=${env:VERSION} --params '/Password:Password12!' --no-progress -y - -EXPOSE 5432 - -COPY postgresql.conf . -COPY pg_hba.conf . -COPY entrypoint.ps1 . - -CMD .\entrypoint diff --git a/.ci/scripts/windows/docker/postgres/entrypoint.ps1 b/.ci/scripts/windows/docker/postgres/entrypoint.ps1 deleted file mode 100644 index 008549acc7..0000000000 --- a/.ci/scripts/windows/docker/postgres/entrypoint.ps1 +++ /dev/null @@ -1,8 +0,0 @@ -Write-Host "Wait a few seconds until the postgres is ready..." -sleep 5 -Write-Host "Create users for remote access..." -psql -U postgres -c "CREATE ROLE jenkins WITH LOGIN SUPERUSER INHERIT CREATEDB CREATEROLE REPLICATION;" - -Write-Host "Show postgres log output in the console..." -# Keep running the container with the event logs in the stdout. -Get-Content log/postgresql.log -Wait diff --git a/.ci/scripts/windows/docker/postgres/pg_hba.conf b/.ci/scripts/windows/docker/postgres/pg_hba.conf deleted file mode 100644 index 0959bf3165..0000000000 --- a/.ci/scripts/windows/docker/postgres/pg_hba.conf +++ /dev/null @@ -1,10 +0,0 @@ -# PostgreSQL Client Authentication Configuration File -# =================================================== -# - -# TYPE DATABASE USER CIDR-ADDRESS METHOD -host all all 0.0.0.0/0 trust -# IPv4 local connections: -host all all 127.0.0.1/32 trust -# IPv6 local connections: -host all all ::1/128 trust diff --git a/.ci/scripts/windows/docker/postgres/postgresql.conf b/.ci/scripts/windows/docker/postgres/postgresql.conf deleted file mode 100644 index 303774bf17..0000000000 --- a/.ci/scripts/windows/docker/postgres/postgresql.conf +++ /dev/null @@ -1,658 +0,0 @@ -# ----------------------------- -# PostgreSQL configuration file -# ----------------------------- -# -# This file consists of lines of the form: -# -# name = value -# -# (The "=" is optional.) Whitespace may be used. Comments are introduced with -# "#" anywhere on a line. The complete list of parameter names and allowed -# values can be found in the PostgreSQL documentation. -# -# The commented-out settings shown in this file represent the default values. -# Re-commenting a setting is NOT sufficient to revert it to the default value; -# you need to reload the server. -# -# This file is read on server startup and when the server receives a SIGHUP -# signal. If you edit the file on a running system, you have to SIGHUP the -# server for the changes to take effect, run "pg_ctl reload", or execute -# "SELECT pg_reload_conf()". Some parameters, which are marked below, -# require a server shutdown and restart to take effect. -# -# Any parameter can also be given as a command-line option to the server, e.g., -# "postgres -c log_connections=on". Some parameters can be changed at run time -# with the "SET" SQL command. -# -# Memory units: kB = kilobytes Time units: ms = milliseconds -# MB = megabytes s = seconds -# GB = gigabytes min = minutes -# TB = terabytes h = hours -# d = days - - -#------------------------------------------------------------------------------ -# FILE LOCATIONS -#------------------------------------------------------------------------------ - -# The default values of these variables are driven from the -D command-line -# option or PGDATA environment variable, represented here as ConfigDir. - -#data_directory = 'ConfigDir' # use data in another directory - # (change requires restart) -#hba_file = 'ConfigDir/pg_hba.conf' # host-based authentication file - # (change requires restart) -#ident_file = 'ConfigDir/pg_ident.conf' # ident configuration file - # (change requires restart) - -# If external_pid_file is not explicitly set, no extra PID file is written. -#external_pid_file = '' # write an extra PID file - # (change requires restart) - - -#------------------------------------------------------------------------------ -# CONNECTIONS AND AUTHENTICATION -#------------------------------------------------------------------------------ - -# - Connection Settings - - -listen_addresses = '*' # what IP address(es) to listen on; - # comma-separated list of addresses; - # defaults to 'localhost'; use '*' for all - # (change requires restart) -port = 5432 # (change requires restart) -max_connections = 100 # (change requires restart) -#superuser_reserved_connections = 3 # (change requires restart) -#unix_socket_directories = '' # comma-separated list of directories - # (change requires restart) -#unix_socket_group = '' # (change requires restart) -#unix_socket_permissions = 0777 # begin with 0 to use octal notation - # (change requires restart) -#bonjour = off # advertise server via Bonjour - # (change requires restart) -#bonjour_name = '' # defaults to the computer name - # (change requires restart) - -# - Security and Authentication - - -#authentication_timeout = 1min # 1s-600s -#ssl = off -#ssl_ciphers = 'HIGH:MEDIUM:+3DES:!aNULL' # allowed SSL ciphers -#ssl_prefer_server_ciphers = on -#ssl_ecdh_curve = 'prime256v1' -#ssl_dh_params_file = '' -#ssl_cert_file = 'server.crt' -#ssl_key_file = 'server.key' -#ssl_ca_file = '' -#ssl_crl_file = '' -#password_encryption = md5 # md5 or scram-sha-256 -#db_user_namespace = off -#row_security = on - -# GSSAPI using Kerberos -#krb_server_keyfile = '' -#krb_caseins_users = off - -# - TCP Keepalives - -# see "man 7 tcp" for details - -#tcp_keepalives_idle = 0 # TCP_KEEPIDLE, in seconds; - # 0 selects the system default -#tcp_keepalives_interval = 0 # TCP_KEEPINTVL, in seconds; - # 0 selects the system default -#tcp_keepalives_count = 0 # TCP_KEEPCNT; - # 0 selects the system default - - -#------------------------------------------------------------------------------ -# RESOURCE USAGE (except WAL) -#------------------------------------------------------------------------------ - -# - Memory - - -shared_buffers = 128MB # min 128kB - # (change requires restart) -#huge_pages = try # on, off, or try - # (change requires restart) -#temp_buffers = 8MB # min 800kB -#max_prepared_transactions = 0 # zero disables the feature - # (change requires restart) -# Caution: it is not advisable to set max_prepared_transactions nonzero unless -# you actively intend to use prepared transactions. -#work_mem = 4MB # min 64kB -#maintenance_work_mem = 64MB # min 1MB -#replacement_sort_tuples = 150000 # limits use of replacement selection sort -#autovacuum_work_mem = -1 # min 1MB, or -1 to use maintenance_work_mem -#max_stack_depth = 2MB # min 100kB -dynamic_shared_memory_type = windows # the default is the first option - # supported by the operating system: - # posix - # sysv - # windows - # mmap - # use none to disable dynamic shared memory - # (change requires restart) - -# - Disk - - -#temp_file_limit = -1 # limits per-process temp file space - # in kB, or -1 for no limit - -# - Kernel Resource Usage - - -#max_files_per_process = 1000 # min 25 - # (change requires restart) -#shared_preload_libraries = '' # (change requires restart) - -# - Cost-Based Vacuum Delay - - -#vacuum_cost_delay = 0 # 0-100 milliseconds -#vacuum_cost_page_hit = 1 # 0-10000 credits -#vacuum_cost_page_miss = 10 # 0-10000 credits -#vacuum_cost_page_dirty = 20 # 0-10000 credits -#vacuum_cost_limit = 200 # 1-10000 credits - -# - Background Writer - - -#bgwriter_delay = 200ms # 10-10000ms between rounds -#bgwriter_lru_maxpages = 100 # 0-1000 max buffers written/round -#bgwriter_lru_multiplier = 2.0 # 0-10.0 multiplier on buffers scanned/round -#bgwriter_flush_after = 0 # measured in pages, 0 disables - -# - Asynchronous Behavior - - -#effective_io_concurrency = 0 # 1-1000; 0 disables prefetching -#max_worker_processes = 8 # (change requires restart) -#max_parallel_workers_per_gather = 2 # taken from max_parallel_workers -#max_parallel_workers = 8 # maximum number of max_worker_processes that - # can be used in parallel queries -#old_snapshot_threshold = -1 # 1min-60d; -1 disables; 0 is immediate - # (change requires restart) -#backend_flush_after = 0 # measured in pages, 0 disables - - -#------------------------------------------------------------------------------ -# WRITE AHEAD LOG -#------------------------------------------------------------------------------ - -# - Settings - - -#wal_level = replica # minimal, replica, or logical - # (change requires restart) -#fsync = on # flush data to disk for crash safety - # (turning this off can cause - # unrecoverable data corruption) -#synchronous_commit = on # synchronization level; - # off, local, remote_write, remote_apply, or on -#wal_sync_method = fsync # the default is the first option - # supported by the operating system: - # open_datasync - # fdatasync (default on Linux) - # fsync - # fsync_writethrough - # open_sync -#full_page_writes = on # recover from partial page writes -#wal_compression = off # enable compression of full-page writes -#wal_log_hints = off # also do full page writes of non-critical updates - # (change requires restart) -#wal_buffers = -1 # min 32kB, -1 sets based on shared_buffers - # (change requires restart) -#wal_writer_delay = 200ms # 1-10000 milliseconds -#wal_writer_flush_after = 1MB # measured in pages, 0 disables - -#commit_delay = 0 # range 0-100000, in microseconds -#commit_siblings = 5 # range 1-1000 - -# - Checkpoints - - -#checkpoint_timeout = 5min # range 30s-1d -#max_wal_size = 1GB -#min_wal_size = 80MB -#checkpoint_completion_target = 0.5 # checkpoint target duration, 0.0 - 1.0 -#checkpoint_flush_after = 0 # measured in pages, 0 disables -#checkpoint_warning = 30s # 0 disables - -# - Archiving - - -#archive_mode = off # enables archiving; off, on, or always - # (change requires restart) -#archive_command = '' # command to use to archive a logfile segment - # placeholders: %p = path of file to archive - # %f = file name only - # e.g. 'test ! -f /mnt/server/archivedir/%f && cp %p /mnt/server/archivedir/%f' -#archive_timeout = 0 # force a logfile segment switch after this - # number of seconds; 0 disables - - -#------------------------------------------------------------------------------ -# REPLICATION -#------------------------------------------------------------------------------ - -# - Sending Server(s) - - -# Set these on the master and on any standby that will send replication data. - -#max_wal_senders = 10 # max number of walsender processes - # (change requires restart) -#wal_keep_segments = 0 # in logfile segments, 16MB each; 0 disables -#wal_sender_timeout = 60s # in milliseconds; 0 disables - -#max_replication_slots = 10 # max number of replication slots - # (change requires restart) -#track_commit_timestamp = off # collect timestamp of transaction commit - # (change requires restart) - -# - Master Server - - -# These settings are ignored on a standby server. - -#synchronous_standby_names = '' # standby servers that provide sync rep - # method to choose sync standbys, number of sync standbys, - # and comma-separated list of application_name - # from standby(s); '*' = all -#vacuum_defer_cleanup_age = 0 # number of xacts by which cleanup is delayed - -# - Standby Servers - - -# These settings are ignored on a master server. - -#hot_standby = on # "off" disallows queries during recovery - # (change requires restart) -#max_standby_archive_delay = 30s # max delay before canceling queries - # when reading WAL from archive; - # -1 allows indefinite delay -#max_standby_streaming_delay = 30s # max delay before canceling queries - # when reading streaming WAL; - # -1 allows indefinite delay -#wal_receiver_status_interval = 10s # send replies at least this often - # 0 disables -#hot_standby_feedback = off # send info from standby to prevent - # query conflicts -#wal_receiver_timeout = 60s # time that receiver waits for - # communication from master - # in milliseconds; 0 disables -#wal_retrieve_retry_interval = 5s # time to wait before retrying to - # retrieve WAL after a failed attempt - -# - Subscribers - - -# These settings are ignored on a publisher. - -#max_logical_replication_workers = 4 # taken from max_worker_processes - # (change requires restart) -#max_sync_workers_per_subscription = 2 # taken from max_logical_replication_workers - - -#------------------------------------------------------------------------------ -# QUERY TUNING -#------------------------------------------------------------------------------ - -# - Planner Method Configuration - - -#enable_bitmapscan = on -#enable_hashagg = on -#enable_hashjoin = on -#enable_indexscan = on -#enable_indexonlyscan = on -#enable_material = on -#enable_mergejoin = on -#enable_nestloop = on -#enable_seqscan = on -#enable_sort = on -#enable_tidscan = on - -# - Planner Cost Constants - - -#seq_page_cost = 1.0 # measured on an arbitrary scale -#random_page_cost = 4.0 # same scale as above -#cpu_tuple_cost = 0.01 # same scale as above -#cpu_index_tuple_cost = 0.005 # same scale as above -#cpu_operator_cost = 0.0025 # same scale as above -#parallel_tuple_cost = 0.1 # same scale as above -#parallel_setup_cost = 1000.0 # same scale as above -#min_parallel_table_scan_size = 8MB -#min_parallel_index_scan_size = 512kB -#effective_cache_size = 4GB - -# - Genetic Query Optimizer - - -#geqo = on -#geqo_threshold = 12 -#geqo_effort = 5 # range 1-10 -#geqo_pool_size = 0 # selects default based on effort -#geqo_generations = 0 # selects default based on effort -#geqo_selection_bias = 2.0 # range 1.5-2.0 -#geqo_seed = 0.0 # range 0.0-1.0 - -# - Other Planner Options - - -#default_statistics_target = 100 # range 1-10000 -#constraint_exclusion = partition # on, off, or partition -#cursor_tuple_fraction = 0.1 # range 0.0-1.0 -#from_collapse_limit = 8 -#join_collapse_limit = 8 # 1 disables collapsing of explicit - # JOIN clauses -#force_parallel_mode = off - - -#------------------------------------------------------------------------------ -# ERROR REPORTING AND LOGGING -#------------------------------------------------------------------------------ - -# - Where to Log - - -log_destination = 'stderr' # Valid values are combinations of - # stderr, csvlog, syslog, and eventlog, - # depending on platform. csvlog - # requires logging_collector to be on. - -# This is used when logging to stderr: -logging_collector = on # Enable capturing of stderr and csvlog - # into log files. Required to be on for - # csvlogs. - # (change requires restart) - -# These are only used if logging_collector is on: -#log_directory = 'log' # directory where log files are written, - # can be absolute or relative to PGDATA -log_filename = 'postgresql.log' # log file name pattern, - # can include strftime() escapes -#log_file_mode = 0600 # creation mode for log files, - # begin with 0 to use octal notation -#log_truncate_on_rotation = off # If on, an existing log file with the - # same name as the new log file will be - # truncated rather than appended to. - # But such truncation only occurs on - # time-driven rotation, not on restarts - # or size-driven rotation. Default is - # off, meaning append to existing files - # in all cases. -#log_rotation_age = 1d # Automatic rotation of logfiles will - # happen after that time. 0 disables. -#log_rotation_size = 10MB # Automatic rotation of logfiles will - # happen after that much log output. - # 0 disables. - -# These are relevant when logging to syslog: -#syslog_facility = 'LOCAL0' -#syslog_ident = 'postgres' -#syslog_sequence_numbers = on -#syslog_split_messages = on - -# This is only relevant when logging to eventlog (win32): -# (change requires restart) -#event_source = 'PostgreSQL' - -# - When to Log - - -client_min_messages = info # values in order of decreasing detail: - # debug5 - # debug4 - # debug3 - # debug2 - # debug1 - # log - # notice - # warning - # error - -log_min_messages = info # values in order of decreasing detail: - # debug5 - # debug4 - # debug3 - # debug2 - # debug1 - # info - # notice - # warning - # error - # log - # fatal - # panic - -#log_min_error_statement = error # values in order of decreasing detail: - # debug5 - # debug4 - # debug3 - # debug2 - # debug1 - # info - # notice - # warning - # error - # log - # fatal - # panic (effectively off) - -#log_min_duration_statement = -1 # -1 is disabled, 0 logs all statements - # and their durations, > 0 logs only - # statements running at least this number - # of milliseconds - - -# - What to Log - - -#debug_print_parse = off -#debug_print_rewritten = off -#debug_print_plan = off -#debug_pretty_print = on -#log_checkpoints = off -log_connections = on -#log_disconnections = off -#log_duration = off -#log_error_verbosity = default # terse, default, or verbose messages -#log_hostname = off -#log_line_prefix = '%m [%p] ' # special values: - # %a = application name - # %u = user name - # %d = database name - # %r = remote host and port - # %h = remote host - # %p = process ID - # %t = timestamp without milliseconds - # %m = timestamp with milliseconds - # %n = timestamp with milliseconds (as a Unix epoch) - # %i = command tag - # %e = SQL state - # %c = session ID - # %l = session line number - # %s = session start timestamp - # %v = virtual transaction ID - # %x = transaction ID (0 if none) - # %q = stop here in non-session - # processes - # %% = '%' - # e.g. '<%u%%%d> ' -#log_lock_waits = off # log lock waits >= deadlock_timeout -#log_statement = 'none' # none, ddl, mod, all -#log_replication_commands = off -#log_temp_files = -1 # log temporary files equal or larger - # than the specified size in kilobytes; - # -1 disables, 0 logs all temp files -log_timezone = 'Africa/Casablanca' - - -# - Process Title - - -#cluster_name = '' # added to process titles if nonempty - # (change requires restart) -#update_process_title = off - - -#------------------------------------------------------------------------------ -# RUNTIME STATISTICS -#------------------------------------------------------------------------------ - -# - Query/Index Statistics Collector - - -#track_activities = on -#track_counts = on -#track_io_timing = off -#track_functions = none # none, pl, all -#track_activity_query_size = 1024 # (change requires restart) -#stats_temp_directory = 'pg_stat_tmp' - - -# - Statistics Monitoring - - -#log_parser_stats = off -#log_planner_stats = off -#log_executor_stats = off -#log_statement_stats = off - - -#------------------------------------------------------------------------------ -# AUTOVACUUM PARAMETERS -#------------------------------------------------------------------------------ - -#autovacuum = on # Enable autovacuum subprocess? 'on' - # requires track_counts to also be on. -#log_autovacuum_min_duration = -1 # -1 disables, 0 logs all actions and - # their durations, > 0 logs only - # actions running at least this number - # of milliseconds. -#autovacuum_max_workers = 3 # max number of autovacuum subprocesses - # (change requires restart) -#autovacuum_naptime = 1min # time between autovacuum runs -#autovacuum_vacuum_threshold = 50 # min number of row updates before - # vacuum -#autovacuum_analyze_threshold = 50 # min number of row updates before - # analyze -#autovacuum_vacuum_scale_factor = 0.2 # fraction of table size before vacuum -#autovacuum_analyze_scale_factor = 0.1 # fraction of table size before analyze -#autovacuum_freeze_max_age = 200000000 # maximum XID age before forced vacuum - # (change requires restart) -#autovacuum_multixact_freeze_max_age = 400000000 # maximum multixact age - # before forced vacuum - # (change requires restart) -#autovacuum_vacuum_cost_delay = 20ms # default vacuum cost delay for - # autovacuum, in milliseconds; - # -1 means use vacuum_cost_delay -#autovacuum_vacuum_cost_limit = -1 # default vacuum cost limit for - # autovacuum, -1 means use - # vacuum_cost_limit - - -#------------------------------------------------------------------------------ -# CLIENT CONNECTION DEFAULTS -#------------------------------------------------------------------------------ - -# - Statement Behavior - - -#search_path = '"$user", public' # schema names -#default_tablespace = '' # a tablespace name, '' uses the default -#temp_tablespaces = '' # a list of tablespace names, '' uses - # only default tablespace -#check_function_bodies = on -#default_transaction_isolation = 'read committed' -#default_transaction_read_only = off -#default_transaction_deferrable = off -#session_replication_role = 'origin' -#statement_timeout = 0 # in milliseconds, 0 is disabled -#lock_timeout = 0 # in milliseconds, 0 is disabled -#idle_in_transaction_session_timeout = 0 # in milliseconds, 0 is disabled -#vacuum_freeze_min_age = 50000000 -#vacuum_freeze_table_age = 150000000 -#vacuum_multixact_freeze_min_age = 5000000 -#vacuum_multixact_freeze_table_age = 150000000 -#bytea_output = 'hex' # hex, escape -#xmlbinary = 'base64' -#xmloption = 'content' -#gin_fuzzy_search_limit = 0 -#gin_pending_list_limit = 4MB - -# - Locale and Formatting - - -datestyle = 'iso, mdy' -#intervalstyle = 'postgres' -timezone = 'Africa/Casablanca' -#timezone_abbreviations = 'Default' # Select the set of available time zone - # abbreviations. Currently, there are - # Default - # Australia (historical usage) - # India - # You can create your own file in - # share/timezonesets/. -#extra_float_digits = 0 # min -15, max 3 -#client_encoding = sql_ascii # actually, defaults to database - # encoding - -# These settings are initialized by initdb, but they can be changed. -lc_messages = 'English_United States.1252' # locale for system error message - # strings -lc_monetary = 'English_United States.1252' # locale for monetary formatting -lc_numeric = 'English_United States.1252' # locale for number formatting -lc_time = 'English_United States.1252' # locale for time formatting - -# default configuration for text search -default_text_search_config = 'pg_catalog.english' - -# - Other Defaults - - -#dynamic_library_path = '$libdir' -#local_preload_libraries = '' -#session_preload_libraries = '' - - -#------------------------------------------------------------------------------ -# LOCK MANAGEMENT -#------------------------------------------------------------------------------ - -#deadlock_timeout = 1s -#max_locks_per_transaction = 64 # min 10 - # (change requires restart) -#max_pred_locks_per_transaction = 64 # min 10 - # (change requires restart) -#max_pred_locks_per_relation = -2 # negative values mean - # (max_pred_locks_per_transaction - # / -max_pred_locks_per_relation) - 1 -#max_pred_locks_per_page = 2 # min 0 - - -#------------------------------------------------------------------------------ -# VERSION/PLATFORM COMPATIBILITY -#------------------------------------------------------------------------------ - -# - Previous PostgreSQL Versions - - -#array_nulls = on -#backslash_quote = safe_encoding # on, off, or safe_encoding -#default_with_oids = off -#escape_string_warning = on -#lo_compat_privileges = off -#operator_precedence_warning = off -#quote_all_identifiers = off -#standard_conforming_strings = on -#synchronize_seqscans = on - -# - Other Platforms and Clients - - -#transform_null_equals = off - - -#------------------------------------------------------------------------------ -# ERROR HANDLING -#------------------------------------------------------------------------------ - -#exit_on_error = off # terminate session on any error? -#restart_after_crash = on # reinitialize after backend crash? - - -#------------------------------------------------------------------------------ -# CONFIG FILE INCLUDES -#------------------------------------------------------------------------------ - -# These options allow settings to be loaded from files other than the -# default postgresql.conf. - -#include_dir = 'conf.d' # include files ending in '.conf' from - # directory 'conf.d' -#include_if_exists = 'exists.conf' # include file only if it exists -#include = 'special.conf' # include file - - -#------------------------------------------------------------------------------ -# CUSTOMIZED OPTIONS -#------------------------------------------------------------------------------ - -# Add settings for extensions here diff --git a/.ci/scripts/windows/docker/redis/Dockerfile b/.ci/scripts/windows/docker/redis/Dockerfile deleted file mode 100644 index 1036b18f70..0000000000 --- a/.ci/scripts/windows/docker/redis/Dockerfile +++ /dev/null @@ -1,18 +0,0 @@ -# escape=` -FROM mcr.microsoft.com/windows/servercore:10.0.17763.737 -SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"] - -ARG VERSION="2.8.19" -ENV REDIS_HOME="C:\redis" -ENV ROOT_URL="https://github.com/MSOpenTech/redis/releases/download/win" -WORKDIR $REDIS_HOME - -RUN Write-Host "Downloading: $env:ROOT_URL-$env:VERSION.zip"; ` - Invoke-WebRequest "$env:ROOT_URL-$env:VERSION/redis-$env:VERSION.zip" -OutFile 'redis.zip' -UseBasicParsing; ` - Expand-Archive redis.zip -DestinationPath C:\redis ; - -COPY redis.conf . -EXPOSE 6379 - -SHELL ["cmd", "/S", "/C"] -CMD "redis-server redis.conf" diff --git a/.ci/scripts/windows/docker/redis/redis.conf b/.ci/scripts/windows/docker/redis/redis.conf deleted file mode 100644 index 47a8d0766c..0000000000 --- a/.ci/scripts/windows/docker/redis/redis.conf +++ /dev/null @@ -1,887 +0,0 @@ -# Redis configuration file example - -# Note on units: when memory size is needed, it is possible to specify -# it in the usual form of 1k 5GB 4M and so forth: -# -# 1k => 1000 bytes -# 1kb => 1024 bytes -# 1m => 1000000 bytes -# 1mb => 1024*1024 bytes -# 1g => 1000000000 bytes -# 1gb => 1024*1024*1024 bytes -# -# units are case insensitive so 1GB 1Gb 1gB are all the same. - -################################## INCLUDES ################################### - -# Include one or more other config files here. This is useful if you -# have a standard template that goes to all Redis servers but also need -# to customize a few per-server settings. Include files can include -# other files, so use this wisely. -# -# Notice option "include" won't be rewritten by command "CONFIG REWRITE" -# from admin or Redis Sentinel. Since Redis always uses the last processed -# line as value of a configuration directive, you'd better put includes -# at the beginning of this file to avoid overwriting config change at runtime. -# -# If instead you are interested in using includes to override configuration -# options, it is better to use include as the last line. -# -# include .\path\to\local.conf -# include c:\path\to\other.conf - -################################ GENERAL ##################################### - -# On Windows, daemonize and pidfile are not supported. -# However, you can run redis as a Windows service, and specify a logfile. -# The logfile will contain the pid. - -# Accept connections on the specified port, default is 6379. -# If port 0 is specified Redis will not listen on a TCP socket. -port 6379 - -# TCP listen() backlog. -# -# In high requests-per-second environments you need an high backlog in order -# to avoid slow clients connections issues. Note that the Linux kernel -# will silently truncate it to the value of /proc/sys/net/core/somaxconn so -# make sure to raise both the value of somaxconn and tcp_max_syn_backlog -# in order to get the desired effect. -tcp-backlog 511 - -# By default Redis listens for connections from all the network interfaces -# available on the server. It is possible to listen to just one or multiple -# interfaces using the "bind" configuration directive, followed by one or -# more IP addresses. -# -# Examples: -# -# bind 192.168.1.100 10.0.0.1 -# bind 127.0.0.1 - - -# Specify the path for the Unix socket that will be used to listen for -# incoming connections. There is no default, so Redis will not listen -# on a unix socket when not specified. -# -# unixsocket /tmp/redis.sock -# unixsocketperm 700 - -# Close the connection after a client is idle for N seconds (0 to disable) -timeout 0 - -# TCP keepalive. -# -# If non-zero, use SO_KEEPALIVE to send TCP ACKs to clients in absence -# of communication. This is useful for two reasons: -# -# 1) Detect dead peers. -# 2) Take the connection alive from the point of view of network -# equipment in the middle. -# -# On Linux, the specified value (in seconds) is the period used to send ACKs. -# Note that to close the connection the double of the time is needed. -# On other kernels the period depends on the kernel configuration. -# -# A reasonable value for this option is 60 seconds. -tcp-keepalive 0 - -# Specify the server verbosity level. -# This can be one of: -# debug (a lot of information, useful for development/testing) -# verbose (many rarely useful info, but not a mess like the debug level) -# notice (moderately verbose, what you want in production probably) -# warning (only very important / critical messages are logged) -loglevel debug - -# Specify the log file name. Also 'stdout' can be used to force -# Redis to log on the standard output. -logfile "" - -# To enable logging to the Windows EventLog, just set 'syslog-enabled' to -# yes, and optionally update the other syslog parameters to suit your needs. -# If Redis is installed and launched as a Windows Service, this will -# automatically be enabled. -# syslog-enabled no - -# Specify the source name of the events in the Windows Application log. -# syslog-ident redis - -# Set the number of databases. The default database is DB 0, you can select -# a different one on a per-connection basis using SELECT where -# dbid is a number between 0 and 'databases'-1 -databases 16 - -################################ SNAPSHOTTING ################################ -# -# Save the DB on disk: -# -# save -# -# Will save the DB if both the given number of seconds and the given -# number of write operations against the DB occurred. -# -# In the example below the behaviour will be to save: -# after 900 sec (15 min) if at least 1 key changed -# after 300 sec (5 min) if at least 10 keys changed -# after 60 sec if at least 10000 keys changed -# -# Note: you can disable saving completely by commenting out all "save" lines. -# -# It is also possible to remove all the previously configured save -# points by adding a save directive with a single empty string argument -# like in the following example: -# -# save "" - -save 900 1 -save 300 10 -save 60 10000 - -# By default Redis will stop accepting writes if RDB snapshots are enabled -# (at least one save point) and the latest background save failed. -# This will make the user aware (in a hard way) that data is not persisting -# on disk properly, otherwise chances are that no one will notice and some -# disaster will happen. -# -# If the background saving process will start working again Redis will -# automatically allow writes again. -# -# However if you have setup your proper monitoring of the Redis server -# and persistence, you may want to disable this feature so that Redis will -# continue to work as usual even if there are problems with disk, -# permissions, and so forth. -stop-writes-on-bgsave-error yes - -# Compress string objects using LZF when dump .rdb databases? -# For default that's set to 'yes' as it's almost always a win. -# If you want to save some CPU in the saving child set it to 'no' but -# the dataset will likely be bigger if you have compressible values or keys. -rdbcompression yes - -# Since version 5 of RDB a CRC64 checksum is placed at the end of the file. -# This makes the format more resistant to corruption but there is a performance -# hit to pay (around 10%) when saving and loading RDB files, so you can disable it -# for maximum performances. -# -# RDB files created with checksum disabled have a checksum of zero that will -# tell the loading code to skip the check. -rdbchecksum yes - -# The filename where to dump the DB -dbfilename dump.rdb - -# The working directory. -# -# The DB will be written inside this directory, with the filename specified -# above using the 'dbfilename' configuration directive. -# -# The Append Only File will also be created inside this directory. -# -# Note that you must specify a directory here, not a file name. -dir ./ - -################################# REPLICATION ################################# - -# Master-Slave replication. Use slaveof to make a Redis instance a copy of -# another Redis server. A few things to understand ASAP about Redis replication. -# -# 1) Redis replication is asynchronous, but you can configure a master to -# stop accepting writes if it appears to be not connected with at least -# a given number of slaves. -# 2) Redis slaves are able to perform a partial resynchronization with the -# master if the replication link is lost for a relatively small amount of -# time. You may want to configure the replication backlog size (see the next -# sections of this file) with a sensible value depending on your needs. -# 3) Replication is automatic and does not need user intervention. After a -# network partition slaves automatically try to reconnect to masters -# and resynchronize with them. -# -# slaveof - -# If the master is password protected (using the "requirepass" configuration -# directive below) it is possible to tell the slave to authenticate before -# starting the replication synchronization process, otherwise the master will -# refuse the slave request. -# -# masterauth - -# When a slave loses its connection with the master, or when the replication -# is still in progress, the slave can act in two different ways: -# -# 1) if slave-serve-stale-data is set to 'yes' (the default) the slave will -# still reply to client requests, possibly with out of date data, or the -# data set may just be empty if this is the first synchronization. -# -# 2) if slave-serve-stale-data is set to 'no' the slave will reply with -# an error "SYNC with master in progress" to all the kind of commands -# but to INFO and SLAVEOF. -# -slave-serve-stale-data yes - -# You can configure a slave instance to accept writes or not. Writing against -# a slave instance may be useful to store some ephemeral data (because data -# written on a slave will be easily deleted after resync with the master) but -# may also cause problems if clients are writing to it because of a -# misconfiguration. -# -# Since Redis 2.6 by default slaves are read-only. -# -# Note: read only slaves are not designed to be exposed to untrusted clients -# on the internet. It's just a protection layer against misuse of the instance. -# Still a read only slave exports by default all the administrative commands -# such as CONFIG, DEBUG, and so forth. To a limited extent you can improve -# security of read only slaves using 'rename-command' to shadow all the -# administrative / dangerous commands. -slave-read-only yes - -# Replication SYNC strategy: disk or socket. -# -# ------------------------------------------------------- -# WARNING: DISKLESS REPLICATION IS EXPERIMENTAL CURRENTLY -# ------------------------------------------------------- -# -# New slaves and reconnecting slaves that are not able to continue the replication -# process just receiving differences, need to do what is called a "full -# synchronization". An RDB file is transmitted from the master to the slaves. -# The transmission can happen in two different ways: -# -# 1) Disk-backed: The Redis master creates a new process that writes the RDB -# file on disk. Later the file is transferred by the parent -# process to the slaves incrementally. -# 2) Diskless: The Redis master creates a new process that directly writes the -# RDB file to slave sockets, without touching the disk at all. -# -# With disk-backed replication, while the RDB file is generated, more slaves -# can be queued and served with the RDB file as soon as the current child producing -# the RDB file finishes its work. With diskless replication instead once -# the transfer starts, new slaves arriving will be queued and a new transfer -# will start when the current one terminates. -# -# When diskless replication is used, the master waits a configurable amount of -# time (in seconds) before starting the transfer in the hope that multiple slaves -# will arrive and the transfer can be parallelized. -# -# With slow disks and fast (large bandwidth) networks, diskless replication -# works better. -repl-diskless-sync no - -# When diskless replication is enabled, it is possible to configure the delay -# the server waits in order to spawn the child that trnasfers the RDB via socket -# to the slaves. -# -# This is important since once the transfer starts, it is not possible to serve -# new slaves arriving, that will be queued for the next RDB transfer, so the server -# waits a delay in order to let more slaves arrive. -# -# The delay is specified in seconds, and by default is 5 seconds. To disable -# it entirely just set it to 0 seconds and the transfer will start ASAP. -repl-diskless-sync-delay 5 - -# Slaves send PINGs to server in a predefined interval. It's possible to change -# this interval with the repl_ping_slave_period option. The default value is 10 -# seconds. -# -# repl-ping-slave-period 10 - -# The following option sets the replication timeout for: -# -# 1) Bulk transfer I/O during SYNC, from the point of view of slave. -# 2) Master timeout from the point of view of slaves (data, pings). -# 3) Slave timeout from the point of view of masters (REPLCONF ACK pings). -# -# It is important to make sure that this value is greater than the value -# specified for repl-ping-slave-period otherwise a timeout will be detected -# every time there is low traffic between the master and the slave. -# -# repl-timeout 60 - -# Disable TCP_NODELAY on the slave socket after SYNC? -# -# If you select "yes" Redis will use a smaller number of TCP packets and -# less bandwidth to send data to slaves. But this can add a delay for -# the data to appear on the slave side, up to 40 milliseconds with -# Linux kernels using a default configuration. -# -# If you select "no" the delay for data to appear on the slave side will -# be reduced but more bandwidth will be used for replication. -# -# By default we optimize for low latency, but in very high traffic conditions -# or when the master and slaves are many hops away, turning this to "yes" may -# be a good idea. -repl-disable-tcp-nodelay no - -# Set the replication backlog size. The backlog is a buffer that accumulates -# slave data when slaves are disconnected for some time, so that when a slave -# wants to reconnect again, often a full resync is not needed, but a partial -# resync is enough, just passing the portion of data the slave missed while -# disconnected. -# -# The bigger the replication backlog, the longer the time the slave can be -# disconnected and later be able to perform a partial resynchronization. -# -# The backlog is only allocated once there is at least a slave connected. -# -# repl-backlog-size 1mb - -# After a master has no longer connected slaves for some time, the backlog -# will be freed. The following option configures the amount of seconds that -# need to elapse, starting from the time the last slave disconnected, for -# the backlog buffer to be freed. -# -# A value of 0 means to never release the backlog. -# -# repl-backlog-ttl 3600 - -# The slave priority is an integer number published by Redis in the INFO output. -# It is used by Redis Sentinel in order to select a slave to promote into a -# master if the master is no longer working correctly. -# -# A slave with a low priority number is considered better for promotion, so -# for instance if there are three slaves with priority 10, 100, 25 Sentinel will -# pick the one with priority 10, that is the lowest. -# -# However a special priority of 0 marks the slave as not able to perform the -# role of master, so a slave with priority of 0 will never be selected by -# Redis Sentinel for promotion. -# -# By default the priority is 100. -slave-priority 100 - -# It is possible for a master to stop accepting writes if there are less than -# N slaves connected, having a lag less or equal than M seconds. -# -# The N slaves need to be in "online" state. -# -# The lag in seconds, that must be <= the specified value, is calculated from -# the last ping received from the slave, that is usually sent every second. -# -# This option does not GUARANTEE that N replicas will accept the write, but -# will limit the window of exposure for lost writes in case not enough slaves -# are available, to the specified number of seconds. -# -# For example to require at least 3 slaves with a lag <= 10 seconds use: -# -# min-slaves-to-write 3 -# min-slaves-max-lag 10 -# -# Setting one or the other to 0 disables the feature. -# -# By default min-slaves-to-write is set to 0 (feature disabled) and -# min-slaves-max-lag is set to 10. - -################################## SECURITY ################################### - -# Require clients to issue AUTH before processing any other -# commands. This might be useful in environments in which you do not trust -# others with access to the host running redis-server. -# -# This should stay commented out for backward compatibility and because most -# people do not need auth (e.g. they run their own servers). -# -# Warning: since Redis is pretty fast an outside user can try up to -# 150k passwords per second against a good box. This means that you should -# use a very strong password otherwise it will be very easy to break. -# -# requirepass foobared - -# Command renaming. -# -# It is possible to change the name of dangerous commands in a shared -# environment. For instance the CONFIG command may be renamed into something -# hard to guess so that it will still be available for internal-use tools -# but not available for general clients. -# -# Example: -# -# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52 -# -# It is also possible to completely kill a command by renaming it into -# an empty string: -# -# rename-command CONFIG "" -# -# Please note that changing the name of commands that are logged into the -# AOF file or transmitted to slaves may cause problems. - -################################### LIMITS #################################### - -# Set the max number of connected clients at the same time. By default -# this limit is set to 10000 clients, however if the Redis server is not -# able to configure the process file limit to allow for the specified limit -# the max number of allowed clients is set to the current file limit -# minus 32 (as Redis reserves a few file descriptors for internal uses). -# -# Once the limit is reached Redis will close all the new connections sending -# an error 'max number of clients reached'. -# -# maxclients 10000 - -# The Linux version of Redis relies on the system call fork() to perform -# point-in-time snapshots of the heap. In addition to the AOF and RDB backup -# mechanism, the master-slave synchronization and clustering features are -# dependent on this behavior of fork(). In order for the Windows version to -# perform like the Linux version we had to simulate this aspect of fork(). -# Doing so meant moving the Redis heap into a memory mapped file that can -# be shared with a child process. -# -# *** There must be disk space available for this file in order for Redis -# to launch. *** The default configuration places this file in the local -# appdata directory. If you wish to move this file to another local disk, -# use the heapdir flag as described below. -# -# The maxheap flag controls the maximum size of this memory mapped file, -# as well as the total usable space for the Redis heap. Running Redis -# without either maxheap or maxmemory will result in a memory mapped file -# being created that is equal to the size of physical memory. During -# fork() operations the total page file commit will max out at around: -# -# (size of physical memory) + (2 * size of maxheap) -# -# For instance, on a machine with 8GB of physical RAM, the max page file -# commit with the default maxheap size will be (8)+(2*8) GB , or 24GB. The -# default page file sizing of Windows will allow for this without having -# to reconfigure the system. Larger heap sizes are possible, but the maximum -# page file size will have to be increased accordingly. -# -# The Redis heap must be larger than the value specified by the maxmemory -# flag, as the heap allocator has its own memory requirements and -# fragmentation of the heap is inevitable. If only the maxmemory flag is -# specified, maxheap will be set at 1.5*maxmemory. If the maxheap flag is -# specified along with maxmemory, the maxheap flag will be automatically -# increased if it is smaller than 1.5*maxmemory. -# -maxheap 128m - -# The heap memory mapped file must reside on a local path for heap sharing -# between processes to work. A UNC path will not suffice here. For maximum -# performance this should be located on the fastest local drive available. -# This value defaults to the local application data folder(e.g., -# "%USERPROFILE%\AppData\Local"). Since this file can be very large, you -# may wish to place this on a drive other than the one the operating system -# is installed on. -# -# Note that you must specify a directory here, not a file name. -# heapdir - -# If Redis is to be used as an in-memory-only cache without any kind of -# persistence, then the fork() mechanism used by the background AOF/RDB -# persistence is unneccessary. As an optimization, all persistence can be -# turned off in the Windows version of Redis. This will disable the creation of -# the memory mapped heap file, redirect heap allocations to the system heap -# allocator, and disable commands that would otherwise cause fork() operations: -# BGSAVE and BGREWRITEAOF. This flag may not be combined with any of the other -# flags that configure AOF and RDB operations. -# persistence-available [(yes)|no] - -# Don't use more memory than the specified amount of bytes. -# When the memory limit is reached Redis will try to remove keys -# according to the eviction policy selected (see maxmemory-policy). -# -# If Redis can't remove keys according to the policy, or if the policy is -# set to 'noeviction', Redis will start to reply with errors to commands -# that would use more memory, like SET, LPUSH, and so on, and will continue -# to reply to read-only commands like GET. -# -# This option is usually useful when using Redis as an LRU cache, or to set -# a hard memory limit for an instance (using the 'noeviction' policy). -# -# WARNING: If you have slaves attached to an instance with maxmemory on, -# the size of the output buffers needed to feed the slaves are subtracted -# from the used memory count, so that network problems / resyncs will -# not trigger a loop where keys are evicted, and in turn the output -# buffer of slaves is full with DELs of keys evicted triggering the deletion -# of more keys, and so forth until the database is completely emptied. -# -# In short... if you have slaves attached it is suggested that you set a lower -# limit for maxmemory so that there is some free RAM on the system for slave -# output buffers (but this is not needed if the policy is 'noeviction'). -# -maxmemory 64m - -# MAXMEMORY POLICY: how Redis will select what to remove when maxmemory -# is reached. You can select among five behaviors: -# -# volatile-lru -> remove the key with an expire set using an LRU algorithm -# allkeys-lru -> remove any key according to the LRU algorithm -# volatile-random -> remove a random key with an expire set -# allkeys-random -> remove a random key, any key -# volatile-ttl -> remove the key with the nearest expire time (minor TTL) -# noeviction -> don't expire at all, just return an error on write operations -# -# Note: with any of the above policies, Redis will return an error on write -# operations, when there are no suitable keys for eviction. -# -# At the date of writing these commands are: set setnx setex append -# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd -# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby -# zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby -# getset mset msetnx exec sort -# -# The default is: -# -# maxmemory-policy volatile-lru - -# LRU and minimal TTL algorithms are not precise algorithms but approximated -# algorithms (in order to save memory), so you can select as well the sample -# size to check. For instance for default Redis will check three keys and -# pick the one that was used less recently, you can change the sample size -# using the following configuration directive. -# -# maxmemory-samples 3 - -############################## APPEND ONLY MODE ############################### - -# By default Redis asynchronously dumps the dataset on disk. This mode is -# good enough in many applications, but an issue with the Redis process or -# a power outage may result into a few minutes of writes lost (depending on -# the configured save points). -# -# The Append Only File is an alternative persistence mode that provides -# much better durability. For instance using the default data fsync policy -# (see later in the config file) Redis can lose just one second of writes in a -# dramatic event like a server power outage, or a single write if something -# wrong with the Redis process itself happens, but the operating system is -# still running correctly. -# -# AOF and RDB persistence can be enabled at the same time without problems. -# If the AOF is enabled on startup Redis will load the AOF, that is the file -# with the better durability guarantees. -# -# Please check http://redis.io/topics/persistence for more information. - -appendonly no - -# The name of the append only file (default: "appendonly.aof") -appendfilename "appendonly.aof" - -# The fsync() call tells the Operating System to actually write data on disk -# instead of waiting for more data in the output buffer. Some OS will really flush -# data on disk, some other OS will just try to do it ASAP. -# -# Redis supports three different modes: -# -# no: don't fsync, just let the OS flush the data when it wants. Faster. -# always: fsync after every write to the append only log . Slow, Safest. -# everysec: fsync only one time every second. Compromise. -# -# The default is "everysec", as that's usually the right compromise between -# speed and data safety. It's up to you to understand if you can relax this to -# "no" that will let the operating system flush the output buffer when -# it wants, for better performances (but if you can live with the idea of -# some data loss consider the default persistence mode that's snapshotting), -# or on the contrary, use "always" that's very slow but a bit safer than -# everysec. -# -# More details please check the following article: -# http://antirez.com/post/redis-persistence-demystified.html -# -# If unsure, use "everysec". - -# appendfsync always -appendfsync everysec -# appendfsync no - -# When the AOF fsync policy is set to always or everysec, and a background -# saving process (a background save or AOF log background rewriting) is -# performing a lot of I/O against the disk, in some Linux configurations -# Redis may block too long on the fsync() call. Note that there is no fix for -# this currently, as even performing fsync in a different thread will block -# our synchronous write(2) call. -# -# In order to mitigate this problem it's possible to use the following option -# that will prevent fsync() from being called in the main process while a -# BGSAVE or BGREWRITEAOF is in progress. -# -# This means that while another child is saving, the durability of Redis is -# the same as "appendfsync none". In practical terms, this means that it is -# possible to lose up to 30 seconds of log in the worst scenario (with the -# default Linux settings). -# -# If you have latency problems turn this to "yes". Otherwise leave it as -# "no" that is the safest pick from the point of view of durability. -no-appendfsync-on-rewrite no - -# Automatic rewrite of the append only file. -# Redis is able to automatically rewrite the log file implicitly calling -# BGREWRITEAOF when the AOF log size grows by the specified percentage. -# -# This is how it works: Redis remembers the size of the AOF file after the -# latest rewrite (if no rewrite has happened since the restart, the size of -# the AOF at startup is used). -# -# This base size is compared to the current size. If the current size is -# bigger than the specified percentage, the rewrite is triggered. Also -# you need to specify a minimal size for the AOF file to be rewritten, this -# is useful to avoid rewriting the AOF file even if the percentage increase -# is reached but it is still pretty small. -# -# Specify a percentage of zero in order to disable the automatic AOF -# rewrite feature. - -auto-aof-rewrite-percentage 100 -auto-aof-rewrite-min-size 64mb - -# An AOF file may be found to be truncated at the end during the Redis -# startup process, when the AOF data gets loaded back into memory. -# This may happen when the system where Redis is running -# crashes, especially when an ext4 filesystem is mounted without the -# data=ordered option (however this can't happen when Redis itself -# crashes or aborts but the operating system still works correctly). -# -# Redis can either exit with an error when this happens, or load as much -# data as possible (the default now) and start if the AOF file is found -# to be truncated at the end. The following option controls this behavior. -# -# If aof-load-truncated is set to yes, a truncated AOF file is loaded and -# the Redis server starts emitting a log to inform the user of the event. -# Otherwise if the option is set to no, the server aborts with an error -# and refuses to start. When the option is set to no, the user requires -# to fix the AOF file using the "redis-check-aof" utility before to restart -# the server. -# -# Note that if the AOF file will be found to be corrupted in the middle -# the server will still exit with an error. This option only applies when -# Redis will try to read more data from the AOF file but not enough bytes -# will be found. -aof-load-truncated yes - -################################ LUA SCRIPTING ############################### - -# Max execution time of a Lua script in milliseconds. -# -# If the maximum execution time is reached Redis will log that a script is -# still in execution after the maximum allowed time and will start to -# reply to queries with an error. -# -# When a long running script exceeds the maximum execution time only the -# SCRIPT KILL and SHUTDOWN NOSAVE commands are available. The first can be -# used to stop a script that did not yet called write commands. The second -# is the only way to shut down the server in the case a write command was -# already issued by the script but the user doesn't want to wait for the natural -# termination of the script. -# -# Set it to 0 or a negative value for unlimited execution without warnings. -lua-time-limit 5000 - -################################## SLOW LOG ################################### - -# The Redis Slow Log is a system to log queries that exceeded a specified -# execution time. The execution time does not include the I/O operations -# like talking with the client, sending the reply and so forth, -# but just the time needed to actually execute the command (this is the only -# stage of command execution where the thread is blocked and can not serve -# other requests in the meantime). -# -# You can configure the slow log with two parameters: one tells Redis -# what is the execution time, in microseconds, to exceed in order for the -# command to get logged, and the other parameter is the length of the -# slow log. When a new command is logged the oldest one is removed from the -# queue of logged commands. - -# The following time is expressed in microseconds, so 1000000 is equivalent -# to one second. Note that a negative number disables the slow log, while -# a value of zero forces the logging of every command. -slowlog-log-slower-than 10000 - -# There is no limit to this length. Just be aware that it will consume memory. -# You can reclaim memory used by the slow log with SLOWLOG RESET. -slowlog-max-len 128 - -################################ LATENCY MONITOR ############################## - -# The Redis latency monitoring subsystem samples different operations -# at runtime in order to collect data related to possible sources of -# latency of a Redis instance. -# -# Via the LATENCY command this information is available to the user that can -# print graphs and obtain reports. -# -# The system only logs operations that were performed in a time equal or -# greater than the amount of milliseconds specified via the -# latency-monitor-threshold configuration directive. When its value is set -# to zero, the latency monitor is turned off. -# -# By default latency monitoring is disabled since it is mostly not needed -# if you don't have latency issues, and collecting data has a performance -# impact, that while very small, can be measured under big load. Latency -# monitoring can easily be enalbed at runtime using the command -# "CONFIG SET latency-monitor-threshold " if needed. -latency-monitor-threshold 0 - -############################# Event notification ############################## - -# Redis can notify Pub/Sub clients about events happening in the key space. -# This feature is documented at http://redis.io/topics/notifications -# -# For instance if keyspace events notification is enabled, and a client -# performs a DEL operation on key "foo" stored in the Database 0, two -# messages will be published via Pub/Sub: -# -# PUBLISH __keyspace@0__:foo del -# PUBLISH __keyevent@0__:del foo -# -# It is possible to select the events that Redis will notify among a set -# of classes. Every class is identified by a single character: -# -# K Keyspace events, published with __keyspace@__ prefix. -# E Keyevent events, published with __keyevent@__ prefix. -# g Generic commands (non-type specific) like DEL, EXPIRE, RENAME, ... -# $ String commands -# l List commands -# s Set commands -# h Hash commands -# z Sorted set commands -# x Expired events (events generated every time a key expires) -# e Evicted events (events generated when a key is evicted for maxmemory) -# A Alias for g$lshzxe, so that the "AKE" string means all the events. -# -# The "notify-keyspace-events" takes as argument a string that is composed -# of zero or multiple characters. The empty string means that notifications -# are disabled. -# -# Example: to enable list and generic events, from the point of view of the -# event name, use: -# -# notify-keyspace-events Elg -# -# Example 2: to get the stream of the expired keys subscribing to channel -# name __keyevent@0__:expired use: -# -# notify-keyspace-events Ex -# -# By default all notifications are disabled because most users don't need -# this feature and the feature has some overhead. Note that if you don't -# specify at least one of K or E, no events will be delivered. -notify-keyspace-events "" - -############################### ADVANCED CONFIG ############################### - -# Hashes are encoded using a memory efficient data structure when they have a -# small number of entries, and the biggest entry does not exceed a given -# threshold. These thresholds can be configured using the following directives. -hash-max-ziplist-entries 512 -hash-max-ziplist-value 64 - -# Similarly to hashes, small lists are also encoded in a special way in order -# to save a lot of space. The special representation is only used when -# you are under the following limits: -list-max-ziplist-entries 512 -list-max-ziplist-value 64 - -# Sets have a special encoding in just one case: when a set is composed -# of just strings that happen to be integers in radix 10 in the range -# of 64 bit signed integers. -# The following configuration setting sets the limit in the size of the -# set in order to use this special memory saving encoding. -set-max-intset-entries 512 - -# Similarly to hashes and lists, sorted sets are also specially encoded in -# order to save a lot of space. This encoding is only used when the length and -# elements of a sorted set are below the following limits: -zset-max-ziplist-entries 128 -zset-max-ziplist-value 64 - -# HyperLogLog sparse representation bytes limit. The limit includes the -# 16 bytes header. When an HyperLogLog using the sparse representation crosses -# this limit, it is converted into the dense representation. -# -# A value greater than 16000 is totally useless, since at that point the -# dense representation is more memory efficient. -# -# The suggested value is ~ 3000 in order to have the benefits of -# the space efficient encoding without slowing down too much PFADD, -# which is O(N) with the sparse encoding. The value can be raised to -# ~ 10000 when CPU is not a concern, but space is, and the data set is -# composed of many HyperLogLogs with cardinality in the 0 - 15000 range. -hll-sparse-max-bytes 3000 - -# Active rehashing uses 1 millisecond every 100 milliseconds of CPU time in -# order to help rehashing the main Redis hash table (the one mapping top-level -# keys to values). The hash table implementation Redis uses (see dict.c) -# performs a lazy rehashing: the more operation you run into a hash table -# that is rehashing, the more rehashing "steps" are performed, so if the -# server is idle the rehashing is never complete and some more memory is used -# by the hash table. -# -# The default is to use this millisecond 10 times every second in order to -# actively rehash the main dictionaries, freeing memory when possible. -# -# If unsure: -# use "activerehashing no" if you have hard latency requirements and it is -# not a good thing in your environment that Redis can reply from time to time -# to queries with 2 milliseconds delay. -# -# use "activerehashing yes" if you don't have such hard requirements but -# want to free memory asap when possible. -activerehashing yes - -# The client output buffer limits can be used to force disconnection of clients -# that are not reading data from the server fast enough for some reason (a -# common reason is that a Pub/Sub client can't consume messages as fast as the -# publisher can produce them). -# -# The limit can be set differently for the three different classes of clients: -# -# normal -> normal clients including MONITOR clients -# slave -> slave clients -# pubsub -> clients subscribed to at least one pubsub channel or pattern -# -# The syntax of every client-output-buffer-limit directive is the following: -# -# client-output-buffer-limit -# -# A client is immediately disconnected once the hard limit is reached, or if -# the soft limit is reached and remains reached for the specified number of -# seconds (continuously). -# So for instance if the hard limit is 32 megabytes and the soft limit is -# 16 megabytes / 10 seconds, the client will get disconnected immediately -# if the size of the output buffers reach 32 megabytes, but will also get -# disconnected if the client reaches 16 megabytes and continuously overcomes -# the limit for 10 seconds. -# -# By default normal clients are not limited because they don't receive data -# without asking (in a push way), but just after a request, so only -# asynchronous clients may create a scenario where data is requested faster -# than it can read. -# -# Instead there is a default limit for pubsub and slave clients, since -# subscribers and slaves receive data in a push fashion. -# -# Both the hard or the soft limit can be disabled by setting them to zero. -client-output-buffer-limit normal 0 0 0 -client-output-buffer-limit slave 256mb 64mb 60 -client-output-buffer-limit pubsub 32mb 8mb 60 - -# Redis calls an internal function to perform many background tasks, like -# closing connections of clients in timeot, purging expired keys that are -# never requested, and so forth. -# -# Not all tasks are perforemd with the same frequency, but Redis checks for -# tasks to perform according to the specified "hz" value. -# -# By default "hz" is set to 10. Raising the value will use more CPU when -# Redis is idle, but at the same time will make Redis more responsive when -# there are many keys expiring at the same time, and timeouts may be -# handled with more precision. -# -# The range is between 1 and 500, however a value over 100 is usually not -# a good idea. Most users should use the default of 10 and raise this up to -# 100 only in environments where very low latency is required. -hz 10 - -# When a child rewrites the AOF file, if the following option is enabled -# the file will be fsync-ed every 32 MB of data generated. This is useful -# in order to commit the file to the disk more incrementally and avoid -# big latency spikes. -aof-rewrite-incremental-fsync yes - -################################## INCLUDES ################################### - -# Include one or more other config files here. This is useful if you -# have a standard template that goes to all Redis server but also need -# to customize a few per-server settings. Include files can include -# other files, so use this wisely. -# -# include /path/to/local.conf -# include /path/to/other.conf diff --git a/.ci/scripts/windows/docker/run-services.bat b/.ci/scripts/windows/docker/run-services.bat deleted file mode 100644 index 521e9b72dc..0000000000 --- a/.ci/scripts/windows/docker/run-services.bat +++ /dev/null @@ -1,15 +0,0 @@ -docker build --tag cassandra cassandra/ -docker run -d -p 7000:7000 -p 9042:9042 --name cassandra cassandra -docker build --tag=elasticsearch elasticsearch/ -docker run -d -p 9200:9200 -p 9300:9300 --name elasticsearch elasticsearch -docker build --tag=mongodb mongodb/ -docker run -d -p 27017:27017 --name mongodb mongodb -docker build --tag=mssql mssql/ -docker run -d -p 1433:1433 -e sa_password=%SA_PASSWORD% -e ACCEPT_EULA=Y --name mssql mssql -docker build --tag=mysql mysql/ -docker run -d -p 3306:3306 -e MYSQL_USER=%MYSQL_USER% -e MYSQL_PASSWORD=%MYSQL_PASSWORD% --name mysql mysql -docker build --tag=postgres postgres/ -docker run -d -p 5432:5432 --name postgres postgres -docker build --tag=redis redis/ -docker run -d -p 6379:6379 --name redis redis -docker ps -a From b628ce0ee60b68ad37514b1be14e4af4754a63ad Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 13:30:02 +0000 Subject: [PATCH 108/117] ci(jenkins): windows test output --- .ci/Jenkinsfile | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 19fe6f1395..90c2b1c71d 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -486,6 +486,11 @@ def generateStepForWindows(Map params = [:]){ } } catch(e){ error(e.toString()) + } finally { + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ + sh(label: 'Convert Test results to JUnit format', script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") } } } From f9953fc6ddb38830769d6c80ca9667faae59afd0 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 14:09:08 +0000 Subject: [PATCH 109/117] ci(jenkins): junit in windows not yet enabled --- .ci/Jenkinsfile | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 60f71ad891..735b640a04 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -487,10 +487,7 @@ def generateStepForWindows(Map params = [:]){ } catch(e){ error(e.toString()) } finally { - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}:/app"){ - sh(label: 'Convert Test results to JUnit format', script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: "${BASE_DIR}/**/junit-*.xml") + echo 'JUnit archiving no yet in place' } } } From 4a6650e0e9b5542cf5745746db0c38a2c834c2cf Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 14:10:43 +0000 Subject: [PATCH 110/117] ci(jenkins): multiple node versions --- .ci/Jenkinsfile | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 735b640a04..046d4aa9a8 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -80,13 +80,9 @@ pipeline { node['NODEJS_VERSION'].each{ version -> parallelTasks["Node.js-${version}"] = generateStep(version: version) parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) - // TODO: to be enabled if required. - // parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) + parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) } - // Only 12 for the time being - parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') - // PRs don't require to run here as it's now managed within the linting pipeline if (!env.CHANGE_ID) { // Linting in parallel with the test stage From 0b652cef7527c0bc786860d095a52a5401e66db6 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 14:14:51 +0000 Subject: [PATCH 111/117] Revert "ci(jenkins): multiple node versions" This reverts commit 4a6650e0e9b5542cf5745746db0c38a2c834c2cf. --- .ci/Jenkinsfile | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 046d4aa9a8..735b640a04 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -80,9 +80,13 @@ pipeline { node['NODEJS_VERSION'].each{ version -> parallelTasks["Node.js-${version}"] = generateStep(version: version) parallelTasks["Node.js-${version}-async-hooks-false"] = generateStep(version: version, disableAsyncHooks: true) - parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) + // TODO: to be enabled if required. + // parallelTasks["Windows-Node.js-${version}"] = generateStepForWindows(version: version) } + // Only 12 for the time being + parallelTasks["Windows-Node.js-12"] = generateStepForWindows(version: '12') + // PRs don't require to run here as it's now managed within the linting pipeline if (!env.CHANGE_ID) { // Linting in parallel with the test stage From bdb5890e45c87f4e4dcf8ac9526b1ec746a2da27 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 15:18:27 +0000 Subject: [PATCH 112/117] Revert "ci(jenkins): remove support to appveyor" This reverts commit becd3dee74a7567c20db44654e74df765bef17e2. --- .appveyor.yml | 28 +++++++++++++++++ test/script/appveyor/install-cassandra.ps1 | 23 ++++++++++++++ .../script/appveyor/install-elasticsearch.ps1 | 31 +++++++++++++++++++ test/script/appveyor/install-redis.ps1 | 21 +++++++++++++ 4 files changed, 103 insertions(+) create mode 100644 .appveyor.yml create mode 100755 test/script/appveyor/install-cassandra.ps1 create mode 100755 test/script/appveyor/install-elasticsearch.ps1 create mode 100755 test/script/appveyor/install-redis.ps1 diff --git a/.appveyor.yml b/.appveyor.yml new file mode 100644 index 0000000000..2355eb74da --- /dev/null +++ b/.appveyor.yml @@ -0,0 +1,28 @@ +environment: + PGUSER: "postgres" + PGPASSWORD: "Password12!" + MYSQL_PASSWORD: "Password12!" + +# Install scripts runs after repo cloning +install: + - ps: .\test\script\appveyor\install-redis.ps1 + - ps: .\test\script\appveyor\install-elasticsearch.ps1 + - ps: .\test\script\appveyor\install-cassandra.ps1 + - ps: Install-Product node 10 # Latest LTS + - npm install + +# Services are started after all install scripts have run +services: + - mysql + - mongodb + - postgresql + - mssql2017 + +# Post-install test scripts +test_script: + - node --version + - npm --version + - node test/test.js + +# Don't actually build +build: off diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 new file mode 100755 index 0000000000..76f5730a82 --- /dev/null +++ b/test/script/appveyor/install-cassandra.ps1 @@ -0,0 +1,23 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan +$cassandraVersion = "3.11.3" +$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" +$extractRoot = "$env:USERPROFILE" +$tgzPath = "$extractRoot\cassandra.tar.gz" +$tarPath = "$extractRoot\cassandra.tar" +$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" + +Write-Host "Downloading Cassandra..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) + +Write-Host "Extracting Cassandra..." +7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null +7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null +del $tgzPath + +Write-Host "Starting Cassandra..." +Start-Process $cassandra -PassThru + +Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 new file mode 100755 index 0000000000..b66f51da56 --- /dev/null +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -0,0 +1,31 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan +$esVersion = "7.3.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" +$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" +$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" +$esRoot = "$extractRoot\elasticsearch-$esVersion" +[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") +Write-Host "Environment..." -ForegroundColor Cyan +Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize + +Write-Host "Downloading Elasticsearch..." +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$extractRoot" | Out-Null +del $zipPath +Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} + +Write-Host "Installing Elasticsearch as a Windows service..." +& "$esRoot\bin\elasticsearch-service.bat" install + +Write-Host "Starting Elasticsearch service..." +& "$esRoot\bin\elasticsearch-service.bat" start + +do { + Write-Host "Waiting for Elasticsearch service to bootstrap..." + sleep 1 +} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) + +Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 new file mode 100755 index 0000000000..bc2a15cfdb --- /dev/null +++ b/test/script/appveyor/install-redis.ps1 @@ -0,0 +1,21 @@ +# Abort with non zero exit code on errors +$ErrorActionPreference = "Stop" + +Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan +$redisVersion = "2.8.19" +$redisRoot = "$env:SYSTEMDRIVE\Redis" +$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" +$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" + +Write-Host "Downloading Redis..." -ForegroundColor Cyan +(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +7z x $zipPath -y -o"$redisRoot" | Out-Null +del $zipPath + +Write-Host "Installing Redis as a Windows service..." +& "$redisRoot\redis-server.exe" --service-install + +Write-Host "Starting Redis service..." +& "$redisRoot\redis-server.exe" --service-start + +Write-Host "Redis installed" -ForegroundColor Green From 324c61817f2f71f99b38461bdacbc2249878eedd Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 15:37:16 +0000 Subject: [PATCH 113/117] ci(jenkins): reset scripts to master version --- test/script/appveyor/install-cassandra.ps1 | 4 +--- test/script/appveyor/install-elasticsearch.ps1 | 8 ++------ test/script/appveyor/install-redis.ps1 | 10 +++------- 3 files changed, 6 insertions(+), 16 deletions(-) diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 index 76f5730a82..6f5b9e9701 100755 --- a/test/script/appveyor/install-cassandra.ps1 +++ b/test/script/appveyor/install-cassandra.ps1 @@ -1,7 +1,6 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Write-Host "Preparing to download and install Cassandra..." -ForegroundColor Cyan $cassandraVersion = "3.11.3" $downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" $extractRoot = "$env:USERPROFILE" @@ -10,12 +9,11 @@ $tarPath = "$extractRoot\cassandra.tar" $cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $tgzPath) +appveyor DownloadFile $downloadUrl -FileName $tgzPath Write-Host "Extracting Cassandra..." 7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null 7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null -del $tgzPath Write-Host "Starting Cassandra..." Start-Process $cassandra -PassThru diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 index b66f51da56..d4da2cfbc8 100755 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ b/test/script/appveyor/install-elasticsearch.ps1 @@ -2,20 +2,16 @@ $ErrorActionPreference = "Stop" Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "7.3.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion)-windows-x86_64.zip" +$esVersion = "6.1.2" +$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion).zip" $zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" $extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" $esRoot = "$extractRoot\elasticsearch-$esVersion" -[Environment]::SetEnvironmentVariable("JAVA_HOME",$null,"User") -Write-Host "Environment..." -ForegroundColor Cyan -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize Write-Host "Downloading Elasticsearch..." (New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) 7z x $zipPath -y -o"$extractRoot" | Out-Null del $zipPath -Get-ChildItem $esRoot | where {$_.Attributes -match'Directory'} Write-Host "Installing Elasticsearch as a Windows service..." & "$esRoot\bin\elasticsearch-service.bat" install diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 index bc2a15cfdb..c8506ff4b0 100755 --- a/test/script/appveyor/install-redis.ps1 +++ b/test/script/appveyor/install-redis.ps1 @@ -1,14 +1,10 @@ # Abort with non zero exit code on errors $ErrorActionPreference = "Stop" -Write-Host "Preparing to download and install Redis..." -ForegroundColor Cyan -$redisVersion = "2.8.19" -$redisRoot = "$env:SYSTEMDRIVE\Redis" -$zipPath = "$($env:USERPROFILE)\redis-$redisVersion.zip" -$downloadUrl = "https://github.com/MSOpenTech/redis/releases/download/win-$redisVersion/redis-$redisVersion.zip" - Write-Host "Downloading Redis..." -ForegroundColor Cyan -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) +$redisRoot = "$env:SYSTEMDRIVE\Redis" +$zipPath = "$($env:USERPROFILE)\redis-2.8.19.zip" +(New-Object Net.WebClient).DownloadFile('https://github.com/MSOpenTech/redis/releases/download/win-2.8.19/redis-2.8.19.zip', $zipPath) 7z x $zipPath -y -o"$redisRoot" | Out-Null del $zipPath From 03923bf57f2e5cbdb67ee2474682ed9f2d77db03 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Sun, 15 Dec 2019 16:36:46 +0000 Subject: [PATCH 114/117] ci(jenkins): appveyor is not required --- .appveyor.yml | 28 ------------------- test/script/appveyor/install-cassandra.ps1 | 21 -------------- .../script/appveyor/install-elasticsearch.ps1 | 27 ------------------ test/script/appveyor/install-redis.ps1 | 17 ----------- 4 files changed, 93 deletions(-) delete mode 100644 .appveyor.yml delete mode 100755 test/script/appveyor/install-cassandra.ps1 delete mode 100755 test/script/appveyor/install-elasticsearch.ps1 delete mode 100755 test/script/appveyor/install-redis.ps1 diff --git a/.appveyor.yml b/.appveyor.yml deleted file mode 100644 index 2355eb74da..0000000000 --- a/.appveyor.yml +++ /dev/null @@ -1,28 +0,0 @@ -environment: - PGUSER: "postgres" - PGPASSWORD: "Password12!" - MYSQL_PASSWORD: "Password12!" - -# Install scripts runs after repo cloning -install: - - ps: .\test\script\appveyor\install-redis.ps1 - - ps: .\test\script\appveyor\install-elasticsearch.ps1 - - ps: .\test\script\appveyor\install-cassandra.ps1 - - ps: Install-Product node 10 # Latest LTS - - npm install - -# Services are started after all install scripts have run -services: - - mysql - - mongodb - - postgresql - - mssql2017 - -# Post-install test scripts -test_script: - - node --version - - npm --version - - node test/test.js - -# Don't actually build -build: off diff --git a/test/script/appveyor/install-cassandra.ps1 b/test/script/appveyor/install-cassandra.ps1 deleted file mode 100755 index 6f5b9e9701..0000000000 --- a/test/script/appveyor/install-cassandra.ps1 +++ /dev/null @@ -1,21 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -$cassandraVersion = "3.11.3" -$downloadUrl = "http://archive.apache.org/dist/cassandra/$cassandraVersion/apache-cassandra-$cassandraVersion-bin.tar.gz" -$extractRoot = "$env:USERPROFILE" -$tgzPath = "$extractRoot\cassandra.tar.gz" -$tarPath = "$extractRoot\cassandra.tar" -$cassandra = "$extractRoot\apache-cassandra-$cassandraVersion\bin\cassandra.bat" - -Write-Host "Downloading Cassandra..." -ForegroundColor Cyan -appveyor DownloadFile $downloadUrl -FileName $tgzPath - -Write-Host "Extracting Cassandra..." -7z e $tgzPath -tgzip -y -o"$extractRoot" | Out-Null -7z x $tarPath -ttar -r -aou -o"$extractRoot" | Out-Null - -Write-Host "Starting Cassandra..." -Start-Process $cassandra -PassThru - -Write-Host "Cassandra $cassandraVersion running" -ForegroundColor Green diff --git a/test/script/appveyor/install-elasticsearch.ps1 b/test/script/appveyor/install-elasticsearch.ps1 deleted file mode 100755 index d4da2cfbc8..0000000000 --- a/test/script/appveyor/install-elasticsearch.ps1 +++ /dev/null @@ -1,27 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Preparing to download and install Elasticsearch..." -ForegroundColor Cyan -$esVersion = "6.1.2" -$downloadUrl = "https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-$($esVersion).zip" -$zipPath = "$($env:USERPROFILE)\elasticsearch-$esVersion.zip" -$extractRoot = "$env:SYSTEMDRIVE\Elasticsearch" -$esRoot = "$extractRoot\elasticsearch-$esVersion" - -Write-Host "Downloading Elasticsearch..." -(New-Object Net.WebClient).DownloadFile($downloadUrl, $zipPath) -7z x $zipPath -y -o"$extractRoot" | Out-Null -del $zipPath - -Write-Host "Installing Elasticsearch as a Windows service..." -& "$esRoot\bin\elasticsearch-service.bat" install - -Write-Host "Starting Elasticsearch service..." -& "$esRoot\bin\elasticsearch-service.bat" start - -do { - Write-Host "Waiting for Elasticsearch service to bootstrap..." - sleep 1 -} until(Test-NetConnection localhost -Port 9200 | ? { $_.TcpTestSucceeded } ) - -Write-Host "Elasticsearch installed" -ForegroundColor Green diff --git a/test/script/appveyor/install-redis.ps1 b/test/script/appveyor/install-redis.ps1 deleted file mode 100755 index c8506ff4b0..0000000000 --- a/test/script/appveyor/install-redis.ps1 +++ /dev/null @@ -1,17 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "Downloading Redis..." -ForegroundColor Cyan -$redisRoot = "$env:SYSTEMDRIVE\Redis" -$zipPath = "$($env:USERPROFILE)\redis-2.8.19.zip" -(New-Object Net.WebClient).DownloadFile('https://github.com/MSOpenTech/redis/releases/download/win-2.8.19/redis-2.8.19.zip', $zipPath) -7z x $zipPath -y -o"$redisRoot" | Out-Null -del $zipPath - -Write-Host "Installing Redis as a Windows service..." -& "$redisRoot\redis-server.exe" --service-install - -Write-Host "Starting Redis service..." -& "$redisRoot\redis-server.exe" --service-start - -Write-Host "Redis installed" -ForegroundColor Green From 891b38fa5255af0f534fbfbfa832a4b6cd70ddd2 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 3 Mar 2020 11:02:05 +0000 Subject: [PATCH 115/117] ci(jenkins): use installTools step --- .ci/Jenkinsfile | 6 ++---- .ci/scripts/windows/install-tools.ps1 | 12 ------------ 2 files changed, 2 insertions(+), 16 deletions(-) delete mode 100644 .ci/scripts/windows/install-tools.ps1 diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index 45d68e97e9..d0d10ecc28 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -471,15 +471,13 @@ def generateStepForWindows(Map params = [:]){ deleteDir() unstash 'source' dir(BASE_DIR) { - powershell label: 'Install tools', script: ".\\.ci\\scripts\\windows\\install-tools.ps1" + installTools([ [tool: 'nodejs', version: "${version}" ] ]) bat label: 'Tool versions', script: ''' npm --version node --version ''' bat 'npm install' - bat ''' - node test/test.js - ''' + bat 'node test/test.js' } } catch(e){ error(e.toString()) diff --git a/.ci/scripts/windows/install-tools.ps1 b/.ci/scripts/windows/install-tools.ps1 deleted file mode 100644 index 3d9c44e6c1..0000000000 --- a/.ci/scripts/windows/install-tools.ps1 +++ /dev/null @@ -1,12 +0,0 @@ -# Abort with non zero exit code on errors -$ErrorActionPreference = "Stop" - -Write-Host "List environment variables ..." -Get-ChildItem Env: | Sort Name | Format-Table -Wrap -AutoSize - -Write-Host("Getting latest Nodejs version for {0} ..." -f $env:VERSION) -& choco list nodejs --exact --by-id-only --all | Select-String -Pattern "nodejs $env:VERSION" -$Version = $(choco list nodejs --exact --by-id-only --all) | Select-String -Pattern "nodejs $env:VERSION" | %{$_.ToString().split(" ")[1]} | sort {[version] $_} | Select-Object -Last 1 - -Write-Host("Installing Nodejs {0} ..." -f $Version) -& choco install nodejs --no-progress -y --version "$Version" From 1b8d9ec44d10236f6bb9249e796b592a9b6563e1 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 3 Mar 2020 11:48:04 +0000 Subject: [PATCH 116/117] ci(jenkins): store JUnit for the Windows stage --- .ci/Jenkinsfile | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index d0d10ecc28..a779d8b77b 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -478,15 +478,23 @@ def generateStepForWindows(Map params = [:]){ ''' bat 'npm install' bat 'node test/test.js' + stash includes: '**/*-output.tap', name: 'windows-tap', useDefaultExcludes: true } } catch(e){ error(e.toString()) - } finally { - echo 'JUnit archiving no yet in place' } } } + // Let's now prepare the test output + dir('windows') { + unstash 'windows-tap' + docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}/windows:/app"){ + sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') + } + junit(allowEmptyResults: true, keepLongStdio: true, testResults: '**/junit-*.xml') + } + // If the above execution failed, then it will not reach this section. TBD sh label: 'Stop services', script: ".ci/scripts/windows/stop-test.sh ${version}" } From 35e355f5995572036ea091f9f34d5c5847d56326 Mon Sep 17 00:00:00 2001 From: Victor Martinez Date: Tue, 3 Mar 2020 12:43:53 +0000 Subject: [PATCH 117/117] Revert "ci(jenkins): store JUnit for the Windows stage" This reverts commit 1b8d9ec44d10236f6bb9249e796b592a9b6563e1. --- .ci/Jenkinsfile | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/.ci/Jenkinsfile b/.ci/Jenkinsfile index a779d8b77b..d0d10ecc28 100644 --- a/.ci/Jenkinsfile +++ b/.ci/Jenkinsfile @@ -478,23 +478,15 @@ def generateStepForWindows(Map params = [:]){ ''' bat 'npm install' bat 'node test/test.js' - stash includes: '**/*-output.tap', name: 'windows-tap', useDefaultExcludes: true } } catch(e){ error(e.toString()) + } finally { + echo 'JUnit archiving no yet in place' } } } - // Let's now prepare the test output - dir('windows') { - unstash 'windows-tap' - docker.image('node:12').inside("-v ${WORKSPACE}/${BASE_DIR}/windows:/app"){ - sh(label: "Convert Test results to JUnit format", script: 'cd /app && .ci/scripts/convert_tap_to_junit.sh') - } - junit(allowEmptyResults: true, keepLongStdio: true, testResults: '**/junit-*.xml') - } - // If the above execution failed, then it will not reach this section. TBD sh label: 'Stop services', script: ".ci/scripts/windows/stop-test.sh ${version}" }