一、安装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. ...
随机推荐
- lqb 基础练习 特殊的数字
基础练习 特殊的数字 时间限制:1.0s 内存限制:512.0MB 问题描述 153是一个非常特殊的数,它等于它的每位数字的立方和,即153=1*1*1+5*5*5+3*3*3.编程求所有 ...
- zabbix4.0开源监控部署
---恢复内容开始--- 1.安装依赖环境 yum -y install telnet net-tools python-paramiko dejavu-sans-fonts python-setup ...
- ArcGIS API For Javascript :读取 CSV 文件的方法
我们临时会遇到一些测试数据,通常从数据库中以 CSV 格式导出.最简单实用的方法就是使用 ajax 去读取文件,记得引入 jQuery . 例如,在<ArcGIS JS API :新增一个热力图 ...
- dbstructsync 多套mysql环境表、字段、索引的差异sql产出(原创)
最近写了一个工具(比较两套测试环境数据库表.表字段.索引的差异) 功能:可以比较两套环境中mysql指定库中表.表字段及索引的差异,返回具体需要同步的执行sql A环境的数据库db 作为sourced ...
- SpringBoot学习(三)—— springboot快速整合swagger文档
目录 MyBatis 简介 引入mybatis组件 代码实战 MyBatis @ 简介 优点 最大的优点是SQL语句灵活,适合调优情景,业务复杂情景 劣势 最大的劣势是不同数据库之间的迁移 引入myb ...
- html基础——a标签
a标签:超链接/锚点链接 实现页面跳转 只占据自己内容大小的位置 超链接: 使用 target="_self":表示在本页面跳转到 href 中的地址 target=" ...
- Hystrix完整配置列表
前提 Hystrix在2018年11月20日之后已经停止维护,最后一个提交记录是:Latest commit 3cb2158 on 20 Nov 2018,最后一个正式版本为1.5.18.鉴于目前所在 ...
- 数据表与简单java类——一对多映射
例如:给定一个分类表和子分类表 得到如下信息: 1.一个分类的完整信息: 2.根据分类获取其对应的子分类 package Mapping_transformation; class item { pr ...
- django框架简介及自定义简易版框架
web应用与web框架本质 概念 什么是web应用程序呢? Web应用程序就一种可以通过互联网来访问资源的应用程序, 用户可以只需要用一个浏览器而不需要安装其他程序就可以访问自己需要的资源. 应用软件 ...
- Docker虚拟化之<基础命令>
1.在docker hub中搜索镜像 docker search nginx 2.从docker镜像服务器拉取指定镜像或者库镜像 docker pull docker.io/nginx 3.列出系统当 ...