一、安装kubernetes
实验环境:
centos7.0(建议使用7.5版本)
实验机器IP:192.168.1.4
安装方式:yum安装
1:关闭防火墙
[root@k8s ~]# iptables -F
[root@k8s ~]# setenforce 0
2:由于使用centos7.0版本,安装包较为旧,update包
[root@k8s ~]# yum -y update
3:安装etcd和kubernetes(yum安装的kubernetes包比较老1.5版本,如果需要最新的去官网下载安装包)
[root@k8s ~]# yum -y install etcd kubernetes
4:修改配置文件
[root@k8s ~]# vim /etc/sysconfig/docker
修改下面内容:
--selinux-enabled更改为--selinux-enabled=false ##关闭selinux
--insecure-registry gcr.io ##添加到里面不让Https传输
修改完成内容如下:
# /etc/sysconfig/docker
# Modify these options if you want to change the way the docker daemon runs
OPTIONS='--selinux-enabled=false --insecure-registry gcr.io --log-driver=journald --signature-verification=false'
if [ -z "${DOCKER_CERT_PATH}" ]; then
DOCKER_CERT_PATH=/etc/docker
fi
[root@k8s ~]# vim /etc/kubernetes/apiserver
修改下面内容:
--admission_control参数中的ServiceAccount删除
修改完成内容如下:
# default admission control policies
KUBE_ADMISSION_CONTROL="--admission control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota"
5:准备工作
[root@k8s ~]# yum install python-rhsm-certificates
如果提示:python-rhsm-certificates-1.19.10-1.el7_4.x86_64 被已安装的 subscription-manager-rhsm-certificates-1.24.13-3.el7.centos.x86_64 取代,无须任何处理
解决方法:
[root@k8s ~]# rpm2cpio python-rhsm-certificates-1.19.10-1.el7_4.x86_64.rpm |cpio -iv --to-stdout ./etc/rhsm/ca/redhat- uep.pem > /etc/rhsm/ca/redhat-uep.pem
6:配置docker加速器
[root@k8s ~]# vim /etc/docker/daemon.json
{
"registry-mirrors": ["https://dhq9bx4f.mirror.aliyuncs.com"]
}
7:启动所有服务
[root@k8s ~]# for s in etcd docker kube-apiserver kube-controller-manager kube-scheduler kubelet kube-proxy; do systemctl start $s; done
二、创建Mysql的RC和SVC
1:创建RC文件
[root@k8s ~]# vim mysql-rc.yaml
apiVersion: v1
kind: ReplicationController ##副本控制器RC
metadata:
name: mysql ##RC的名称,全局唯一
spec:
replicas: 1 ##Pod副本的期待数量
selector:
app: mysql ##符合目标的Pod拥有此标签
template: ##根据此模板创建Pod的副本(实例)
metadata:
labels:
app: mysql ##Pod副本拥有的标签,对应RC的Selector
spec:
containers: ##Pod内容器的定义部分
- name: mysql ##容器的名称
image: mysql:5.6 ##容器对应的Docker image
ports:
- containerPort: 3306 ##容器应用监听的端口号
env: ##注入容器内的环境变量
- name: MYSQL_ROOT_PASSWORD
value: "123456" ##数据库的密码
2:拉取mysql的docker镜像(此步骤可省略,kubernetes会自动去拉取,这里做演示)
[root@k8s ~]# docker pull registry.access.redhat.com/rhel7/pod-infrastructure:latest
[root@k8s ~]# docker pull mysql:5.6
3:创建启动rc
[root@k8s ~]# kubectl create -f mysql-rc.yaml
replicationcontroller "mysql" created
4:查询是否有mysql-rc
[root@k8s ~]# kubectl get rc
NAME DESIRED CURRENT READY AGE
mysql 1 1 1 34m
5:查询pod的状态
[root@k8s ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
mysql-19h65 1/1 Running 0 34m
6:创建svc文件
[root@k8s ~]# vim mysql-svc.yaml
apiVersion: v1
kind: Service
metadata:
name: mysql
spec:
ports:
- port: 3306
selector:
app: mysql
7:创建启动svc
[root@k8s ~]# kubectl create -f mysql-svc.yaml
service "mysql" created
8:查询svc运行状态
[root@k8s ~]# kubectl get svc
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes 10.254.0.1 <none> 443/TCP 33m
mysql 10.254.27.65 <none> 3306/TCP 13s
三、创建Tomcat的RC和SVC
1:创建RC文件
[root@k8s ~]# vim tomcat-rc.yaml
apiVersion: v1
kind: ReplicationController ##副本控制器RC
metadata:
name: tomcat ##RC的名称,全局唯一
spec:
replicas: 1 ##Pod副本的期待数量
selector:
app: tomcat ##符合目标的Pod拥有此标签
template: ##根据此模板创建Pod的副本(实例)
metadata:
labels:
app: tomcat ##Pod副本拥有的标签,对应RC的Selector
spec:
containers: ##Pod内容器的定义部分
- name: tomcat ##容器的名称
image: kubeguide/tomcat-app:v1 ##容器对应的Docker image
ports:
- containerPort: 8080 ##容器应用监听的端口号
env:
- name: MYSQL_SERVICE_HOST
value: 'mysql_service_ip'
- name: MYSQL_SERVICE_PORT
value: '3306'
2:创建启动rc
[root@k8s ~]# kubectl create -f tomcat-rc.yaml
replicationcontroller "tomcat" created
3:查询是否有tomcat-rc
[root@k8s ~]# kubectl get rc
NAME DESIRED CURRENT READY AGE
mysql 1 1 1 1h
tomcat 1 1 1 14m
4:查询pod的状态
[root@k8s ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
mysql-19h65 1/1 Running 0 1h
tomcat-p9x0h 1/1 Running 0 14m
5:创建svc文件
[root@k8s ~]# vim tomcat-svc.yaml
kind: Service
metadata:
name: tomcat
spec:
type: NodePort
ports:
- port: 8080
nodePort: 30001 ##设置映射端口,本机IP加此port供外部访问,该端口号不能小于30000
selector:
app: tomcat
6:创建启动svc
[root@k8s ~]# kubectl create -f tomcat-svc.yaml
service "tomcat" created
7:查询svc运行状态
[root@k8s ~]# kubectl get svc
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes 10.254.0.1 <none> 443/TCP 1h
mysql 10.254.27.65 <none> 3306/TCP 1h
tomcat 10.254.250.150 <nodes> 8080:30001/TCP 10m
四、测试
1:用curl命令
[root@k8s ~]# crul 10.254.250.150:8080
[root@k8s ~]# crul 192.168.1.4:30001
2:浏览器访问,添加防火墙规则
[root@k8s ~]# iptables -P FORWARD ACCEPT
输入IP:PORT(注意该端口是映射的30001端口,不是8080)
- kubernetes入门(10)kubernetes单机安装后 - helloworld
前言 查看端口是否被监听了 ::netstat -tlp |grep 31002 我是用的yum install etcd kubernetes docker vim, 这样装的是1.5.2,不是最新 ...
- 3、kubernetes应用快速入门190625
一.kubernetes应用入门 1.kubectl命令 Basic Commands create Create a resource from a file or from stdin. expo ...
- centos7 kubernetes单机安装
单机版的kubernetes 适合初学者,对kuber有个很好的入门. 因为centos系统内置了安装源.我们可以直接安装 1.yum install -y etco kubernetes 2.whe ...
- kubernetes单机板
参考地址: *** http://blog.csdn.net/carter115/article/details/51121223 ** http://www.cnblogs.com/dongdong ...
- Kubernetes单机安装部署
系统环境: Ubuntu 16.04.2 LTS 软件环境: Docker 1.12.6 Go 1.8.3 Etcd 3.1.8 Flannel 0.7.1 Kubernetes master 1.7 ...
- Kubernetes服务发现入门:如何高效管理服务?
愈发复杂的应用程序正在依靠微服务来保持可扩展性和提升效率.Kubernetes为微服务提供了完美的环境,并能够让其与Kubernetes的工具组件和功能兼容.当应用程序的每个部分放置在一个容器中,整个 ...
- Kubernetes 学习4 kubernetes应用快速入门
一.相关命令 1.kubectl 通过连接api server 进行各k8s对象资源的增删改查,如pod,service,controller(控制器),我们常用的pod控制器replicaset,d ...
- kubernetes 应用快速入门
使用kubectl进行增.删.查.改等常用操作 查看kubectl命令帮助 kubectl -h kubectl controls the Kubernetes cluster manager. Fi ...
- kubernetes快速应用入门
kubectl 就是 api server的客户端工具 创建一个nginx的pod [root@master ~]# kubectl run nginx-deploy --image=nginx:1. ...
随机推荐
- 通过myclipse建立一个简单的Hibernate项目(PS:在单元测试中实现数据的向表的插入)
Hibernate的主要功能及用法: Ⅰ.Hibernate封装了JDBC,使Java程序员能够以面向对象的思想对数据库进行操作 Ⅱ.Hibernate可以应用于EJB的J2EE架构,完成数据的持久化 ...
- lqb 基础练习 特殊的数字
基础练习 特殊的数字 时间限制:1.0s 内存限制:512.0MB 问题描述 153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3.编程求所有 ...
- hdu 2527 Safe Or Unsafe (优先队列实现Huffman)
Safe Or UnsafeTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- ArcGIS API For Javascript :如何制作地图切换器
大部分情况下我们开发会使用原生的地图切换器,由于每个项目的页面风格不同,业务场景不同,因此需要做一些样式不同的地图切换器. 首先可以照猫画虎,自己照着地图切换器的样式抄一个,或者看看主流的地图切换器都 ...
- 剑指Offer-20.包含min函数的栈(C++/Java)
题目: 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 分析: 因为题目要求得到栈中最小元素的min函数时间复杂度为O(1),这里便不选择遍历栈 ...
- objc反汇编分析,block函数块为何物?
上一篇向大家介绍了__block变量的反汇编和它的伪代码,本篇函数块block,通常定义成原型(^){},它在反汇编中是什么东西. 我们先定义将要反汇编的例子,为减少篇幅例子采用non-arc环境. ...
- opencv 3 core组件进阶(2 ROI区域图像叠加&图像混合;分离颜色通道、多通道图像混合;图像对比度,亮度值调整)
ROI区域图像叠加&图像混合 #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp&g ...
- SpringSecurity退出功能实现的正确方式
本文将介绍在Spring Security框架下如何实现用户的"退出"logout的功能.其实这是一个非常简单的功能,我见过很多的程序员在使用了Spring Security之后, ...
- applicationContext-dao.xml 配置错误
https://www.captainbed.net/ 配置文件报错: 不允许有匹配 "[xX][mM][lL]" 的处理指令目标. 错误原因: 由于大部分都是搬砖,所以格式没注意 ...
- 一文彻底搞懂CAS实现原理 & 深入到CPU指令
本文导读: 前言 如何保障线程安全 CAS原理剖析 CPU如何保证原子操作 解密CAS底层指令 小结 朋友,文章优先发布公众号,如果你愿意,可否扫文末二维码关注下? 前言 日常编码过程中,基本不会直接 ...