虚拟机部署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)的更多相关文章

  1. k8s dockerk个人学习(2)

    部署nginx和应用 部署nginx时我们需要把nginx的配置文件那出来便于以后修改nginx的配置,放置nginx配置文件时我们用k8s的pv的存储方式来存放这些文件 1.安装nfs服务,在kub ...

  2. dockerk个人学习(0)

    接下来几篇记录学习docker和ks的部署搭建环境和应用部署等

  3. k8s的chart学习(下)

    1.开发自己的chart Kubernetes 给我们提供了大量官方 chart,不过要部署微服务应用,还是需要开发自己的 chart,下面就来实践这个主题. 1.1创建 chart 执行 helm ...

  4. k8s的chart学习(上)

    chart 是 Helm 的应用打包格式.chart 由一系列文件组成,这些文件描述了 Kubernetes 部署应用时所需要的资源,比如 Service.Deployment.PersistentV ...

  5. Android开发学习4

    学习内容: 1.RecyclerView 2.WebView

  6. k8s的网络学习

    1.Kubernetes 网络模型 Kubernetes 采用的是基于扁平地址空间的网络模型,集群中的每个 Pod 都有自己的 IP 地址,Pod 之间不需要配置 NAT 就能直接通信.另外,同一个 ...

  7. K8s & Openshift案例学习

    1. openshift排错技巧:https://mp.weixin.qq.com/s?__biz=MzAwMDc2NjQ4Nw==&mid=2663494178&idx=1& ...

  8. .NET Core on K8S快速入门课程学习笔记

    课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 目录 01-介绍K8s是什么 02-为什么要学习k8s 03-如何学习k8s ...

  9. k8s学习

    k8s简介 在学习k8s之前,相信大家和我一样,肯定都学习和使用过docker容器,并且对容器技术有了一个基本的认识.引用张磊老师的总结:其实一个"容器",实际上是一个由Linux ...

随机推荐

  1. Java 包的概述和讲解

    2017-11-02 22:58:45 包(package):其实就是文件夹. 包的作用是对类进行分类的管理,并且区分不同的类名. 举例: 学生:增加,删除,修改,查询 教师:增加,删除,修改,查询 ...

  2. spring boot 2.0+ 错误页面配置

    如果访问了错误的路径,或者后台报错 如果没有一个统一的页面! 或者说页面上展示一堆报错信息,既影响美观,又对用户不友好! 那么如何配置? 定义 ErrorPageConfig,配置错误状态与对应访问路 ...

  3. 测序中Q20 Q30 Q40

    你能给别人讲清楚这个概念吗? 二代测序中,每测一个碱基会给出一个相应的质量值,这个质量值是衡量测序准确度的.碱基的质量值13,错误率为5%,20的错误率为1%,30的错误率为0.1%.行业中Q20与Q ...

  4. English trip V1 - 辅导课 VOCABULARY BRUSH UP(1-6) 词汇刷新 SA:Winona

    1.How Do you Feel Now?            形容词  adj.  = adjective                     Describe people and thi ...

  5. 12月3日周日,关联:has_many(dependent::delete_all和destroy的区别) 注意看log; where等查询语句的用法。 layout传递参数❌

    错误❌: 1.belongs_to :job, dependent: :destroy //尝试删除一条resumen后,job没有同步删除?? 答:建立一对多的关系,如job和resume.应该在j ...

  6. layui图片显示

    有些东西看文档可以实现,但当真不如自己写的实在.所以还是记录下来吧. 1. 图片赋值 <div id="layer-photos-demo" class="laye ...

  7. hdu多校2C

    题意:找多条路径覆盖所有的边,求最小路径数,要求输出路径 题解:新建一个点n+1,所有奇点向它连边,然后跑欧拉回路,最后把新加的边删去,一段连续的边就是一条路径 = =但是由于太久没写欧拉回路以及之前 ...

  8. 绝对干货!!css3字体图标—丰富的阿里图标库iconfont的使用详解

    在移动端Web项目开发中,我们往往需要用到一些小图标,比如搜索,返回,小菜单,小箭头等等..这如果还用切图你就OUT了.. 而这时CSS3提供的字体图标无疑是我们最好的选择,它就像字体一样,可以设置大 ...

  9. python-day4笔记

    1.文件后缀名对python运行没关系 2.Python解释器执行python程序的过程:python3 C:\test.py 1)启动python解释器(内存中) 2)将C:\test.py内容从硬 ...

  10. Oracle数据库的“健康指示器”——事件(events)

    Oracle数据库“赢在”在架构,这话还是有道理的,除了锁(lock)这个最大的架构上的“赢点”之外,Oracle事件(event)也是另外一个很重要的架构上的“赢点”,因为当今的Oracle数据库, ...