init
This commit is contained in:
13
App/docker/docker-compose.yaml
Normal file
13
App/docker/docker-compose.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
version: '3.7'
|
||||
services:
|
||||
app:
|
||||
build: ./php
|
||||
container_name: myapp
|
||||
ports:
|
||||
- 80:80
|
||||
networks:
|
||||
app_net:
|
||||
|
||||
networks:
|
||||
app_net:
|
||||
name: app_net
|
19
App/docker/php/Dockerfile
Normal file
19
App/docker/php/Dockerfile
Normal file
@@ -0,0 +1,19 @@
|
||||
FROM php:7.4-apache-buster
|
||||
MAINTAINER vasyakrg <vasyakrg@gmail.com>
|
||||
|
||||
RUN apt-get update && apt-get install -y \
|
||||
apt-transport-https \
|
||||
curl \
|
||||
wget \
|
||||
git \
|
||||
# && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \
|
||||
&& apt-get update && rm -rf /var/lib/apt/lists/*
|
||||
|
||||
RUN rm /etc/apache2/sites-enabled/*
|
||||
COPY myapp.conf /etc/apache2/sites-available/myapp.conf
|
||||
RUN a2enmod rewrite headers && a2ensite myapp
|
||||
|
||||
COPY myapp/ /var/www/
|
||||
|
||||
WORKDIR /var/www
|
||||
# CMD ['apache2-foreground']
|
3
App/docker/php/build.sh
Executable file
3
App/docker/php/build.sh
Executable file
@@ -0,0 +1,3 @@
|
||||
#!/bin/bash
|
||||
|
||||
docker build -t vasyakrg/php-app . && docker push vasyakrg/php-app
|
17
App/docker/php/myapp.conf
Normal file
17
App/docker/php/myapp.conf
Normal file
@@ -0,0 +1,17 @@
|
||||
<VirtualHost *:80>
|
||||
ServerName localhost
|
||||
DocumentRoot /var/www
|
||||
<Directory "/var/www">
|
||||
DirectoryIndex index.html
|
||||
</Directory>
|
||||
|
||||
ErrorLog /var/log/apache2/error.log
|
||||
CustomLog /var/log/apache2/access.log combined
|
||||
|
||||
RewriteEngine On
|
||||
|
||||
RewriteCond "%{DOCUMENT_ROOT}%{REQUEST_FILENAME}" !-f
|
||||
RewriteCond "%{DOCUMENT_ROOT}%{REQUEST_FILENAME}" !-d
|
||||
RewriteRule "^" "/index.php" [L]
|
||||
|
||||
</VirtualHost>
|
8
App/docker/php/myapp/index.php
Normal file
8
App/docker/php/myapp/index.php
Normal file
@@ -0,0 +1,8 @@
|
||||
<html>
|
||||
<head>
|
||||
<title>Тестируем PHP</title>
|
||||
</head>
|
||||
<body>
|
||||
<?php echo '<p>Привет, мир!</p>'; ?>
|
||||
</body>
|
||||
</html>
|
27
App/kubernetes/deploy.yaml
Normal file
27
App/kubernetes/deploy.yaml
Normal file
@@ -0,0 +1,27 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
namespace: myapp
|
||||
labels:
|
||||
app: myapp
|
||||
name: myapp
|
||||
spec:
|
||||
replicas: 1
|
||||
selector:
|
||||
matchLabels:
|
||||
app: myapp
|
||||
strategy:
|
||||
type: Recreate
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: myapp
|
||||
spec:
|
||||
hostname: app-pod
|
||||
restartPolicy: Always
|
||||
containers:
|
||||
- name: app-fpm
|
||||
image: vasyakrg/php-app
|
||||
imagePullPolicy: Always
|
||||
ports:
|
||||
- containerPort: 80
|
25
App/kubernetes/ingress.yaml
Normal file
25
App/kubernetes/ingress.yaml
Normal file
@@ -0,0 +1,25 @@
|
||||
apiVersion: networking.k8s.io/v1
|
||||
kind: Ingress
|
||||
metadata:
|
||||
namespace: myapp
|
||||
annotations:
|
||||
cert-manager.io/cluster-issuer: orc-letsencrypt-issuer
|
||||
nginx.ingress.kubernetes.io/proxy-body-size: 200m
|
||||
nginx.ingress.kubernetes.io/from-to-www-redirect: "true"
|
||||
name: k8s-app
|
||||
spec:
|
||||
rules:
|
||||
- host: app.k8s-nsk.tk
|
||||
http:
|
||||
paths:
|
||||
- pathType: Prefix
|
||||
path: /
|
||||
backend:
|
||||
service:
|
||||
name: app-service
|
||||
port:
|
||||
number: 80
|
||||
tls:
|
||||
- hosts:
|
||||
- app.k8s-nsk.tk
|
||||
secretName: app-k8s-nsk-tls
|
6
App/kubernetes/namespace.yaml
Normal file
6
App/kubernetes/namespace.yaml
Normal file
@@ -0,0 +1,6 @@
|
||||
# kubetpl:syntax:$
|
||||
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: myapp
|
13
App/kubernetes/service.yaml
Normal file
13
App/kubernetes/service.yaml
Normal file
@@ -0,0 +1,13 @@
|
||||
# App
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
namespace: myapp
|
||||
name: app-service
|
||||
spec:
|
||||
ports:
|
||||
- name: app-port
|
||||
port: 80
|
||||
selector:
|
||||
app: myapp
|
||||
---
|
4
Cluster/.gitignore
vendored
Normal file
4
Cluster/.gitignore
vendored
Normal file
@@ -0,0 +1,4 @@
|
||||
cluster.rkestate
|
||||
kube_config_cluster.yml
|
||||
tls/*.key
|
||||
tls/*.crt
|
4
Cluster/0-docker.sh
Executable file
4
Cluster/0-docker.sh
Executable file
@@ -0,0 +1,4 @@
|
||||
#!/bin/bash
|
||||
|
||||
# to all nodes
|
||||
apt update && apt install -y curl && curl https://get.docker.com -o install.sh && sh install.sh
|
7
Cluster/1-rke.sh
Executable file
7
Cluster/1-rke.sh
Executable file
@@ -0,0 +1,7 @@
|
||||
#!/bin/bash
|
||||
|
||||
# brew install rke
|
||||
# https://rancher.com/docs/rke/latest/en/installation/
|
||||
|
||||
# create cluster
|
||||
rke up
|
10
Cluster/2-add-config.sh
Executable file
10
Cluster/2-add-config.sh
Executable file
@@ -0,0 +1,10 @@
|
||||
#!/bin/bash
|
||||
|
||||
# add config file
|
||||
cat kube_config_cluster.yml > ~/.kube/k8s-hls
|
||||
|
||||
# enable config auth
|
||||
export KUBECONFIG=$(find ~/.kube -maxdepth 1 -type f -name '*' | tr "\n" ":")
|
||||
|
||||
# test auth to cluster
|
||||
kubectl get pods --all-namespaces
|
25
Cluster/3-init-certmanager.sh
Executable file
25
Cluster/3-init-certmanager.sh
Executable file
@@ -0,0 +1,25 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Install the CustomResourceDefinition resources separately
|
||||
kubectl apply -f https://github.com/jetstack/cert-manager/releases/download/v1.3.1/cert-manager.crds.yaml
|
||||
|
||||
# Create the namespace for cert-manager
|
||||
kubectl create namespace cert-manager
|
||||
|
||||
# Add the Jetstack Helm repository
|
||||
helm repo add cert-manager https://charts.jetstack.io
|
||||
|
||||
# Update your local Helm chart repository cache
|
||||
helm repo update
|
||||
|
||||
helm upgrade --install \
|
||||
cert-manager \
|
||||
cert-manager/cert-manager \
|
||||
--namespace cert-manager \
|
||||
--version 1.3.1
|
||||
|
||||
kubectl -n cert-manager rollout status deploy/cert-manager
|
||||
|
||||
sleep 5
|
||||
|
||||
kubectl apply -f certmanager/orc-letsencrypt-issuer.yaml
|
15
Cluster/certmanager/orc-letsencrypt-issuer.yaml
Normal file
15
Cluster/certmanager/orc-letsencrypt-issuer.yaml
Normal file
@@ -0,0 +1,15 @@
|
||||
apiVersion: cert-manager.io/v1
|
||||
kind: ClusterIssuer
|
||||
metadata:
|
||||
name: orc-letsencrypt-issuer
|
||||
spec:
|
||||
acme:
|
||||
server: https://acme-v02.api.letsencrypt.org/directory
|
||||
email: vasyakrg@gmail.com
|
||||
privateKeySecretRef:
|
||||
name: orc-letsencrypt-private-key
|
||||
solvers:
|
||||
- selector: {}
|
||||
http01:
|
||||
ingress:
|
||||
class: nginx
|
64
Cluster/cluster.yml
Normal file
64
Cluster/cluster.yml
Normal file
@@ -0,0 +1,64 @@
|
||||
cluster_name: k8s-cluster
|
||||
name: k8s-cluster
|
||||
enable_cluster_alerting: false
|
||||
enable_cluster_monitoring: false
|
||||
ignore_docker_version: true
|
||||
kubernetes_version: v1.19.9-rancher1-1
|
||||
|
||||
nodes:
|
||||
- address: 65.21.148.66
|
||||
internal_address: 10.0.0.3
|
||||
hostname_override: node1
|
||||
user: root
|
||||
labels:
|
||||
worker: yes
|
||||
location: nsk
|
||||
role: [controlplane, worker, etcd]
|
||||
- address: 65.21.146.162
|
||||
internal_address: 10.0.0.2
|
||||
hostname_override: node2
|
||||
user: root
|
||||
labels:
|
||||
worker: yes
|
||||
location: nsk
|
||||
role: [controlplane, worker, etcd]
|
||||
- address: 65.21.149.204
|
||||
internal_address: 10.0.0.4
|
||||
hostname_override: node3
|
||||
user: root
|
||||
labels:
|
||||
worker: yes
|
||||
location: nsk
|
||||
role: [controlplane, worker, etcd]
|
||||
|
||||
services:
|
||||
etcd:
|
||||
snapshot: true
|
||||
creation: 6h
|
||||
retention: 30h
|
||||
kube-controller:
|
||||
extra_args:
|
||||
terminated-pod-gc-threshold: 100
|
||||
kubelet:
|
||||
extra_args:
|
||||
max-pods: 250
|
||||
kube-api:
|
||||
extra_args:
|
||||
feature-gates: "ServiceAccountIssuerDiscovery=false,RemoveSelfLink=false"
|
||||
|
||||
authentication:
|
||||
strategy: x509
|
||||
sans:
|
||||
- "167.233.11.162"
|
||||
- "rke.k8s-nsk.tk"
|
||||
|
||||
dns:
|
||||
provider: coredns
|
||||
upstreamnameservers:
|
||||
- 8.8.8.8
|
||||
- 8.8.4.4
|
||||
|
||||
ingress:
|
||||
provider: nginx
|
||||
options:
|
||||
use-forwarded-headers: "true"
|
Reference in New Issue
Block a user