add dqlite

pull/998/head
galal-hussein 2019-11-15 13:14:28 +02:00
parent 2165464af6
commit 9969dc9cff
7 changed files with 30 additions and 29 deletions

View File

@ -27,7 +27,4 @@ runcmd:
- apt-get install -y software-properties-common - apt-get install -y software-properties-common
- apt-get install -y resolvconf linux-headers-$(uname -r) && echo "nameserver 1.1.1.1" > /etc/resolvconf/resolv.conf.d/tail && systemctl start resolvconf - apt-get install -y resolvconf linux-headers-$(uname -r) && echo "nameserver 1.1.1.1" > /etc/resolvconf/resolv.conf.d/tail && systemctl start resolvconf
- DEBIAN_FRONTEND=noninteractive apt-get upgrade -y - DEBIAN_FRONTEND=noninteractive apt-get upgrade -y
- wget https://raw.githubusercontent.com/galal-hussein/k3s/k3s_with_kine_fix/k3s
- cp k3s /usr/local/bin/k3s
- chmod +x /usr/local/bin/k3s
- until (curl -sfL https://get.k3s.io | K3S_URL=https://${k3s_url}:6443 K3S_CLUSTER_SECRET="${k3s_cluster_secret}" K3S_CLUSTER_SECRET="${k3s_cluster_secret}" INSTALL_K3S_VERSION="${install_k3s_version}" sh -); do echo 'Error installing k3s agent'; sleep 1; done - until (curl -sfL https://get.k3s.io | K3S_URL=https://${k3s_url}:6443 K3S_CLUSTER_SECRET="${k3s_cluster_secret}" K3S_CLUSTER_SECRET="${k3s_cluster_secret}" INSTALL_K3S_VERSION="${install_k3s_version}" sh -); do echo 'Error installing k3s agent'; sleep 1; done

View File

@ -10,7 +10,7 @@ locals {
} }
provider "aws" { provider "aws" {
region = "us-west-2" region = "us-east-2"
profile = "rancher-eng" profile = "rancher-eng"
} }
@ -76,7 +76,7 @@ module "k3s-pool-worker-asg" {
root_block_device = [ root_block_device = [
{ {
volume_size = "100" volume_size = "30"
volume_type = "gp2" volume_type = "gp2"
}, },
] ]

View File

@ -1,21 +1,21 @@
## MAIN VARIABLES ## ## MAIN VARIABLES ##
#################### ####################
CLUSTER_NAME="loadtest-k3s" CLUSTER_NAME="loadtest-k3s"
DOMAIN_NAME="" DOMAIN_NAME="loadtest.eng.rancher.space"
ZONE_ID="" ZONE_ID=""
K3S_VERSION="v0.11.0-alpha2" K3S_VERSION="v1.0.0"
EXTRA_SSH_KEYS="" # comma separated public keys EXTRA_SSH_KEYS="" # comma separated public keys
PRIVATE_KEY_PATH="~/.ssh/id_rsa" PRIVATE_KEY_PATH="~/.ssh/id_rsa"
DEBUG=1 DEBUG=1
## K3S DB VARIABLES ## ## K3S DB VARIABLES ##
########################## ##########################
DB_ENGINE="postgres" DB_ENGINE="dqlite"
DB_INSTANCE_TYPE="db.m4.4xlarge" DB_INSTANCE_TYPE="db.m4.4xlarge"
DB_NAME="k3s" DB_NAME="k3s"
DB_USERNAME="k3suser" DB_USERNAME="k3suser"
DB_PASSWORD="024d9442b3add64b7ef90655bc302cd8" DB_PASSWORD="024d9442b3add64b7ef90655bc302cd8"
DB_VERSION=11.5 DB_VERSION=5.7
## K3S SERVER VARIABLES ## ## K3S SERVER VARIABLES ##
########################## ##########################
@ -30,5 +30,5 @@ PROM_WORKER_INSTANCE_TYPE="m5.large"
## K3S AGENTS VARIABLES ## ## K3S AGENTS VARIABLES ##
########################## ##########################
AGENT_NODE_COUNT=100 AGENT_NODE_COUNT=10
AGENT_INSTANCE_TYPE="m5.large" AGENT_INSTANCE_TYPE="m5.large"

View File

@ -16,18 +16,24 @@ write_files:
STORAGE_ENDPOINT="postgres://${db_username}:${db_password}@${db_address}:5432/${db_name}" STORAGE_ENDPOINT="postgres://${db_username}:${db_password}@${db_address}:5432/${db_name}"
elif [ ${db_engine} == "mysql" ]; then elif [ ${db_engine} == "mysql" ]; then
STORAGE_ENDPOINT="mysql://${db_username}:${db_password}@(${db_address})/${db_name}" STORAGE_ENDPOINT="mysql://${db_username}:${db_password}@(${db_address})/${db_name}"
else elif [ ${db_engine} == "etcd" ]; then
IFS=',' read -r -a private_ips <<< "${db_address}" IFS=',' read -r -a private_ips <<< "${db_address}"
for i in "$${!private_ips[@]}"; do for i in "$${!private_ips[@]}"; do
STORAGE_ENDPOINT=$STORAGE_ENDPOINT"http://$${private_ips[i]}:2379", STORAGE_ENDPOINT=$STORAGE_ENDPOINT"http://$${private_ips[i]}:2379",
done done
STORAGE_ENDPOINT=$${STORAGE_ENDPOINT%?} STORAGE_ENDPOINT=$${STORAGE_ENDPOINT%?}
echo hello
fi fi
while true; do while true; do
if [ ${db_engine} == "dqlite" ]; then
curl -sfL https://get.k3s.io | K3S_CLUSTER_SECRET="${k3s_cluster_secret}" \
INSTALL_K3S_VERSION="${install_k3s_version}" \
INSTALL_K3S_EXEC="${k3s_server_args} --cluster-cidr=10.0.0.0/8 --no-deploy traefik --no-deploy servicelb --tls-san ${lb_address} %{ if master_index != 0 } --server https://${lb_address}:6443 %{ else } --cluster-init %{ endif }" sh -
else
curl -sfL https://get.k3s.io | K3S_CLUSTER_SECRET="${k3s_cluster_secret}" \ curl -sfL https://get.k3s.io | K3S_CLUSTER_SECRET="${k3s_cluster_secret}" \
INSTALL_K3S_VERSION="${install_k3s_version}" \ INSTALL_K3S_VERSION="${install_k3s_version}" \
INSTALL_K3S_EXEC="${k3s_server_args} --cluster-cidr=10.0.0.0/8 --no-deploy traefik --no-deploy servicelb --tls-san ${lb_address} %{ if use_ha == "true" } --storage-endpoint=$STORAGE_ENDPOINT %{ endif }" sh - INSTALL_K3S_EXEC="${k3s_server_args} --cluster-cidr=10.0.0.0/8 --no-deploy traefik --no-deploy servicelb --tls-san ${lb_address} %{ if use_ha == "true" } --datastore-endpoint=$STORAGE_ENDPOINT %{ endif }" sh -
fi
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
break break
fi fi

View File

@ -23,7 +23,4 @@ runcmd:
- echo " * soft nofile 20000" >> /etc/security/limits.d/limits.conf - echo " * soft nofile 20000" >> /etc/security/limits.d/limits.conf
- echo " * hard nofile 20000" >> /etc/security/limits.d/limits.conf - echo " * hard nofile 20000" >> /etc/security/limits.d/limits.conf
- sysctl -p - sysctl -p
- wget https://raw.githubusercontent.com/galal-hussein/k3s/scale_test/k3s
- cp k3s /usr/local/bin/k3s
- chmod +x /usr/local/bin/k3s
- until (curl -sfL https://get.k3s.io | INSTALL_K3S_VERSION=${install_k3s_version} INSTALL_K3S_EXEC="${k3s_exec}" K3S_URL=https://${k3s_url}:6443 K3S_CLUSTER_SECRET="${k3s_cluster_secret}" sh -); do echo 'k3s did not install correctly'; sleep 1; done - until (curl -sfL https://get.k3s.io | INSTALL_K3S_VERSION=${install_k3s_version} INSTALL_K3S_EXEC="${k3s_exec}" K3S_URL=https://${k3s_url}:6443 K3S_CLUSTER_SECRET="${k3s_cluster_secret}" sh -); do echo 'k3s did not install correctly'; sleep 1; done

View File

@ -13,7 +13,7 @@ locals {
} }
provider "aws" { provider "aws" {
region = "us-west-2" region = "us-east-2"
profile = "rancher-eng" profile = "rancher-eng"
} }
@ -58,10 +58,9 @@ resource "aws_security_group" "k3s" {
} }
resource "aws_db_instance" "k3s_db" { resource "aws_db_instance" "k3s_db" {
count = "${var.db_engine == "etcd" ? 0 : var.server_ha}" count = "${var.db_engine == "postgres" || var.db_engine == "mysql" ? 1 : 0 }"
allocated_storage = 100 #baseline iops is 300 with gp2 allocated_storage = 100 #baseline iops is 300 with gp2
storage_type = "io1" storage_type = "gp2"
iops = "3000"
engine = "${var.db_engine}" engine = "${var.db_engine}"
engine_version = "${var.db_version}" engine_version = "${var.db_version}"
instance_class = "${var.db_instance_type}" instance_class = "${var.db_instance_type}"
@ -87,7 +86,7 @@ resource "aws_instance" "k3s_etcd" {
] ]
root_block_device { root_block_device {
volume_size = "100" volume_size = "30"
volume_type = "gp2" volume_type = "gp2"
} }
@ -156,8 +155,8 @@ resource "aws_instance" "k3s-server" {
k3s_cluster_secret = local.k3s_cluster_secret, k3s_cluster_secret = local.k3s_cluster_secret,
install_k3s_version = local.install_k3s_version, install_k3s_version = local.install_k3s_version,
k3s_server_args = var.k3s_server_args, k3s_server_args = var.k3s_server_args,
db_engine = var.db_engine db_engine = var.db_engine,
db_address = "${var.db_engine == "etcd" ? join(",",aws_instance.k3s_etcd.*.private_ip) : aws_db_instance.k3s_db[0].address}", db_address = "${var.db_engine == "etcd" ? join(",",aws_instance.k3s_etcd.*.private_ip) : var.db_engine == "dqlite" ? "null" : aws_db_instance.k3s_db[0].address}",
db_name = var.db_name, db_name = var.db_name,
db_username = var.db_username, db_username = var.db_username,
db_password = var.db_password, db_password = var.db_password,
@ -172,12 +171,14 @@ resource "aws_instance" "k3s-server" {
] ]
root_block_device { root_block_device {
volume_size = "100" volume_size = "30"
volume_type = "gp2" volume_type = "gp2"
} }
tags = { tags = {
Name = "${local.name}-server-${count.index}" Name = "${local.name}-server-${count.index}"
Role = "master"
Leader = "${count.index == 0 ? "true" : "false"}"
} }
provisioner "local-exec" { provisioner "local-exec" {
command = "sleep 10" command = "sleep 10"
@ -208,7 +209,7 @@ module "k3s-prom-worker-asg" {
root_block_device = [ root_block_device = [
{ {
volume_size = "100" volume_size = "30"
volume_type = "gp2" volume_type = "gp2"
}, },
] ]

View File

@ -6,11 +6,11 @@
#Constants #Constants
{{$NODE_MODE := DefaultParam .NODE_MODE "allnodes"}} {{$NODE_MODE := DefaultParam .NODE_MODE "allnodes"}}
{{$NODES_PER_NAMESPACE := DefaultParam .NODES_PER_NAMESPACE 100}} {{$NODES_PER_NAMESPACE := DefaultParam .NODES_PER_NAMESPACE 10}}
{{$PODS_PER_NODE := DefaultParam .PODS_PER_NODE 100}} {{$PODS_PER_NODE := DefaultParam .PODS_PER_NODE 30}}
{{$LOAD_TEST_THROUGHPUT := DefaultParam .LOAD_TEST_THROUGHPUT 10}} {{$LOAD_TEST_THROUGHPUT := DefaultParam .LOAD_TEST_THROUGHPUT 10}}
{{$BIG_GROUP_SIZE := 1000}} {{$BIG_GROUP_SIZE := 300}}
{{$MEDIUM_GROUP_SIZE := 500}} {{$MEDIUM_GROUP_SIZE := 150}}
{{$SMALL_GROUP_SIZE := 50}} {{$SMALL_GROUP_SIZE := 50}}
{{$SMALL_STATEFUL_SETS_PER_NAMESPACE := 1}} {{$SMALL_STATEFUL_SETS_PER_NAMESPACE := 1}}
{{$MEDIUM_STATEFUL_SETS_PER_NAMESPACE := 1}} {{$MEDIUM_STATEFUL_SETS_PER_NAMESPACE := 1}}