单机版Kubernetes集群(一)


#!/bin/bash# #FileName: iptables_stop.sh
#Date:
#Author: LiLe
#Contact: @qq.com
#Version: V1.
#Description: Centos7 stop firewalld in grain install(){
yum -y install firewalld
yum -y install iptables-services
} stop_service(){
systemctl stop firewalld
systemctl stop iptables
} starting_stop(){
systemctl disable firewalld.service
systemctl disable iptables.service
} main(){
install
stop_service
starting_stop
} main
yum -y install etcd kubernetes


systemctl start etcd master
systemctl start docker node
systemctl start kube-apiserver master
systemctl start kube-controller-manager master
systemctl start kube-scheduler master
systemctl start kubelet node
systemctl start kube-proxy node
apiVersion: v1
kind: ReplicationController #表明此资源对象的内型,"ReplicationController表明这是一个RC"
metadata:
name: mysql #RC的名称,全局唯一
spec: #spec是RC的相关属性定义
replicas: #副本期待数量
selector: #是RC的Pod标签选择器,监控和管理拥有这些标签的Pod实例,确保当前集群上始终有且仅有replicas个Pod实例在运行,这里设置的replicas=1表明只能运行一个Mysql Pod实例,当集群中运行的Pod数量小于replicas时,RC会根据spec.template一节中定义的Pod模板来生成一个新的Pod实例,spec.template.metadata.labels指定了该Pod的标签,,需要注意的是这里的labels必须匹配之前的spec.selector,否则此RC每次创建了一个无法匹配Label的Pod,就会不停地尝试创建新的Pod.
app: mysql #符合目标的Pod拥有此标签
template: #根据此模板创建Pod的副本(实例)
metadata:
labels:
app: mysql #Pod副本拥有的标签,对应RC的Selector
spec:
containers: #Pod内容器的定义部分
- name: mysql #容器的名称
image: mysql #容器的镜像
ports: #容器暴露的端口
- containerPort:
env: #注入到容器内的环境变量
- name: MYSQL_ROOT_PASSWORD
value: ""
kubectl create -f mysql-rc.yaml
kubectl get rc

kubectl get pods

kubectl describe pod mysql





) wget http://mirror.centos.org/centos/7/os/x86_64/Packages/python-rhsm-certificates-1.19.10-1.el7_4.x86_64.rpm
) rpm2cpio python-rhsm-certificates-1.19.-.el7_4.x86_64.rpm | cpio -iv --to-stdout ./etc/rhsm/ca/redhat-uep.pem | tee /etc/rhsm/ca/redhat-uep.pem

ln -s /usr/libexec/docker/docker-runc-current /usr/libexec/docker/docker-runc
解决完上面的两个问题后,就可以看到status处于Running状态了



apiVersion: v1
kind: Service #表明是Kubernetes Service
metadata:
name: mysql #Service的全局唯一名称;Service 的服务名
spec:
ports:
- port: #Service提供服务的端口号
selector:
app: mysql #service对应的Pod拥有这里定义的标签; 确定了哪些Pod副本(实例)对应到本服务
kubectl create -f mysql-svc.yaml
kubectl get svc

apiVersion: v1
kind: ReplicationController
metadata:
name: myweb
spec:
replicas:
selector:
app: myweb
template:
metadata:
labels:
app: myweb
spec:
containers:
- name : myweb
image: kubeguide/tomcat-app:v1
ports:
- containerPort:
env:
- name: MYSQL_SERVICE_HOST
value: 'mysql'
- name: MYSQL_SERVICE_PORT
value: ''
kubectl create -f myweb-rc.yaml
apiVersion: v1
kind: Service
metadata:
name: myweb
spec:
type: NodePort #表明此Service开启了NodePort方式的外网访问模式
ports:
- port:
nodePort: #在集群之外,可以通过30001这个端口访问myweb,对应到8080的虚端口上。
selector:
app: myweb
kubectl create -f myweb-svc.yaml






kubectl delete rc myweb
kubectl delete pods --grace-period= --force --all


