2023年6月27日发(作者:)
⼀键⽣成ssl⾃签名证书脚本#!/bin/bash -e# * 为必改项# * 更换为你⾃⼰的域名CN='' # 例如: # 扩展信任IP或域名## ⼀般ssl证书只信任域名的访问请求,有时候需要使⽤ip去访问server,那么需要给ssl证书添加扩展IP,## 多个IP⽤逗号隔开。如果想多个域名访问,则添加扩展域名(SSL_DNS),多个SSL_DNS⽤逗号隔开SSL_IP='' # 例如: 1.2.3.4SSL_DNS='' # 例如: # 国家名(2个字母的代号)C=CN# 证书加密位数SSL_SIZE=2048# 证书有效期DATE=${DATE:-3650}# 配置⽂件SSL_CONFIG=''if [[ -z $SILENT ]]; thenecho "----------------------------"echo "| SSL Cert Generator |"echo "----------------------------"echofiexport CA_KEY=${CA_KEY-""}export CA_CERT=${CA_CERT-""}export CA_SUBJECT=ca-$CNexport CA_EXPIRE=${DATE}export SSL_CONFIG=${SSL_CONFIG}export SSL_KEY=$ort SSL_CSR=$ort SSL_CERT=$ort SSL_EXPIRE=${DATE}export SSL_SUBJECT=${CN}export SSL_DNS=${SSL_DNS}export SSL_IP=${SSL_IP}export K8S_SECRET_COMBINE_CA=${K8S_SECRET_COMBINE_CA:-'true'}[[ -z $SILENT ]] && echo "--> Certificate Authority"if [[ -e ./${CA_KEY} ]]; then [[ -z $SILENT ]] && echo "====> Using existing CA Key ${CA_KEY}"else [[ -z $SILENT ]] && echo "====> Generating new CA key ${CA_KEY}" openssl genrsa -out ${CA_KEY} ${SSL_SIZE} > /dev/nullfiif [[ -e ./${CA_CERT} ]]; then [[ -z $SILENT ]] && echo "====> Using existing CA Certificate ${CA_CERT}"else [[ -z $SILENT ]] && echo "====> Generating new CA Certificate ${CA_CERT}" openssl req -x509 -sha256 -new -nodes -key ${CA_KEY} -days ${CA_EXPIRE} -out ${CA_CERT} -subj "/CN=${CA_SUBJECT}" > /dev/null || exit 1fiecho "====> Generating new config file ${SSL_CONFIG}"cat > ${SSL_CONFIG} <> ${SSL_CONFIG} <> ${SSL_CONFIG} done if [[ -n ${SSL_IP} ]]; then ip=(${SSL_IP}) for i in "${!ip[@]}"; do echo IP.$((i+1)) = ${ip[$i]} >> ${SSL_CONFIG} done fifi[[ -z $SILENT ]] && echo "====> Generating new SSL KEY ${SSL_KEY}"openssl genrsa -out ${SSL_KEY} ${SSL_SIZE} > /dev/null || exit 1[[ -z $SILENT ]] && echo "====> Generating new SSL CSR ${SSL_CSR}"openssl req -sha256 -new -key ${SSL_KEY} -out ${SSL_CSR} -subj "/CN=${SSL_SUBJECT}" -config ${SSL_CONFIG} > /dev/null || exit 1[[ -z $SILENT ]] && echo "====> Generating new SSL CERT ${SSL_CERT}"openssl x509 -sha256 -req -in ${SSL_CSR} -CA ${CA_CERT} -CAkey ${CA_KEY} -CAcreateserial -out ${SSL_CERT} -days ${SSL_EXPIRE} -extensions v3_req -extfile ${SSL_CONFIG} > /dev/null || exit 1if [[ -z $SILENT ]]; thenecho "====> Complete"echo "keys can be found in volume mapped to $(pwd)"echoecho "====> Output results as YAML"echo "---"echo "ca_key: |"cat $CA_KEY | sed 's/^/ /'echoecho "ca_cert: |"cat $CA_CERT | sed 's/^/ /'echoecho "ssl_key: |"cat $SSL_KEY | sed 's/^/ /'echoecho "ssl_csr: |"cat $SSL_CSR | sed 's/^/ /'echoecho "ssl_cert: |"cat $SSL_CERT | sed 's/^/ /'echofiif [[ -n $K8S_SECRET_NAME ]]; then if [[ -n $K8S_SECRET_COMBINE_CA ]]; then [[ -z $SILENT ]] && echo "====> Adding CA to Cert file" cat ${CA_CERT} >> ${SSL_CERT} fi [[ -z $SILENT ]] && echo "====> Creating Kubernetes secret: $K8S_SECRET_NAME" kubectl delete secret $K8S_SECRET_NAME --ignore-not-found if [[ -n $K8S_SECRET_SEPARATE_CA ]]; then kubectl create secret generic $K8S_SECRET_NAME --from-file="=${SSL_CERT}" --from-file="=${SSL_KEY}" --from-file="=${CA_CERT}" else kubectl create secret tls $K8S_SECRET_NAME --cert=${SSL_CERT} --key=${SSL_KEY} fi if [[ -n $K8S_SECRET_LABELS ]]; then [[ -z $SILENT ]] && echo "====> Labeling Kubernetes secret" IFS=$' nt' # We have to reset IFS or label secret will misbehave on some systems kubectl label secret $K8S_SECRET_NAME $K8S_SECRET_LABELS fifiecho "4. 重命名服务证书"mv ${CN}.key ${CN}.crt 复制以上代码另存为create_或者其他您喜欢的⽂件名。修改代码开头的CN(域名),如果需要使⽤ip去访问rancher server,那么需要给ssl证书添加扩展IP,多个IP⽤逗号隔开。如果想实现多个域名访问rancher server,则添加扩展域名(SSL_DNS),多个SSL_DNS⽤逗号隔开。
发布者:admin,转转请注明出处:http://www.yc00.com/xiaochengxu/1687804805a46530.html
评论列表(0条)