k8s dockerk个人学习(1)
虚拟机部署k8s
1. 创建虚拟机
虚拟机用的是virtualBox和vagrant工具,百度安装virtualBox和vagrant
创建vagrant目录并创建文件Vagrantfile内容为
Vagrant.configure("2") do |config|
config.vm.box = "ubuntu/bionic64"
config.vm.box_check_update = false
config.vm.provider "virtualbox"
#config.vm.network "public_network" $num_vms = 3
(1..$num_vms).each do |id|
config.vm.define "kube-node#{id+1}" do |node|
node.vm.hostname = "kube-node#{id+1}"
node.vm.network :private_network, ip: "10.64.4.#{id+1}", auto_config: true
config.vm.network "forwarded_port", guest: 8080, host: 8080, auto_correct: true # kube-apiserver
config.vm.network "forwarded_port", guest: 8086, host: 8086, auto_correct: true # kubectl proxy
config.vm.network "forwarded_port", guest: 443, host: 4443, auto_correct: true # harbor
node.vm.provider :virtualbox do |vb, override|
vb.name = "kube-node#{id+1}"
vb.gui = false
vb.memory = 2048
vb.cpus = 1
end
end
end
end
a.进入vagrant目录下运行命令vagrant up创建虚拟机,这时会创建3台虚拟机分别是kube-node2,kube-node3,kube-node4
b.设置kube-node2的cpu数为2(安装k8s时需要),在virtualBox管理器中可以设置
2.配置虚拟机环境
a.进入虚拟机运行命令vagrant ssh kube-node2
b.设置root的登录密码输入命令sudo passwd root 之后输入2次设置的密码
c.设置允许远程登录修改/etc/ssh/sshd_config文件,执行命令/etc/ssh/sshd_config修改内容
PasswordAuthentication yes
UsePAM no
PermitRootLogin yes
RSAAuthentication yes
PubkeyAuthentication yes
sshd_config文件中没有就添加上有就修改为上述保存退出后,运行命令sudo service sshd restart,其他2台虚拟机同样执行
d.修改机器的hostname,hostname -i
返回可路由的IP地址(这是为了解决k8s中Flanne网络中pod无法互访)
sudo vim /etc/hosts
将最后一行 127.0.1.1 kube-node2 kube-node2
修改为10.64.4.2 kube-node2 kube-node2
其他2台机器也改成ip对应的值
3.安装docker
用root进入,并每台机器上执行
sudo apt-get update && apt-get install docker.io 命令安装doucker
4.安装k8s等工具
用root进入,并每台机器上执行
a. sudo apt-get update && apt-get install -y apt-transport-https
b. curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add # 添加key
c. 在/etc/apt/sources.list.d/kubernetes.list文件中添加deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
d. apt-get update # 更新
e. apt-get install -y kubelet kubeadm kubectl #安装
5.初始化 master
用root进入kube-root2中执行
kubeadm init --apiserver-advertise-address 10.64.4.2 --pod-network-cidr=10.244.0.0/16
执行完可能会报ERROR ImagePull 可能是墙外镜像下不下来需要翻墙,我们可以用阿里云免费获取镜像.
免费获取墙外镜像 https://blog.csdn.net/yjf147369/article/details/80290881
6. 配置 kubectl
切换到普通用户vagrant下, 执行
su vagrant
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
echo "source <(kubectl completion bash)" >> ~/.bashrc
7.安装pod网络,在root用户下执行
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
8.添加k8s-node3和k8s-node4
在5步骤成功后会有 kubeadm join 10.64.4.2:6443 --token token --discovery-token-ca-cert-hash sha256: 替换相应的值在其他2个节点执行
k8s dockerk个人学习(1)的更多相关文章
- k8s dockerk个人学习(2)
部署nginx和应用 部署nginx时我们需要把nginx的配置文件那出来便于以后修改nginx的配置,放置nginx配置文件时我们用k8s的pv的存储方式来存放这些文件 1.安装nfs服务,在kub ...
- dockerk个人学习(0)
接下来几篇记录学习docker和ks的部署搭建环境和应用部署等
- k8s的chart学习(下)
1.开发自己的chart Kubernetes 给我们提供了大量官方 chart,不过要部署微服务应用,还是需要开发自己的 chart,下面就来实践这个主题. 1.1创建 chart 执行 helm ...
- k8s的chart学习(上)
chart 是 Helm 的应用打包格式.chart 由一系列文件组成,这些文件描述了 Kubernetes 部署应用时所需要的资源,比如 Service.Deployment.PersistentV ...
- Android开发学习4
学习内容: 1.RecyclerView 2.WebView
- k8s的网络学习
1.Kubernetes 网络模型 Kubernetes 采用的是基于扁平地址空间的网络模型,集群中的每个 Pod 都有自己的 IP 地址,Pod 之间不需要配置 NAT 就能直接通信.另外,同一个 ...
- K8s & Openshift案例学习
1. openshift排错技巧:https://mp.weixin.qq.com/s?__biz=MzAwMDc2NjQ4Nw==&mid=2663494178&idx=1& ...
- .NET Core on K8S快速入门课程学习笔记
课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 目录 01-介绍K8s是什么 02-为什么要学习k8s 03-如何学习k8s ...
- k8s学习
k8s简介 在学习k8s之前,相信大家和我一样,肯定都学习和使用过docker容器,并且对容器技术有了一个基本的认识.引用张磊老师的总结:其实一个"容器",实际上是一个由Linux ...
随机推荐
- 【异常】redis.clients.jedis.exceptions.JedisDataException: ERR unknown command 'PSETEX'
在spring中 针对 RedisTemplate类: private RedisTemplate<String, String> template; 当调用下面方法 template.o ...
- P2048 [NOI2010]超级钢琴 (RMQ,堆)
大意: 给定n元素序列a, 定义一个区间的权值为区间内所有元素和, 求前k大的长度在[L,R]范围内的区间的权值和. 固定右端点, 转为查询左端点最小的前缀和, 可以用RMQ O(1)查询. 要求的是 ...
- hdu1864(01包)
最大报销额 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- HDU-3480 Division (四边形不等式优化DP)
题目大意:将n个数分成m组,将每组的最大值与最小值的平方差加起来,求最小和. 题目分析:先对数排序.定义状态dp(i,j)表示前 j 个数分成 i 组得到的最小和,则状态转移方程为dp(i,j)=mi ...
- ASP.NET网页生命周期事件
网页事件 典型的使用方式 PreInit PreInit事件是网页生命周期中非常早起的一个事件,在PreInit事件触发之后,就会加载用户设置信息与网页主题.我们通常使用PreInit事件来执行下列处 ...
- OC 类对象和类加载
//------------------------Persion类----------------------------// 1 #import "Person.h" @imp ...
- HashMap知识点、问题
转载:https://blog.csdn.net/qq_27007251/article/details/71403647 https://www.cnblogs.com/kxdblog/p/4323 ...
- memory prefix hypo,hecto,hyper out1
1● hypo 次等 2● hecto 许多,百 3● hyper 超过,许多
- ural1469
题解: 从左往右加入每一个点 判断一下和,pre,nxt是否相交 删除得时候也要判断 代码: #pragma GCC optimize(2) #include<cstdio> #inclu ...
- POJ 2242 The Circumference of the Circle
做题回顾:用到海伦公式,还有注意数据类型,最好统一 p=(a+b+c)/2; s=sqrt(p*(p-a)*(p-b)*(p-c));//三角形面积,海伦公式 r=a*b*c/(4*s);//这是外接 ...