当前位置: 首页 > news >正文

乐平市网站建设河北网站建设方案详细

乐平市网站建设,河北网站建设方案详细,广州品牌网站设计,微网站素材Kubernetes使用PV和PVC做存储安装mysql 环境准备什么是PV和PVC环境准备配置nfs安装nfs配置nfs服务端 创建命名空间配置pv和pvcpv的yaml文件pvc的yaml文件 部署mysql创建mysql的root密码的secret创建mysql部署的yaml部署mysql链接mysql外部链接内部链接 环境准备 首先你需要一个… Kubernetes使用PV和PVC做存储安装mysql 环境准备什么是PV和PVC环境准备配置nfs安装nfs配置nfs服务端 创建命名空间配置pv和pvcpv的yaml文件pvc的yaml文件 部署mysql创建mysql的root密码的secret创建mysql部署的yaml部署mysql链接mysql外部链接内部链接 环境准备 首先你需要一个k8s环境可以参考我写的文章https://blog.csdn.net/m0_51510236/article/details/130842122 什么是PV和PVC 我们可以简单看一下官网的描述https://kubernetes.io/zh-cn/docs/concepts/storage/persistent-volumes/#introduction 持久卷PersistentVolumePV 是集群中的一块存储可以由管理员事先制备 或者使用存储类Storage Class来动态制备。 持久卷是集群资源就像节点也是集群资源一样。PV 持久卷和普通的 Volume 一样 也是使用卷插件来实现的只是它们拥有独立于任何使用 PV 的 Pod 的生命周期。 此 API 对象中记述了存储的实现细节无论其背后是 NFS、iSCSI 还是特定于云平台的存储系统。 持久卷申领PersistentVolumeClaimPVC 表达的是用户对存储的请求。概念上与 Pod 类似。 Pod 会耗用节点资源而 PVC 申领会耗用 PV 资源。Pod 可以请求特定数量的资源CPU 和内存同样 PVC 申领也可以请求特定的大小和访问模式 例如可以要求 PV 卷能够以 ReadWriteOnce、ReadOnlyMany 或 ReadWriteMany 模式之一来挂载参见访问模式。 本篇文章就用上面提到的nfs来搭建pv和pvc并部署mysql 环境准备 首先我们需要搭建一个k8s集群并且准备一台nfs服务器为了方便我就使用k8s的主节点作为nfs服务器服务器列表如下表 IP地址服务器用途192.168.1.160k8s-masterk8s的主节点和nfs服务器192.168.1.161k8s-node01k8s的第一个工作节点192.168.1.162k8s-node02k8s的第二个工作节点 配置nfs 安装nfs 首先我们需要在三台服务器单中都需要安装nfs软件包使用如下命令进行安装 yum install -y nfs-utils如图三台服务器都需要安装 配置nfs服务端 然后我们需要在nfs的主服务器暴露一个 /data/nfs/mysql 目录我们需要修改 /etc/exports 配置文件需要将这一行加在里面 /data/nfs/mysql *(rw,sync,no_root_squash)可以直接执行这行命令第一行为创建这个目录第二行为修改文件 mkdir -p /data/nfs/mysql cat /etc/exports EOF /data/nfs/mysql *(rw,sync,no_root_squash) EOF然后我们需要启动nfs服务只需要在nfs服务器上执行 systemctl enable --now nfs-server然后我们执行这行命令看目录是否暴露 showmount -e nfs服务器地址可以看到目录暴露成功 创建命名空间 我们需要创建一个命名空间当然也可以越过这一步这里创建命名空间的目的只是为了更接近生产环境创建命名空间的yaml文件 apiVersion: v1 kind: Namespace metadata:name: deploy-test spec: {} status: {}上面的yaml文件创建了一个名为 deploy-test 的命名空间可以查看创建结果 配置pv和pvc pv的yaml文件 注意按照提示修改内容 apiVersion: v1 kind: PersistentVolume metadata:name: deploy-mysql-nfs-pv # pv的名字namespace: deploy-test # 这里为命名空间的名字 spec:capacity:storage: 1Gi # 申请的硬盘大小为1GB可修改accessModes:- ReadWriteMany # 权限为多节点读写nfs:# 注意修改nfs服务器地址server: 192.168.1.160# 注意修改目录的地址path: /data/nfs/mysqlstorageClassName: nfs # 存储类型选择nfspvc的yaml文件 apiVersion: v1 kind: PersistentVolumeClaim metadata:name: deploy-mysql-nfs-pvc # 为pvc取一个好听的名字namespace: deploy-test # 命名空间名字 spec:accessModes:- ReadWriteMany # 权限为多节点读写storageClassName: nfs # 存储类型为nfsresources:requests:storage: 1Gi # 申请大小容量为1GBvolumeName: deploy-mysql-nfs-pv # 绑定的pv名字执行后我们可以查看创建的状态 部署mysql 创建mysql的root密码的secret 前面准备工作都做好了接下来我们就可以开始部署mysql了但是之前我们还需要创建一个secret执行命令获取yaml文件内容 # 命令说明 kubectl create secret generic mysql-password --from-literalmysql_root_passwordmysql的root密码 -n 命名空间 --dry-runclient -oyaml# 命令示例 kubectl create secret generic mysql-password --from-literalmysql_root_passwordroot -n deploy-test --dry-runclient -oyaml生成如图所示 创建mysql部署的yaml apiVersion: v1 kind: Service metadata:name: deploy-mysql-svc # mysql暴露服务的名字namespace: deploy-test # 命名空间labels:app: mysql spec:ports:- port: 3306 # 暴露给外部3306端口name: mysqltargetPort: 3306 # 内部目标3306端口nodePort: 30306 # 外部访问集群nodeport的30306端口selector:app: mysqltype: NodePortsessionAffinity: ClientIP---apiVersion: apps/v1 kind: StatefulSet # 创建一个StatefulSet有状态的控制器 metadata:name: deploy-mysql # 部署的名字namespace: deploy-test # 命名空间 spec:selector:matchLabels:app: mysqlserviceName: deploy-mysql-svc # 注意指定上面的那个服务名称replicas: 1template:metadata:labels:app: mysqlspec:terminationGracePeriodSeconds: 10containers:- args: # 新增一些启动参数- --character-set-serverutf8mb4- --collation-serverutf8mb4_unicode_ci- --lower_case_table_names1- --default-time_zone8:00name: mysql# image: docker.io/library/mysql:5.7.43image: registry.cn-shenzhen.aliyuncs.com/xiaohh-docker/mysql:5.7.43 # 因为dockerhub上镜像经常拉取失败所以使用此镜像ports:- containerPort: 3306 # 容器内部暴露3306端口name: mysqlvolumeMounts:- name: mysql-data # 引用pvc挂载的名字mountPath: /var/lib/mysql # 这个是容器内部存放数据的文件夹目录需要挂在到pvc当中env:- name: MYSQL_ROOT_PASSWORDvalueFrom: # mysql的密码引用上面创建的secretsecretKeyRef:key: mysql_root_passwordname: mysql-passwordvolumes:- name: mysql-data # pvc的挂载名称persistentVolumeClaim:claimName: deploy-mysql-nfs-pvc # 指定使用那个pvc部署mysql 整体的yaml文件内容为 apiVersion: v1 kind: Namespace metadata:name: deploy-test spec: {} status: {}---apiVersion: v1 kind: PersistentVolume metadata:name: deploy-mysql-nfs-pvnamespace: deploy-test spec:capacity:storage: 1GiaccessModes:- ReadWriteManynfs:server: 192.168.1.160path: /data/nfs/mysqlstorageClassName: nfs---apiVersion: v1 kind: PersistentVolumeClaim metadata:name: deploy-mysql-nfs-pvcnamespace: deploy-test spec:accessModes:- ReadWriteManystorageClassName: nfsresources:requests:storage: 1GivolumeName: deploy-mysql-nfs-pv---apiVersion: v1 data:mysql_root_password: cm9vdA kind: Secret metadata:name: mysql-passwordnamespace: deploy-test---apiVersion: v1 kind: Service metadata:name: deploy-mysql-svcnamespace: deploy-testlabels:app: mysql spec:ports:- port: 3306name: mysqltargetPort: 3306nodePort: 30306selector:app: mysqltype: NodePortsessionAffinity: ClientIP---apiVersion: apps/v1 kind: StatefulSet metadata:name: deploy-mysqlnamespace: deploy-test spec:selector:matchLabels:app: mysqlserviceName: deploy-mysql-svcreplicas: 1template:metadata:labels:app: mysqlspec:terminationGracePeriodSeconds: 10containers:- args:- --character-set-serverutf8mb4- --collation-serverutf8mb4_unicode_ci- --lower_case_table_names1- --default-time_zone8:00name: mysql# image: docker.io/library/mysql:5.7.43image: registry.cn-shenzhen.aliyuncs.com/xiaohh-docker/mysql:5.7.43ports:- containerPort: 3306name: mysqlvolumeMounts:- name: mysql-datamountPath: /var/lib/mysqlenv:- name: MYSQL_ROOT_PASSWORDvalueFrom:secretKeyRef:key: mysql_root_passwordname: mysql-passwordvolumes:- name: mysql-datapersistentVolumeClaim:claimName: deploy-mysql-nfs-pvc执行以下命令部署 kubectl apply -f deploy-mysql.yaml创建结果 执行下面这行命令监控部署 watch kubectl get all -o wide -n deploy-test看到下面这个代表创建成功 当我们查看nfs当中挂在出来的mysql目录的时候 ll /data/nfs/mysql/文件夹内容 链接mysql 外部链接 在我们创建mysql的时候我们就规定了一个NodePort端口如图 我们直接使用集群当中任意一个节点的30306端口即可链接这个数据库 mysql -uroot -h192.168.1.160 -p -P30306查看结果 内部链接 在集群里面访问我们可以通过主机名主机名格式如下 pod名称.service名称.命名空间名称.svc.cluster.local执行命令查看 kubectl get all -o wide -n deploy-test各类名称如图所示 所以我们此次访问mysql的主机名如下 deploy-mysql-0.deploy-mysql-svc.deploy-test.svc.cluster.local我们此次就不建立其他的pod来验证是否能够安装上了我们直接检查集群内的dns解析是否正常就知道这个域名是否正常了使用以下命令查看k8s集群当中的dns服务的地址 kubectl get svc -o wide -n kube-system | grep dns查看dns服务地址 直接通过 nslookup 尝试解析查看是否解析到正确的IP地址上 # 安装nslookup命令所在的软件包 yum install -y bind-utils # 解析域名 nslookup deploy-mysql-0.deploy-mysql-svc.deploy-test.svc.cluster.local 10.96.0.10发现域名解析是正常的 好了k8s上部署mysql完成了下课
http://www.hkea.cn/news/14381142/

