K8s权威指南学习

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 第一章 k8s入门(简单的Java web项目) 环境: VMware Workstation在本机虚拟一个64位的Centos7虚拟机 环境准备 关闭防火墙 systemctl disable firewalld systemctl stop firewalld 安装etcd和Kuber.

第一章 k8s入门(简单的Java web项目) 

环境: VMware Workstation在本机虚拟一个64位的Centos7虚拟机

环境准备

  1. 关闭防火墙

    systemctl disable firewalld
    systemctl stop firewalld
    
  2. 安装etcd和Kubernetes软件(会自动安装Docker软件)

    yum install -y etcd kubernetes
    
  3. 按顺序启动所有服务

    systemctl start etcd
    systemctl start docker
    systemctl start kube-apiserver
    systemctl start kube-controller-manager
    systemctl start kube-scheduler
    systemctl start kubelet
    systemctl start kube-proxy

启动MySQL服务

  1. MySQL镜像

    docker pull daocloud.io/library/mysql:latest
    
  2. 构建Mysql RC定义文件(可以使用vim创建),命名mysql-rc.yaml 内容如下:

    apiVersion: v1
    kind: ReplicationController
    metadata:
     name: mysql
    	spec:
    	 replicas: 1
    	 selector:
    		app: mysql
    	 template:
    		metadata:
    		 labels:
    			app: mysql
    		spec:
    		 containers:
    		 - name: mysql
    			image: mysql
    			ports:
    			- containerPort: 3306
    			env:
    			- name: MYSQL_ROOT_PASSWORD
    			 value: "123456" 
  3. 发布到kubernetes集群中,在master节点执行命令(注:此时可能出现问题,如:问题1:no resource found,问题2:status的状态是ContainerCreating而不是running,如果出现此问题请看关于创建rc和pod出现的问问题

    $ kubectl create -f mysql-rc.yaml 
    replicationcontroller "mysql" created
    

    查看创建的rc

    $ kubectl get rc 
    NAME DESIRED CURRENT READY AGE 
    mysql 1 1 1 14s
    

    查看pod创建情况

    $ kubectl get pods 
    NAME READY STATUS RESTARTS AGE 
    mysql-srd1m 1/1 Running 0 41s
    
  4. 创建一个与之关联的k8s Service-Mysql的定义文件(文件名为mysql-svc.yaml),内容如下:

    apiVersion: v1
    kind: Service
    metadata:
    name: mysql
    spec:
    ports:
    - port: 3306
    selector:
    app: mysql
    

    运行kubectl命令,创建service

    kubectl create -f mysql-svc.yaml
    

    查看刚刚创建的service

    $ kubectl get svc
    NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
    kubernetes 10.254.0.1 <none> 443/TCP 8d
    mysql 10.254.55.41 <none> 3306/TCP 13s

启动Tomcat服务

  1. 拉取Tomcat镜像
    	docker pull kubeguide/tomcat-app:v2
    
  2. 构建Tomcat RC定义文件,命名myweb-rc.yaml 内容如下:
    		apiVersion: v1
    		kind: ReplicationController
    		metadata:
    		 name: myweb
    		spec:
    		 replicas: 2
    		 selector:
    			app: myweb
    		 template:
    			metadata:
    			 labels:
    				app: myweb
    			spec:
    			 containers:
    				- name: myweb
    				 image: kubeguide/tomcat-app:v1
    				 ports:
    				 - containerPort: 8080 
    完成rc创建和验证
    	$ kubectl create -f myweb-rc.yaml 
    	replicationcontroller "myweb" created
    	$ kubectl get rc 
    	NAME DESIRED CURRENT READY AGE
    	mysql 1 1 1 23h
    	myweb 2 2 2 12s
    	$ kubectl get pods
    	NAME READY STATUS RESTARTS AGE
    	mysql-srd1m 1/1 Running 1 23h
    	myweb-fqlvz 1/1 Running 0 40s
    	myweb-ggrlg 1/1 Running 0 40s
    
  3. 创建对应的Service,文件名(myweb-svc.yaml),内容如下
    	apiVersion: v1
    	kind: Service
    	metadata: 
    	name: myweb
    	spec:
    	type: NodePort
    	ports:
    	- port: 8080
    	nodePort: 30001
    	selector:
    	app: myweb
    
    创建并验证
    	$ kubectl create -f myweb-svc.yaml 
    	service "myweb" created
    	$ kubectl get services
    	NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE
    	kubernetes 10.254.0.1 <none> 443/TCP 8d
    	mysql 10.254.55.41 <none> 3306/TCP 42m
    	myweb 10.254.237.187 <nodes> 8080:30001/TCP 21s

本文转移开源中国-K8s权威指南学习

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2月前
|
存储 Kubernetes 持续交付
k8s学习
【10月更文挑战第1天】
89 4
|
2月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
k8s学习--YAML资源清单文件托管服务nginx
|
2月前
|
Kubernetes 监控 测试技术
k8s学习--基于Ingress-nginx实现灰度发布系统
k8s学习--基于Ingress-nginx实现灰度发布系统
113 2
k8s学习--基于Ingress-nginx实现灰度发布系统
|
2月前
|
Prometheus Kubernetes 监控
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
115 1
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
|
2月前
|
存储 Kubernetes 调度
|
2月前
|
Kubernetes API 调度
k8s学习--pod的所有状态详解(图例展示)
k8s学习--pod的所有状态详解(图例展示)
173 1
|
2月前
|
Kubernetes JavaScript 前端开发
k8s学习--chart包开发(创建chart包)
k8s学习--chart包开发(创建chart包)
104 1
|
2月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--Traffic Shifting 流量接入
k8s学习--Traffic Shifting 流量接入
|
2月前
|
Kubernetes 监控 数据可视化
k8s学习--使用argo-rollouts实现金丝雀发布
k8s学习--使用argo-rollouts实现金丝雀发布
|
2月前
|
Kubernetes 应用服务中间件 nginx
k8s学习--kubernetes服务自动伸缩之水平收缩(pod副本收缩)VPA策略应用案例
k8s学习--kubernetes服务自动伸缩之水平收缩(pod副本收缩)VPA策略应用案例