centos7 安装Kubernetes 1.7.1

配置环境说明

  • 主服务器

腾讯云,广州二区,1核1G,centos7.3 64bit

  • 节点服务器

腾讯云,广州二区,1核1G,centos7.3 64bit

主服务器安装配置

关闭防火墙

systemctl stop firewalld.service 
systemctl disable firewalld.service

关闭selinux

setenforce 0

# 修改/etc/selinux/config文件的SELINUX=XXX
vi /etc/selinux/config
SELINUX=disabled

安装docker

yum install epel-release -y
yum install -y docker

安装k8s

# 添加一个k8s软件源
vim /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0

yum install -y kubectl kubelet kubeadm

修改k8s配置文件

vim /etc/systemd/system/kubelet.service.d/10-kubeadm.conf

原内容:
Environment="KUBELET_KUBECONFIG_ARGS=--kubeconfig=/etc/kubernetes/kubelet.conf --require-kubeconfig=true"

修改后内容
Environment="KUBELET_KUBECONFIG_ARGS=--kubeconfig=/etc/kubernetes/kubelet.conf --require-kubeconfig=true --cgroup-driver=systemd"

修改主机名,主机名不能有_之类特殊字符

hostnamectl --static set-hostname master

启动docker

service docker start

初始化k8s集群

kubeadm init --kubernetes-version=v1.7.1 --pod-network-cidr=192.168.0.0/16 --apiserver-advertise-address=0.0.0.0

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

注意保留加入集群命令,上面初始化输出的:

# 初始化输出的
kubeadm join --token b6c727.96eca5ce6ff26bb6 10.135.10.97:6443

安装一些必要的服务

kubectl apply -f http://docs.projectcalico.org/v2.4/getting-started/kubernetes/installation/hosted/kubeadm/1.6/calico.yaml

kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

注意,可以提前安装好镜像,我已经同步一些镜像到腾讯云了

docker pull ccr.ccs.tencentyun.com/kubenetes/kube-controller-manager-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kube-controller-manager-amd64:v1.7.1 gcr.io/google_containers/kube-controller-manager-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/kubenetes/etcd-amd64:3.0.17
docker tag ccr.ccs.tencentyun.com/kubenetes/etcd-amd64:3.0.17 gcr.io/google_containers/etcd-amd64:3.0.17

docker pull ccr.ccs.tencentyun.com/kubenetes/kube-scheduler-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kube-scheduler-amd64:v1.7.1 gcr.io/google_containers/kube-scheduler-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/kubenetes/kube-apiserver-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kube-apiserver-amd64:v1.7.1 gcr.io/google_containers/kube-apiserver-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/kubenetes/pause-amd64:3.0
docker tag ccr.ccs.tencentyun.com/kubenetes/pause-amd64:3.0 gcr.io/google_containers/pause-amd64:3.0

docker pull ccr.ccs.tencentyun.com/kubenetes/kube-proxy-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kube-proxy-amd64:v1.7.1 gcr.io/google_containers/kube-proxy-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/kubenetes/k8s-dns-kube-dns-amd64:1.14.4
docker tag ccr.ccs.tencentyun.com/kubenetes/k8s-dns-kube-dns-amd64:1.14.4 gcr.io/google_containers/k8s-dns-kube-dns-amd64:1.14.4

docker pull ccr.ccs.tencentyun.com/kubenetes/k8s-dns-dnsmasq-nanny-amd64:1.14.4
docker tag ccr.ccs.tencentyun.com/kubenetes/k8s-dns-dnsmasq-nanny-amd64:1.14.4 gcr.io/google_containers/k8s-dns-dnsmasq-nanny-amd64:1.14.4

docker pull ccr.ccs.tencentyun.com/kubenetes/k8s-dns-sidecar-amd64:1.14.4
docker tag ccr.ccs.tencentyun.com/kubenetes/k8s-dns-sidecar-amd64:1.14.4 gcr.io/google_containers/k8s-dns-sidecar-amd64:1.14.4