相关文章:

  • 做爰免费视频网站滦南网站建设推广
  • eclipse用来做网站前端网站数据表怎么做
  • 响应式中文网站模板wordpress和vue哪个好
  • 怎么创立网站 优帮云如何制作ppt视频教程
  • 外贸做平台好还是自己建网站好什么网站能接工地做
  • 网站建设方案怎么做网站制作开发 杭州
  • 兰州网站seo公司驻马店市网站建设
  • 重庆公司注册费用是多少长春建站优化加徽信xiala5效果好
  • 微博网站建设自己网站页面设计软件
  • 创意网站建设设计公司学室内设计去哪里学比较好
  • 西安当地做网站的公司wordpress禁用修订
  • 河北专业网站建设wordpress淘宝客教程
  • 漯河网站建设兼职58做网站
  • 桂林做网站的公司小学生做网站
  • 外贸网站运营是做什么的西安网站优化招聘网
  • wordpress建不了网站超酷个人网站欣赏
  • 安徽餐饮网站建设做测算的网站
  • html5动态效果的网站是怎么做的网站优化平台
  • 湛江百度网站快速排名网站前台 后台
  • jsp企业网站开发前期报告网站推广平台有哪些
  • 单页面营销型网站制作wordpress网站 800cdn
  • 广告公司网站制作wordpress浏览器主题
  • 江苏建设网官方网站外贸营销模式
  • 自己学习建设网站最好玩的传奇网页游戏
  • 免费的网站有哪些平台北京工商注册公司
  • 新的网站的建设步骤域名备案和网站备案
  • 建设网站网站建设公司网站每天更新多少文章
  • 厦门seo网站关键词优推广优秀网站赏析
  • 做搬运的话哪个网站好抖音小程序加盟
  • 山东卓创 网站建设g3云推广是哪家公司的