一、介绍
Kubernetes (K8s) 是一个开源的、自动化的、跨平台的容器编排系统。K8s 以容器为基础,提供了自动部署、自动扩展、自动故障恢复等一系列功能,是现代应用开发中不可或缺的基础设施。本文将介绍如何在 Kubernetes 中通过 YAML 文件部署 Redis。
二、准备工作
在开始之前,我们需要准备好以下环境:
1. Kubectl 工具:用于部署应用到 Kubernetes 集群中
2. Redis Docker 镜像:用于创建 Redis 容器
可以使用以下命令检查是否已经安装 Kubectl 工具:
kubectl version
如果没有安装,可以使用以下命令在 Linux 系统上进行安装:
curl -LO "https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl"
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
可以使用以下命令检查是否已经安装 Docker 镜像:
docker version
如果没有安装,可以使用以下命令在 Linux 系统上进行安装:
sudo apt-get update
sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
gnupg-agent \
software-properties-common
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository \
"deb [arch=amd64] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io
我们还需要下载 Redis 镜像,可以使用以下命令:
docker pull redis
三、部署 Redis
在使用 Kubernetes 部署 Redis 之前,我们需要先创建一个 Redis 镜像的 Deployment 对象,该对象用于描述需要部署到 Kubernetes 集群中的 Redis 容器。可以使用以下 YAML 文件描述 Redis 的 Deployment 对象:
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis
labels:
app: redis
spec:
replicas: 1
selector:
matchLabels:
app: redis
template:
metadata:
labels:
app: redis
spec:
containers:
- name: redis
image: redis
ports:
- containerPort: 6379
在本 YAML 文件中:
1. apiVersion: apps/v1 表示使用 Kubernetes 的版本是 v1
2. kind: Deployment 表示创建一个 Deployment 对象
3. metadata 表示部署的名称和标签
4. spec 表示部署的规格,replicas 表示需要运行的副本数量,selector 表示选取要进行增删操作的 Deployment 实例的标签,template 表示如何创建容器的模板
5. containers 中定义了容器的名称、镜像、以及需要暴露的端口
使用以下命令创建 Redis 的 Deployment:
kubectl apply -f redis-deployment.yaml
然后我们需要在 Redis 的 Deployment 对象上创建一个 Service
在 Kubernetes 中,Service 可以用来为后端 Pod 暴露一个固定的 IP 地址和端口,以方便提供 HTTP 或者 TCP 服务。使用以下 YAML 文件描述 Redis 的 Service 对象:
apiVersion: v1
kind: Service
metadata:
name: redis
spec:
selector:
app: redis
ports:
- name: redis
port: 6379
targetPort: 6379
在本 YAML 文件中:
1. apiVersion: v1 表示定义一个 v1 版本的 Service 对象
2. kind: Service 表示创建一个 Service 对象
3. metadata 表示 Service 的名称
4. selector 表示需要将该 Service 和那些标签匹配
5. ports 表示暴露的端口号
使用以下命令创建 Redis 的 Service:
kubectl apply -f redis-service.yaml
同时检查状态是否正确:
kubectl get deploy redis
kubectl get svc redis
四、测试 Redis
现在 Redis 已经部署完成,我们可以通过一些命令来检查 Redis 是否可以正常运行。
首先使用以下命令获取 Redis 的 IP 和端口号:
kubectl get svc redis
然后,我们需要连接到这个 Redis 的实例:
redis-cli -h [REDIS_IP_ADDRESS] -p [REDIS_PORT]
在连接后,我们可以使用以下命令设置一个 key/value:
set mykey "Hello World"
使用以下命令获取该 key 的 value:
get mykey
如果返回的值是 "Hello World",那么说明 Redis 已经成功部署并且可以正常运行。
五、结束语
Kubernetes 是一个功能强大的容器编排系统,可以用来自动化部署、扩展、恢复容器化应用程序。在本文中,我们通过一个简单的例子演示了如何在 Kubernetes 中通过 YAML 文件部署 Redis。
本文所涉及的内容只是入门级别的内容,关于 Kubernetes 的更多用法和概念,建议大家自行查阅 Kubernetes 的官方文档。