docker pull ccr.ccs.tencentyun.com/calico/node:v2.4.1
docker tag ccr.ccs.tencentyun.com/calico/node:v2.4.1 quay.io/calico/node:v2.4.1

docker pull ccr.ccs.tencentyun.com/calico/cni:v1.10.0
docker tag ccr.ccs.tencentyun.com/calico/cni:v1.10.0 quay.io/calico/cni:v1.10.0

docker pull ccr.ccs.tencentyun.com/calico/kube-policy-controller:v0.7.0
docker tag ccr.ccs.tencentyun.com/calico/kube-policy-controller:v0.7.0 quay.io/calico/kube-policy-controller:v0.7.0

docker pull ccr.ccs.tencentyun.com/calico/etcd:v3.1.10
docker tag ccr.ccs.tencentyun.com/calico/etcd:v3.1.10 quay.io/calico/etcd:v3.1.10

docker pull ccr.ccs.tencentyun.com/kubenetes/kubernetes-dashboard-init-amd64:v1.0.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kubernetes-dashboard-init-amd64:v1.0.1 gcr.io/google_containers/kubernetes-dashboard-init-amd64:v1.0.1

docker pull ccr.ccs.tencentyun.com/kubenetes/kubernetes-dashboard-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kubernetes-dashboard-amd64:v1.7.1 gcr.io/google_containers/kubernetes-dashboard-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-grafana-amd64:v4.4.3
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-grafana-amd64:v4.4.3 gcr.io/google_containers/heapster-grafana-amd64:v4.4.3

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-amd64:v1.4.0
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-amd64:v1.4.0 gcr.io/google_containers/heapster-amd64:v1.4.0

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-influxdb-amd64:v1.3.3
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-influxdb-amd64:v1.3.3 gcr.io/google_containers/heapster-influxdb-amd64:v1.3.3


docker pull ccr.ccs.tencentyun.com/coreos/flannel:v0.9.0-amd64
docker tag ccr.ccs.tencentyun.com/coreos/flannel:v0.9.0-amd64 quay.io/coreos/flannel:v0.9.0-amd64

安装面板(kubernetes-dashboard)

在主服务器下载一个文件,https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashboard.yaml

但是注意,我们为了面板可以在公网访问,需要修改一下这个文件,暴露出一个公网IP。

原来的部分代码

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kube-system
spec:
  ports:
    - port: 443
      targetPort: 8443
  selector:
    k8s-app: kubernetes-dashboard

修改后部分代码(30000是暴露的端口)

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kube-system
spec:
  ports:
    - port: 443
      targetPort: 8443
      nodePort: 30000
  type: NodePort
  selector:
    k8s-app: kubernetes-dashboard

然后我们直接通过访问https://{服务器ip}:30000的时候需要我们登录,我唯一成功实践过就是使用token登录,看了很多教程都没有其它登录方式成功过。

我们需要创建一个token,新建一个文件a.yaml

---
apiVersion: v1
kind: ServiceAccount
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard-admin
  namespace: kube-system

---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
  name: kubernetes-dashboard-admin
  labels:
    k8s-app: kubernetes-dashboard
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: cluster-admin
subjects:
- kind: ServiceAccount
  name: kubernetes-dashboard-admin
  namespace: kube-system

启用,并且获取token

kubectl apply -f a.yaml
kubectl -n kube-system get secret | grep kubernetes-dashboard-admin
kubectl describe -n kube-system secret  kubernetes-dashboard-admin-token-{xxx}

配置hpa(Horizontal Pod Autoscaling)

wget https://github.com/kubernetes/heapster/archive/master.zip
unzip master.zip
cd heapster-master/

# 修改heapster-master/deploy/kube-config/influxdb/heapster.yaml
# - --source=kubernetes
# 连接apiserver仅仅需要上面这句

/bin/bash deploy/kube.sh start

