kubenetes安装

官网:https://github.com/kubernetes/kubernetes/blob/release-1.0/docs/getting-started- guides/centos/centos_manual_config.md



在两个主机上分别配置

vi /etc/hostname
echo "192.168.18.128 centos-master 192.168.18.130 centos-minion
" >> /etc/hosts

使得两个主机可以互ping

添加yum源

cd /etc/yum.repo.d
 vi virt7-testing.repo

 [virt7-testing]
name=virt7-testing baseurl=http://cbs.centos.org/repos/virt7- testing/x86_64/os/
gpgcheck=0

原来安装了docker1.8的先删除,没有安装的就不用执行下面这个步骤了



正式安装

Install Kubernetes on all hosts - centos-{master,minion}(所有的机器都安装)

yum -y install --enablerepo=virt7-testing kubernetes

master节点安装

master 节点安装 etcd package:

yum install http://cbs.centos.org/kojifiles/packages/etcd/0.4.6/7.el7.centos/x86_64/etcd-0.4.6-7.el7.centos.x86_64.rpm



关闭防火墙

systemctl disable iptables-services firewalld (firewalid是自定义的)

systemctl stop iptables-services firewalld

每个节点上修改kubernetes配置文件:

vi /etc/kubernetes/config

# How the controller-manager, scheduler, and proxy find the apiserver
KUBE_MASTER="--master=http://centos-master:8080" (centos-master是master节点的主机名,用来配置apiserver)
KUBE_ETCD_SERVERS="--etcd_servers=http://centos-master:4001"(配置etcd)

Master节点上 vi /etc/kubernetes/apiserver

# The address on the local server to listen to.
KUBE_API_ADDRESS="--address=0.0.0.0" KUBE_API_PORT="--port=8080"(配置apiserver)
# Comma separated list of nodes in the etcd cluster
#KUBE_ETCD_SERVERS="--etcd_servers=http://127.0.0.1:2379"(上面已经配置过了,这里不用管)

Master节点启动相关kubernetes服务:

for SERVICES in etcd kube-apiserver kube-controller- manager kube-scheduler; do
systemctl restart $SERVICES
systemctl enable $SERVICES
systemctl status $SERVICES
done

查看状态

for SERVICES in etcd kube-apiserver kube-controller- manager kube-scheduler; do
systemctl status $SERVICES done

Master节点启动相关kubernetes服务

查看启动的结果:

node节点安装

Node节点修改/etc/kubernetes/kubelet:

###
# kubernetes kubelet (minion) config
KUBELET_ADDRESS="--address=0.0.0.0" (绑定本地的端口)
KUBELET_PORT="--port=10250"(指定自己的端口绑定给本地的0000端口)
KUBELET_HOSTNAME="--hostname_override=centos-minion" (给master节点汇报自己节点的主机名)
KUBELET_API_SERVER="--api_servers=http://centos-master:8080“ (要访问的apiserver的地址)
# Add your own!
KUBELET_ARGS=""

node节点:

for SERVICES in kube-proxy kubelet docker; do
systemctl restart $SERVICES
systemctl enable $SERVICES
systemctl status $SERVICES
done
for SERVICES in kube-proxy kubelet docker; do
systemctl status $SERVICES
done



查看启动的日志

tail -f /var/log/messages |grep kube

查看是否安装成功

在master节点执行kubectl get nodes

查看到节点注册成功,则表明系统安装正常

[root@centos-master yum.repos.d]# kubectl get nodes
NAME LABELS STATUS centos-minion kubernetes.io/hostname=centos-minion Ready (ready表示成功)
[root@centos-master yum.repos.d]# kubectl cluster-info
 Kubernetes master is running at http://localhost:8080

kubernetes基本命令

Master上的kubectl命令为管理集群的命令

资源管理命令



kubectl describe --help

可以看到资源的信息属性等



kubernetes中的namespace不是为了隔离,而是为了配额,比如,某个namespace只能占用10%的cpu

实例

vi nginx-pod.yaml

apiVersion: v1
kind: Pod (资源类型)
metadata:
name: nginx
spec:
containers:
- name: nginx
image: nginx ports:
- containerPort: 80

可能会报错

//service account配置的问题,在之前的apiserver中的一个参数
[root@centos-master ~]# kubectl create -f nginx-pod.yaml Error from
server: error when creating "nginx-pod.yaml": Pod "nginx" is forbidden:
no API token found for service account default/default, retry after the
token is automatically created and added to the service account
参数在这里
KUBE_ADMISSION_CONTROL="-- admission_control=NamespaceLifecycle,NamespaceExists,LimitRanger
Secu,rityContextDeny,ServiceAccount,ResourceQuota"

