在CentOS7上安装新版本Git(2.x)
centos7 的默认源里面的git版本是1.8.3, 比较老了, 对于有些操作会提示git版本太低, 可以使用第三方源的方式来安装新版本的git
使用Wandisco源创建仓库文件
12345678cat > /etc/yum.repos.d/wandisco-git.repo <<-'EOF'[wandisco-git]name=Wandisco GIT Repositorybaseurl=http://opensource.wandisco.com/centos/7/git/$basearch/enabled=1gpgcheck=1gpgkey=http://opensource.wandisco.com/RPM-GPG-KEY-WANdiscoEOF
安装git1sudo yum install git
查看版本1git version
离线安装(手动安装rpm)下载两个文件到本地
12wget https://file.babudiu.com/f/Njsj/perl-Git-2.31.1-1.WANdisco.165709600 ...
Nginx配置双向认证
单项认证只需要服务器提供证书即可, 不验证客户端证书, 而双向认证需要验证服务器证书,也需要验证客户端证书, 不满足要求的客户端可以不允许其访问, 并且可以通过后期吊销证书的方式禁止其访问.
证书签名可以参考:
使用certbot自动申请ssl证书
使用acme.sh来自动更新https证书
制作和使用自签名证书
本文提到的 client.crt server.crt 都是通过ca签发的
服务器配置Nginx配置:
1234567891011121314151617server { listen 443 ssl; server_name localhost; ssl_certificate ssl/server.crt; # 配置证书位置 ssl_certificate_key ssl/server.key; # 配置私钥位置 ssl_client_certificate ssl/ca.crt; # 客户端证书 ssl_verify_c ...
制作和使用自签名证书
在很多使用到证书的场景, 比如HTTPS, 可以选择去申请一个免费的证书, 也可以尝试自签名证书, 申请免费证书请看:使用certbot自动申请ssl证书或者使用acme.sh来自动更新https证书, 本文介绍自签名证书.
SSL协议加密方式SSL协议即用到了对称加密也用到了非对称加密(公钥加密),在建立传输链路时,SSL首先对对称加密的密钥使用公钥进行非对称加密,链路建立好之后,SSL对传输内容使用对称加密。
对称加密 速度高,可加密内容较大,用来加密会话过程中的消息。
公钥加密 加密速度较慢,但能提供更好的身份认证技术,用来加密对称加密的密钥。
CA 证书生成 CA 私钥1openssl genrsa -out ca.key 4096
生成一个 ca.key 文件
生成 CA 证书交互式创建非交互式创建1openssl req -utf8 -new -x509 -days 3650 -key ca.key -out ca.crt
需要交互式输入:
提示
含义
输入内容
Country Name
国家
CN
State or Province Nam ...
Nginx设置图片防盗链
常见的使用Nginx进行防盗链配置是利用了referer, 也就是来源地址来判断, 只要不是白名单中的地址, 就禁止访问, referer是比较有效的方式, 但是可以轻松绕过, 目的是为了防止页面被别人复制粘贴我们的文章, 图片等资源依然使用我们的连接, 占用带宽或流量造成费用.
白名单模式这种模式就是在白名单之外的所有域名都不能请求我们的图片等资源
配置示例:
1234567891011121314151617181920212223242526# 资源防盗链(指定目录or指定文件类型) location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { # location /upload/ { access_log off; # none:表示没有 referer 的可以访问 # blocked:表示 referer 没有值的可以访问 # server_names:表示 Nginx 的 server_name 可以访问 # ~.*google\.:google 前后都是正则匹配, ~表示后面的是正则匹配 ...
Kubernetes回滚应用之kubectl rollout
kubernetes 每次更新资源会记录资源的历史版本, 方便我们进行回滚操作。真的k8s解决了很多运维的痛点问题, 想起来以前没有用k8s的时候,用jenkins和ansible来做的发布和回滚…
查看历史版本12345678kubectl rollout history deployment nfs-client-provisionerdeployment.apps/nfs-client-provisionerREVISION CHANGE-CAUSE1 <none>2 <none>4 <none>5 <none>
这里列出的就是版本, 为什么没有3, 因为从版本4回滚到了版本3, 则版本3就变成了版本5
查看指定版本详情1kubectl rollout history deployment nfs-client-provisioner --revision=4
也可以以yaml格式输出
1kubectl rollout history deployment n ...
Kubeadm之单节点master升级高可用master
单节点升级master总体来说就是两步, 先修改apiserver地址为负载均衡地址,然后添加新的master节点。
搭建集群的时候我们注意一下就可以减少后期维护的烦恼,比如:
使用hostname而不是ip来作为kube-apiserver地址
单节点也把负载均衡安排上
假设已经有一个没有负载均衡的单节点master,现在想将它切换为高可用集群,记录以下步骤:
部署负载均衡参考部署负载均衡
更新证书
因为我们部署了负载均衡,所以需要通过负载均衡的地址来访问apiserver,因为证书是针对域名或者ip做的签名,如果ip变了证书就失效了,这也是为什么建议使用hostname来代替ip
如果你是用kubeadm init 来创建的集群,那么你需要导出一个kubeadm配置
1kubectl -n kube-system get configmap kubeadm-config -o jsonpath='{.data.ClusterConfiguration}' > kubeadm.yaml
添加证书SANs信息123456789101 ...
使用kubeasz搭建一套高可用的Kubernetes集群
kubeasz 是基于ansible和shell制作的工具,可以快速搭建一个高可用的k8s集群(二进制部署),不需要额外的负载均衡。项目地址:https://github.com/easzlab/kubeasz, kubeasz 每个版本对应了支持的k8s版本, 可以到项目主页查看, 这里使用 kubeasz版本3.0.0, 部署k8s 1.18.2
另见kubeadm部署在centos使用kubeadm部署k8s在ubuntu使用kubeadm部署k8s
安装准备准备机器如下:
机器
IP
kubeasz操作机
10.0.0.7
master1
10.0.0.31
master2
10.0.0.32
master3
10.0.0.33
worker1
10.0.0.41
首先确保操作机可以通过ssh连接到其他所有机器,最好密钥打通(这是使用ansible的必要条件)
安装kubeasz安装ansible12yum install epel-release -yyum install ansible -y
下载ezdown部署工具123export ...
使用kubeadm部署一套高可用k8s集群 for CentOS
基于centos使用kubeadm搭建集群, ubuntu部署文档, 有疑问的地方可以看官方文档
准备机器
我的机器详情如下, 配置至少为4C4G
hostname
IP
作用
public
10.0.0.3
ingress和apiserver的负载均衡,nfs存储
master1
10.0.0.11
k8s master节点
master2
10.0.0.12
k8s master节点
master3
10.0.0.13
k8s master节点
worker1
10.0.0.21
k8s worker节点
worker2
10.0.0.22
k8s worker节点
每台机器都做域名解析,或者绑定hosts(可选但建议)
123456vim /etc/hosts10.0.0.3 public kube-apiserver10.0.0.11 master110.0.0.12 master210.0.0.13 master3
每台机器都关闭防火墙和SELinux
负载均衡机器必须要关闭,因为6443不是nginx的标准端口,会被selin ...
配置树莓派关机时正常停转移动硬盘
将闲置的树莓派做个共享服务器,在家里面存一些文件用。将树莓派和移动硬盘盒都已经改装好了,固定在了一起,用一块12864来显示一些信息,比如磁盘空间占用等。
树莓派3B+的千兆网口和usb接口相当于是一个usb2.0 hub分出来的, 速度根本达不到千兆,还抢占usb的带宽。实测速度20M/s左右(硬盘速度能跑到100M/s)
遇到的问题每次关机或者重启的时候,都会遇到硬盘吱~的一声,这种情况是操作系统关机的时候没有通知硬盘磁头归位直接断电, 这样硬盘会自己将磁头归位,就会有声音。时间久了对机械硬盘是一种损伤。
参考http://www.linux-ata.org/shutdown.html
解决方案查找硬盘启停配置在linux系统里面,一切皆文件,硬盘的各种信息也不列外。我们可以到/sys/class/scsi_disk/找自己的硬盘,可以通过查看硬盘的型号来确定
1cat /sys/class/scsi_disk/0:0:0:0/device/model
文件manage_start_stop就是配置磁头归位的,只需要将此文件内容设置成1即可。需要每次开机后都 ...
Kubernetes集群调度之节点亲和性、Pod亲和性、污点与容忍
调度器Scheduler 是 Kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上。听起来非常简单,但有很多要考虑的问题:
公平:如何保证每个节点都能被分配资源
资源高效利用:集群所有资源最大化被使用
效率:调度的性能要好,能够尽快地对大批量的 pod 完成调度工作
灵活:允许用户根据自己的需求控制调度的逻辑k
Scheduler 是作为单独的程序运行的,启动之后会一直监听 API Server,获取PodSpec.NodeName为空的 pod,对每个 pod 都会创建一个 binding(必须遵守的),表明该 pod 应该放到哪个节点上
调度过程调度分为几个步骤:
首先是过滤掉不满足条件的节点,这个过程称为predicate(预选);
然后对通过的节点按照优先级排序,这个是priority(优选);
最后从中选择优先级最高的节点。
Predicate(预选)有一系列的算法可以使用:
算法
说明
PodFitsResources
节点上剩余的资源是否大于 pod 请求的资源
PodFitsHost
如果 pod 指定了 NodeNa ...