返回列表 发新帖

k8s启动mysql时创建数据库_创建MySQL数据库

[复制链接]

8

主题

18

帖子

18

积分

新手上路

Rank: 1

积分
18
发表于 2024-8-24 23:43:34  | 显示全部楼层 | 阅读模式
在Kubernetes(k8s)环境中启动MySQL容器时,可以通过配置文件或命令行参数来自动创建数据库。这通常涉及编写一个初始化脚本或使用Kubernetes的初始化容器特性,确保在MySQL服务运行之前执行数据库创建命令。
要在Kubernetes(k8s)上启动MySQL并创建数据库,你需要遵循以下步骤:

zbhj20io3qy1x2m.jpg

zbhj20io3qy1x2m.jpg


(图片来源网络,侵删)
1、部署MySQL服务器
2、连接到MySQL服务器
3、创建数据库
以下是详细的操作步骤:
1. 部署MySQL服务器
你需要创建一个MySQL的Deployment和Service,这里我们使用官方的MySQL镜像,创建一个名为mysqldeployment.yaml的文件,内容如下:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      name: mysql
        image: mysql:5.7
        env:
        name: MYSQL_ROOT_PASSWORD
          value: mypassword
        ports:
        containerPort: 3306
        volumeMounts:
        name: mysqlpersistentstorage
          mountPath: /var/lib/mysql
      volumes:
      name: mysqlpersistentstorage
        persistentVolumeClaim:
          claimName: mysqlpvclaim
apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  ports:
  port: 3306
  selector:
    app: mysql
  clusterIP: None
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysqlpvclaim
spec:
  accessModes:
    ReadWriteOnce
  resources:
    requests:
      storage: 1Gi
应用这个YAML文件来部署MySQL服务器:

zbhjugbf2afxrtt.png

zbhjugbf2afxrtt.png


(图片来源网络,侵删)

kubectl apply f mysqldeployment.yaml
2. 连接到MySQL服务器
要连接到MySQL服务器,你需要创建一个Pod并运行一个MySQL客户端,创建一个名为mysqlclient.yaml的文件,内容如下:

apiVersion: v1
kind: Pod
metadata:
  name: mysqlclient
spec:
  containers:
  name: mysqlclient
    image: mysql:5.7
    command: ["sleep", "infinity"]
  restartPolicy: Never
应用这个YAML文件来创建Pod:

kubectl apply f mysqlclient.yaml
获取Pod的名称:

kubectl get pods
进入Pod的容器:

kubectl exec it  /bin/bash
在容器内,运行MySQL客户端:

mysql h mysql u root pmypassword
3. 创建数据库

zbhj5otassetd1b.jpg

zbhj5otassetd1b.jpg


(图片来源网络,侵删)
现在你已经连接到了MySQL服务器,可以创建一个新的数据库,在MySQL命令行中输入以下命令:

CREATE DATABASE my_database;
这将创建一个名为my_database的新数据库,你可以使用SHOW DATABASES;命令查看所有数据库。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表