单机版Kubernetes集群(一)的更多相关文章
- 快速安装与配置kubernetes集群搭
Kubernetes是什么? 首先,它是一个全新的基于容器技术的分布式架构领先方案.这个方案尽然很新,但它是谷歌十几年以来大规模应用容器技术的经验积累和升华的一个重要成果.确切地说,kubernete ...
- 基于Python+Django的Kubernetes集群管理平台
➠更多技术干货请戳:听云博客 时至今日,接触kubernetes也有一段时间了,而我们的大部分业务也已经稳定地运行在不同规模的kubernetes集群上,不得不说,无论是从应用部署.迭代,还是从资源调 ...
- Kubernetes集群搭建过程中遇到的问题
1. 创建Nginx Pod过程中报如下错误: #kubectlcreate -f nginx-pod.yaml Error from server: error when creating &quo ...
- Kubernetes集群初探
上文我们在一台虚机上演示了Kubernetes基于redis和docker的guestbook留言簿案例,本文我们将通过配置Kubernetes集群的方式继续深入研究.集群组件安装如下配置. IP N ...
- kubernetes集群部署
鉴于Docker如此火爆,Google推出kubernetes管理docker集群,不少人估计会进行尝试.kubernetes得到了很多大公司的支持,kubernetes集群部署工具也集成了gce,c ...
- 在Openstack上创建并访问Kubernetes集群
第一部分:创建集群 在Openstack部署Kubernetes集群运行Nginx容器的步骤,其中包括: 利用Murano部署Kubernetes集群 配置Openstack的安全性使Kubernet ...
- Centos7上安装Kubernetes集群部署docker
一.安装前准备1.操作系统详情需要三台主机,都最小化安装 centos7.3,并update到最新 [root@master ~]# (Core) 角色 主机名 IPMaster master 192 ...
- 和我一步步部署 kubernetes 集群
和我一步步部署 kubernetes 集群 本系列文档介绍使用二进制部署最新 kubernetes v1.6.1 集群的所有步骤,而不是使用 kubeadm 等自动化方式来部署集群: 在部署的过程中, ...
- 在Kubernetes集群中使用calico做网络驱动的配置方法
参考calico官网:http://docs.projectcalico.org/v2.0/getting-started/kubernetes/installation/hosted/kubeadm ...
随机推荐
- Hibernate中get()和load()方法区别
get和load方式是根据id取得一个记录下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来. 1.从返回结果上对比:load方式检索不到的话会抛出org.hibernat ...
- SharePoint Framework解决方案管理参考(一)
博客地址:http://blog.csdn.net/FoxDave 使用SPFx,你的企业可以轻松构建解决方案跟Office 365和SharePoint Online集成.SPFx解决方案基于现代w ...
- Sql Server 2012 集群配置
基于Windows Server 2008 R2的WSFC实现SQL Server 2012高可用性组(AlwaysOn Group) 2012年5月 微软新一代数据库产品SQL Server 201 ...
- Python第六章(北理国家精品课 嵩天等)
一 1.集合类型定义及其操作: 集合用{}表示,元素用逗号分隔,无序,唯一 集合操作符: |:并 -:减 &:交 ^ :补 <= <:判断子集关系 >= >:判断包含关 ...
- [python3.6+opencv] 02 imwrite-打开图像后保存退出还是不保存退出的问题
加载一个灰度图,显示图片,按下’s’键保存后退出, 或者按下 ESC 键退出不保存 # -*- coding: utf-8 -*- import numpy as np import cv2 as c ...
- 鼠标跟随效果 vue或者js通用
this.$refs.tooltip.getBoundingClientRect() => 用于获取某个元素相对于视窗的位置集合.集合中有top, right, bottom, left等属性. ...
- LSC问题(不连续问题)
转载:http://blog.csdn.net/v_JULY_v/article/details/6110269 本文是动态规划算法中,网上写得最好的一个之一.看完很容易理解.需要重点理解的部分,我会 ...
- WEBBASE篇: 第十篇, JavaScript知识5
JavaScript知识5 <!doctype html> <html lang="en"> <head> <meta charset=& ...
- Alienware R8外星人台式机安装双系统(WIN10+Ubuntu)的总结
新电脑终于到了,然而外星人的系统比较特殊,很多东西和别的品牌(包括DELL)不一样, 同时NVIDIA显卡也带来了很多问题.重装了十几遍,查阅了上百篇文章后之后终于搞定了双系统. 其实核心问题很傻,就 ...
- call,apply,bind 方法的学习
这是三个常用的操作函数的方法,在js中函数就是一等公民,所以说掌握这三个方法还是有必要的 call 和 apply,都会绑定函数的上下文(context)并立即执行调用该方法函数,两者区别在于,接受的 ...