查看状态

 [root@centos-master ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
nginx 0/1 Image: nginx is not ready on the node 0 56s

发现报错







解决:

进入:
/etc/sysconfig/docker
添加配置:
INSECURE_REGISTRY='--insecure-registry gcr.io'



查看状态



有可能会报错



原因:

因为当时是代理上网的,把代理的地址放进去就好了。

成功:



过段时间会自动从pending到running状态。

paus镜像是docker的根镜像。

Docker系列(十):Kubernetes集群入门的更多相关文章

  1. K8S从入门到放弃系列-(16)Kubernetes集群Prometheus-operator监控部署

    Prometheus Operator不同于Prometheus,Prometheus Operator是 CoreOS 开源的一套用于管理在 Kubernetes 集群上的 Prometheus 控 ...

  2. K8S从入门到放弃系列-(15)Kubernetes集群Ingress部署

    Ingress是kubernetes集群对外提供服务的一种方式.ingress部署相对比较简单,官方把相关资源配置文件,都已经集合到一个yml文件中(mandatory.yaml),镜像地址也修改为q ...

  3. K8S从入门到放弃系列-(9)kubernetes集群之kubelet部署

    摘要: Kubelet组件运行在Node节点上,维持运行中的Pods以及提供kuberntes运行时环境,主要完成以下使命: 1.监视分配给该Node节点的pods 2.挂载pod所需要的volume ...

  4. K8S从入门到放弃系列-(4)kubernetes集群之kubectl命令行工具部署

    摘要:随着版本的不断迭代,k8s为了集群安全,集群中趋向采用TLS+RBAC的安全配置方式,所以我们在部署过程中,所有组件都需要证书,并启用RBAC认证. 我们这里采用二进制安装,下载解压后,把对应组 ...

  5. K8S从入门到放弃系列-(13)Kubernetes集群mertics-server部署

    集群部署好后,如果我们想知道集群中每个节点及节点上的pod资源使用情况,命令行下可以直接使用kubectl top node/pod来查看资源使用情况,默认此命令不能正常使用,需要我们部署对应api资 ...

  6. K8S从入门到放弃系列-(14)Kubernetes集群Dashboard部署

    Dashboard是k8s的web界面,用户可以用 Kubernetes Dashboard 部署容器化的应用.监控应用.并对集群本身进行管理,在 Kubernetes Dashboard 中可以查看 ...

  7. K8S从入门到放弃系列-(12)Kubernetes集群Coredns部署

    摘要: 集群其他组件全部完成后我们应当部署集群 DNS 使 service 等能够正常解析,1.11版本coredns已经取代kube-dns成为集群默认dns. 1)下载yaml配置清单 [root ...

  8. K8S从入门到放弃系列-(11)kubernetes集群网络Calico部署

    摘要: 前面几个篇幅,已经介绍master与node节点集群组件部署,由于K8S本身不支持网络,当 node 全部启动后,由于网络组件(CNI)未安装会显示为 NotReady 状态,需要借助第三方网 ...

  9. K8S从入门到放弃系列-(10)kubernetes集群之kube-proxy部署

    摘要: kube-proxy的作用主要是负责service的实现,具体来说,就是实现了内部从pod到service和外部的从node port向service的访问 新版本目前 kube-proxy ...

随机推荐

  1. C#枚举转化示例大全,数字或字符串转枚举

    本文重点举例说明C#枚举的用法,数字转化为枚举.枚举转化为数字及其枚举数值的判断,以下是具体的示例: 先举两个简单的例子,然后再详细的举例说明: 字符串转换成枚举:DayOfWeek week=(Da ...

  2. Codeforces 479【D】div3

    题目链接:http://codeforces.com/problemset/problem/977/D 题意:给你一个数字序列,定了一个游戏规则.你可以对当前数字进行两个操作 1./ 3  如果这个数 ...

  3. sparkStreaming结合SparkSql实例

    SparkSQL结合SparkStreaming的使用 Flume+Kafka+SparkStreaming已经发展为一个比较成熟的实时日志收集与计算架构,利用Kafka,即可以支持将用于离线分析的数 ...

  4. centos7使用iptables作为防火墙方法

    centos7使用iptables作为防火墙方法查看firewalld状态: systemctl status firewalld将centos7默认的firewalld停止,并将iptables作为 ...

  5. web项目中使用的协议

    DNS协议 1.DNS协议的作用是将域名解析为IP,网络上的每个站点的位置是用IP来确定的,访问一个网站首先就要知道它的IP,不过数据组成的IP记起来不方便,所以就使用域名来代替IP,由于IP和域名的 ...

  6. SHELL脚本中执行SQL语句操作MYSQL的5种方法

    对于自动化运维,诸如备份恢复之类的,DBA经常需要将SQL语句封装到shell脚本.本文描述了在Linux环境下mysql数据库中,shell脚本下调用sql语句的几种方法,供大家参考.对于脚本输出的 ...

  7. Python自学:第四章 在for循环中执行更多操作(2)

    # -*- coding: GBK -*- magicians = ['alice', 'david', 'carolina'] for magician in magicians: print(ma ...

  8. VS 解决方案 Xamarin 配置

    需要额外安装 Mono 程序 工具->Xamarin->Android -> SDK路径  要和 你配置的ANDROID_SDK_ROOT 的路径一至如果没有 ANDROID_SDK ...

  9. 「STL」bitset正传

    前言 之前一些需要转二进制来解决的题目我看到很多大佬用了bitset. 然而我并不会这东西.看上去很高级的样子…… 改题改累了来学习一下233. 正文 一.bitset的构造 bitset有三种构造方 ...

  10. (转)JNI入门教程之HelloWorld篇 .

    转: http://blog.csdn.net/mingjava/article/details/180946 本文讲述如何使用JNI技术实现HelloWorld,目的是让读者熟悉JNI的机制并编写第 ...