zoukankan      html  css  js  c++  java
  • Kubernetes集群存储之etcd

    Kubernetes集群存储之etcd

    部署

    签发ca证书

    创建证书请求文件

    [root@lab-26 ~]# vi /opt/certs/ca-config.json
    
    {
        "signing": {
            "default": {
                "expiry": "175200h"
            },
            "profiles": {
                "server": {
                    "expiry": "175200h",
                    "usages": [
                        "signing",
                        "key encipherment",
                        "server auth"
                    ]
                },
                "client": {
                    "expiry": "175200h",
                    "usages": [
                        "signing",
                        "key encipherment",
                        "client auth"
                    ]
                },
                "peer": {
                    "expiry": "175200h",
                    "usages": [
                        "signing",
                        "key encipherment",
                        "server auth",
                        "client auth"
                    ]
                }
            }
        }
    }
    

    创建证书文件

    [root@lab-26 ~]# vi /opt/certs/etcd-peer-csr.json
    
    # hosts 只能添加ip地址,地址为可能部署的etcd的服务器上
    {
        "CN": "k8s-etcd",
        "hosts": [
            "172.17.152.106"
        ],
        "key": {
            "algo": "rsa",
            "size": 2048
        },
        "names": [
            {
                "C": "CN",
                "ST": "beijing",
                "L": "beijing",
                "O": "op",
                "OU": "ops"
            }
        ]
    }
    

    签发证书

    [root@lab-26 certs]# cfssl gencert -ca=ca.pem -ca-key=ca-key.pem -config=ca-config.json -profile=peer etcd-peer-csr.json |cfssl-json -bare etcd-peer
    

    解压配置etcd

    [root@lab-26 certs]# useradd -s /sbin/nologin -M etcd
    [root@lab-26 certs]# cd /opt/src 
    

    软件包下载地址

    [root@lab-26 certs]# tar xvf etcd-v3.1.20-linux-amd64.tar.gz -C /opt/
    [root@lab-26 src]# cd /opt/
    [root@lab-26 opt]# mv etcd-v3.1.20-linux-amd64/ etcd-v3.1.20
    [root@lab-26 opt]# ln -s etcd-v3.1.20/ etcd
    [root@lab-26 opt]# mkdir -p /data/etcd /opt/etcd/certs /data/logs/etcd-server
    

    拷贝证书

    [root@lab-26 opt]# cd /opt/etcd/certs/
    [root@lab-26 certs]# cp /opt/certs/ca.pem .
    [root@lab-26 certs]# cp /opt/certs/ca-key.pem .
    [root@lab-26 certs]# cp /opt/certs/etcd-peer .
    [root@lab-26 certs]# cp /opt/certs/etcd-peer-key.pem .
    [root@lab-26 certs]# cp /opt/certs/etcd-peer.pem .
    

    创建启动脚本

    [root@lab-26 certs]# vi /opt/etcd/etcd-server-startup.sh
    
    #!/bin/sh
    ./etcd --name etcd-server-152-106 
           --data-dir /data/etcd/etcd-server 
           --listen-peer-urls https://172.17.152.106:2380 
           --listen-client-urls https://172.17.152.106:2379,http://127.0.0.1:2379 
           --quota-backend-bytes 8000000000 
           --initial-advertise-peer-urls https://172.17.152.106:2380 
           --advertise-client-urls https://172.17.152.106:2379,http://127.0.0.1:2379 
           --initial-cluster  etcd-server-152-106=https://172.17.152.106:2380 
           --ca-file ./certs/ca.pem 
           --cert-file ./certs/etcd-peer.pem 
           --key-file ./certs/etcd-peer-key.pem 
           --client-cert-auth  
           --trusted-ca-file ./certs/ca.pem 
           --peer-ca-file ./certs/ca.pem 
           --peer-cert-file ./certs/etcd-peer.pem 
           --peer-key-file ./certs/etcd-peer-key.pem 
           --peer-client-cert-auth 
           --peer-trusted-ca-file ./certs/ca.pem 
           --log-output stdout
    
    [root@lab-26 certs]# chmod +x /opt/etcd/etcd-server-startup.sh 
    [root@lab-26 certs]# chown -R etcd. /data/etcd
    [root@lab-26 certs]# chown -R etcd. /data/logs/
    [root@lab-26 certs]# chown -R etcd. /opt/etcd/certs
    

    使用supervisor工具管理服务

    [root@lab-26 certs]# vi /etc/supervisord.d/etcd-server.ini
    
    [program:etcd-server-152-106]
    command=/opt/etcd/etcd-server-startup.sh                        ; the program (relative uses PATH, can take args)
    numprocs=1                                                      ; number of processes copies to start (def 1)
    directory=/opt/etcd                                             ; directory to cwd to before exec (def no cwd)
    autostart=true                                                  ; start at supervisord start (default: true)
    autorestart=true                                                ; retstart at unexpected quit (default: true)
    startsecs=30                                                    ; number of secs prog must stay running (def. 1)
    startretries=3                                                  ; max # of serial start failures (default 3)
    exitcodes=0,2                                                   ; 'expected' exit codes for process (default 0,2)
    stopsignal=QUIT                                                 ; signal used to kill process (default TERM)
    stopwaitsecs=10                                                 ; max num secs to wait b4 SIGKILL (default 10)
    user=etcd                                                       ; setuid to this UNIX account to run the program
    redirect_stderr=true                                            ; redirect proc stderr to stdout (default false)
    stdout_logfile=/data/logs/etcd-server/etcd.stdout.log           ; stdout log path, NONE for none; default AUTO
    stdout_logfile_maxbytes=64MB                                    ; max # logfile bytes b4 rotation (default 50MB)
    stdout_logfile_backups=4                                        ; # of stdout logfile backups (default 10)
    stdout_capture_maxbytes=1MB                                     ; number of bytes in 'capturemode' (default 0)
    stdout_events_enabled=false                                     ; emit events on stdout writes (default false)
    killasgroup=true
    stopasgroup=true
    
    [root@lab-26 certs]# systemctl start supervisord
    [root@lab-26 certs]# systemctl enable supervisord
    [root@lab-26 ctchat]# supervisorctl status
    etcd-server-152-106              RUNNING   pid 22579, uptime 0:01:29
    

    至此部署成功。

    加油,你们是最棒的!
  • 相关阅读:
    GEF: 图形拖拽处理
    【矩阵快速幂】bzoj1297 [SCOI2009]迷路
    【扩展欧几里得】NOIP2012同余方程
    【高精度乘法】NOIP2003麦森数
    【数论·错位排列】bzoj4517 排列计数
    【数论】Lucas
    【NOIP2012】疫情传递
    【NOIP2012】旅行计划
    【Manacher算法】求最长回文串的优秀算法
    【Tarjan】洛谷P3379 Tarjan求LCA
  • 原文地址:https://www.cnblogs.com/Wshile/p/12842656.html
Copyright © 2011-2022 走看看