kubectl create clusterrolebinding myname-cluster-admin-binding --clusterrole=cluster-admin --user=system:serviceaccount:kube-system:heapster

使用hpa必须要有节点服务器,并且要看看启动的容器会不会显示i/o timeout之类的信息,如果出现了,我只能重装节点服务器系统再来一次。

节点服务器安装配置:

关闭防火墙

systemctl stop firewalld.service 
systemctl disable firewalld.service

关闭selinux

setenforce 0

# 修改/etc/selinux/config文件的SELINUX=XXX
vi /etc/selinux/config
SELINUX=disabled

安装docker

yum install epel-release -y
yum install -y docker

安装k8s

# 添加一个k8s软件源
vim /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0

yum install -y kubectl kubelet kubeadm

修改k8s配置文件

vim /etc/systemd/system/kubelet.service.d/10-kubeadm.conf

原内容:
Environment="KUBELET_KUBECONFIG_ARGS=--kubeconfig=/etc/kubernetes/kubelet.conf --require-kubeconfig=true"

修改后内容
Environment="KUBELET_KUBECONFIG_ARGS=--kubeconfig=/etc/kubernetes/kubelet.conf --require-kubeconfig=true --cgroup-driver=systemd"

启动docker

service docker start

修改主机名,主机名不能有_之类特殊字符

hostnamectl --static set-hostname node1

特殊处理,不然会出错

echo 1 > /proc/sys/net/bridge/bridge-nf-call-iptables
echo 1 > /proc/sys/net/bridge/bridge-nf-call-ip6tables

执行加入集群命令

kubeadm join --token e7323f.8d87d7056b704900 10.135.10.97:6443
service docker restart

注意:可以提前下载好镜像

还有最总要的一步,在节点服务器不要执行systemctl start kubelet,在测试配置的时候,因为执行了这一步,执行kubeadm join就出错了,然后删除k8s相关目录,虽然成功加入集群,但是在hpa却不停报错,显示dial tcp xxx : i/o timeout。我只好重装了。

docker pull ccr.ccs.tencentyun.com/kubenetes/pause-amd64:3.0
docker tag ccr.ccs.tencentyun.com/kubenetes/pause-amd64:3.0 gcr.io/google_containers/pause-amd64:3.0

docker pull ccr.ccs.tencentyun.com/kubenetes/kube-proxy-amd64:v1.7.1
docker tag ccr.ccs.tencentyun.com/kubenetes/kube-proxy-amd64:v1.7.1 gcr.io/google_containers/kube-proxy-amd64:v1.7.1

docker pull ccr.ccs.tencentyun.com/calico/cni:v1.10.0
docker tag ccr.ccs.tencentyun.com/calico/cni:v1.10.0 quay.io/calico/cni:v1.10.0

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-grafana-amd64:v4.4.3
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-grafana-amd64:v4.4.3 gcr.io/google_containers/heapster-grafana-amd64:v4.4.3

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-amd64:v1.4.0
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-amd64:v1.4.0 gcr.io/google_containers/heapster-amd64:v1.4.0

docker pull ccr.ccs.tencentyun.com/kubenetes/heapster-influxdb-amd64:v1.3.3
docker tag ccr.ccs.tencentyun.com/kubenetes/heapster-influxdb-amd64:v1.3.3 gcr.io/google_containers/heapster-influxdb-amd64:v1.3.3

docker pull ccr.ccs.tencentyun.com/calico/node:v2.4.1
docker tag ccr.ccs.tencentyun.com/calico/node:v2.4.1 quay.io/calico/node:v2.4.1

docker pull ccr.ccs.tencentyun.com/coreos/flannel:v0.9.0-amd64
docker tag ccr.ccs.tencentyun.com/coreos/flannel:v0.9.0-amd64 quay.io/coreos/flannel:v0.9.0-amd64

文章首发于 http://blog.yubangweb.com/centos7-an-zhuang-kubernetes-1-7-1/ ,转载请注明来源

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容