## 一、实践环境准备
#### 1、服务器说明
部署采用三主两从高可用部署方案
| 系统类型 | IP地址 | 节点角色 | CPU | Memory | hostname |
| --- | --- | --- | --- | --- | --- |
| centos-7.6 | 172.16.3.62 | master | \>=2 | \>=2G | master1 |
| centos-7.6 | 172.16.3.63 | master | \>=2 | \>=2G | master2 |
| centos-7.6 | 172.16.3.64 | master | \>=2 | \>=2G | master3 |
| centos-7.6 | 172.16.3.65 | master | \>=2 | \>=2G | worker1 |
| centos-7.6 | 172.16.3.66 | master | \>=2 | \>=2G | worker2 |
#### 2、系统设置(所有节点)
##### 2.1 主机名设置
主机名必须每个节点都不一样,并且保证所有点之间可以通过hostname互相访问。
~~~
# 查看主机名
$ hostname
# 修改主机名
$ hostnamectl set-hostname <your_hostname>
# 配置host,使主节点之间可以通过hostname互相访问
$ vi /etc/hosts
# <node-ip> <node-hostname>
172.16.3.62 master1
172.16.3.63 master2
172.16.3.64 master3
172.16.3.65 worker1
172.16.3.66 worker1
~~~
##### 2.2安装依赖包
~~~
# 更新yum
$ yum update
# 安装依赖包
$ yum install -y conntrack ipvsadm ipset jq sysstat curl iptables libseccomp
~~~
##### 2.3关闭防火墙、swap,重置iptables
~~~
# 关闭防火墙
$ systemctl stop firewalld && systemctl disable firewalld
# 重置iptables
$ iptables -F && iptables -X && iptables -F -t nat && iptables -X -t nat && iptables -P FORWARD ACCEPT
# 关闭swap
$ swapoff -a
$ sed -i '/swap/s/^\(.*\)$/#\1/g' /etc/fstab
# 关闭selinux
$ setenforce 0
# 关闭dnsmasq(否则可能导致docker容器无法解析域名)
$ service dnsmasq stop && systemctl disable dnsmasq
~~~
2.4系统参数设置
~~~
# 制作配置文件
$ cat > /etc/sysctl.d/kubernetes.conf <<EOF
net.bridge.bridge-nf-call-iptables=1
net.bridge.bridge-nf-call-ip6tables=1
net.ipv4.ip_forward=1
vm.swappiness=0
vm.overcommit_memory=1
vm.panic_on_oom=0
fs.inotify.max_user_watches=89100
EOF
# 生效文件
$ sysctl -p /etc/sysctl.d/kubernetes.conf
~~~
#### 3、安装docker(所有节点)
~~~
#使用yum安装
yum install -y docker
#设置开机启动
systemctl start docker
systemctl enable docker
#更改挂载分区,选择较大的目录
mkdir -p /mnt/docker-data
cat <<EOF > /etc/docker/daemon.json
{
"graph": "/mnt/docker-data"
}
EOF
#重启docker服务
service docker restart
~~~
#### 4、准备二进制文件
##### 4.1配置免密登录
选择一个节点作为中转节点,配置使其可以免密登录其他节点,方便用于分发文件。
~~~
# 看看是否已经存在rsa公钥
$ cat ~/.ssh/id_rsa.pub
# 如果不存在就创建一个新的
$ ssh-keygen -t rsa
# 把id_rsa.pub文件内容copy到其他机器的授权文件中
$ cat ~/.ssh/id_rsa.pub
# 在其他节点执行下面命令(包括worker节点)
$ echo "<file_content>" >> ~/.ssh/authorized_keys
~~~
##### 4.2下载二进制文件
官方下载地址(在CHANGELOG链接里面): [https://github.com/kubernetes/kubernetes/releases](https://github.com/kubernetes/kubernetes/releases)
网盘下载地址–推荐(我从官网下载整理好的文件):
链接: [https://pan.baidu.com/s/1\_w9vyQaDGLKDOf\_TU2Xu8Q](https://pan.baidu.com/s/1_w9vyQaDGLKDOf_TU2Xu8Q) 提取码: vca8
##### 4.3分发文件并设置好PATH
~~~
# 把文件copy到每个节点上(注意替换自己的文件目录)
$ ssh <user>@<node-ip> "mkdir -p /opt/kubernetes/bin"
$ scp master/* <user>@<master-ip>:/opt/kubernetes/bin/
$ scp worker/* <user>@<worker-ip>:/opt/kubernetes/bin/
# 给每个节点设置PATH
$ ssh <user>@<node-ip> "echo 'PATH=/opt/kubernetes/bin:$PATH' >>~/.bashrc"
# 给自己设置path,后面会用到kubectl命令
$ vi ~/.bash_profile
~~~
#### 5、准备配置文件(中转节点)
- Linux
- linux常用命令
- awk
- cp
- scp
- mv
- screen工具
- rsync
- Linux设置静态IP
- vim常用
- ssh免密登录
- linux挂载磁盘和开机自动挂载
- 文件的时间戳
- 重定向
- 防火墙
- Vultr 服务器利用快照更换IP
- ss
- node-yarn
- ES安装向导
- lnmp/lamp
- windows安装mysql
- windows安装nginx
- Let'sEncrypt 免费通配符/泛域名SSL证书
- 开机自动挂载硬盘
- 普通用户提权
- ELK日志分析系统
- Docker
- docker
- centos7安装docker
- Centos7安装redis
- CentOS 7 使用Docker搭建Nginx
- CentOS 7 使用Docker搭建Jenkins
- CentOS 7 使用Docker搭建Zookeeper
- CentOS 7 使用Docker搭建Tomcat
- CentOS 7 使用Docker搭建Mysql
- CentOS 7 使用Docker搭建PHP环境
- 使用docker搭建Swagger
- docker阿里云私有仓库
- docker zookeeper集群
- docker部署ES
- docker之java容器运行外置springboot-jar
- docker部署owncloud云盘
- ETCD
- centos7部署etcd节点
- Dockerfile
- Docker-compose
- gitlab.yml
- db.yml
- 安装docker-compose
- gitlab-docker-compose.yml
- nginx-docker-compose.yml
- Mysql
- mysql开启远程访问及相关权限控制
- mysql授权
- mysql快速导出导入大数据
- mysql单机备份
- binlog日志
- shell
- 经典案例
- 俄罗斯方块游戏
- 系统初始化
- 服务器监控
- go基础环境
- shell.监控日志.elk
- shell.检查各服务脚本
- shell.删除文件脚本
- shell.守护进程
- shell.数据库
- shell.Ansible
- shell.dev
- shell.ftp环境
- shell.docker环境
- shell.k8s环境
- k8s.二进制安装
- K8s.一主多从
- k8s.三主两从高可用
- k8s.检查服务与配置
- k8s.jenkins
- k8s.gitlab
- go-install.sh
- jenkins-install.sh
- node-install.sh
- redis-install.sh
- zabbix-install.sh
- zabbix-dockerfile.sh
- nginx-install.sh
- shell变量
- 用户自定义变量
- 环境变量
- shell特殊变量
- shell条件判断
- 流程控制
- shell运算符
- Shell _printf
- shell_test
- shell函数
- 输出重定向
- 网络相关
- 安全相关
- 堡垒机部署
- 区块链威胁情报共享平台
- 签名与验签
- 浅谈区块链
- 智能合约
- 黄金币GTF智能合约
- 节点
- 以太坊公链私链geth同步
- 比特节点同步
- BTC节点错误解决方法
- eth硬分叉
- omni钱包节点搭建
- 架构
- K8s
- 搭建k8s集群完整篇
- 二进制部署k8s
- Devops
- git
- Jenkins
- svn
- 禅道
- CI/CD
- docker+jenkins+golang持续集成持续交付(CI/CD)
- 项目部署
- config.env
- docker-compose.yml
- Dockerfile模板
- .dockerignore
- run.sh
- nginx.conf模板
- 跨域
- jenkins配置
- 测试
- Python