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

横岗网站设计做网站如何网站考虑优化

横岗网站设计,做网站如何网站考虑优化,网站建设优化一体,asp.net获取网站虚拟目录一、前言 minio的部署有几种方式#xff0c;分别是单节点单磁盘#xff0c;单节点多磁盘#xff0c;多节点多磁盘三种方式#xff0c;本次部署使用多节点多磁盘的方式进行部署#xff0c;minio集群多节点部署最低要求需要4个节点#xff0c;集群扩容时也是要求扩容的节点…一、前言 minio的部署有几种方式分别是单节点单磁盘单节点多磁盘多节点多磁盘三种方式本次部署使用多节点多磁盘的方式进行部署minio集群多节点部署最低要求需要4个节点集群扩容时也是要求扩容的节点为4的倍数才能更好的发挥minio的性能使用minio集群可以更好的实现高可用在minio集群还有n/2节点存活时minio集群依然可读但不可写在minio集群还有n/21节点存活时minio集群依然可读可写 二、部署 创建minio 服务yaml文件的存储目录 mkdir /opt/minio  cd /opt/minio 这里使用nfs作为minio的存储其实最好还是单独挂载磁盘作为minio的存储更好用nfs作为minio的存储相当于存储还是有单点的问题单独挂载磁盘可以在k8s的每个工作节点分配磁盘的存储路径再使用pv作为存储块这样就能避免存储的单点问题这里就是用nfs网络存储作为pv存储块的存储 vi pv.yaml apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv0 spec:storageClassName: minio-pv #指定动态存储卷的类型或类别当pvc使用该类别时可以自动绑定属于该类别的pvcapacity:storage: 100Gi #存储大小accessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retain #配置回收模式配置为删除pv不自动删除存储路径中的数据nfs: #使用nfs存储path: /volume2/k8s-data/minio/minio-pv0 #nfs存储路径这里使用4个不同的nfs路径模拟4个单独的存储磁盘server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv1 spec:storageClassName: minio-pv capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv1server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv2 spec:storageClassName: minio-pv capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv2server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv3 spec:storageClassName: minio-pv capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv3server: 10.1.13.99 使用setafulset的方式部署minio集群因为每个minio是有状态的应用每个节点都存着数据这里再说一下使用的是pvc模板的方式去绑定创建好的pv也可以使用动态pv使用pvc模板然后去动态的自动创建pv绑定 vi setafulset.yaml apiVersion: apps/v1 kind: StatefulSet metadata:name: minionamespace: minio spec:podManagementPolicy: Parallel #并行启动pod不配置的话模式是按顺序启动podminio、nacos都需要配置并行启动serviceName: minio #指定Headless Service的名称这个服务的作用是为每个Pod创建一个独立的DNS记录使其能够通过该DNS记录进行唯一标识和访问replicas: 4selector:matchLabels:app: miniotemplate:metadata:labels:app: miniospec:affinity: #亲和性配置可忽略我这里是为了分配到固定的节点上nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: appoperator: Invalues:- miniocontainers:- name: minioimage: minio/minioimagePullPolicy: IfNotPresentenv: #配置变量配置minio集群的账户密码密码不能少于8位数- name: MINIO_ROOT_USERvalue: admin- name: MINIO_ROOT_PASSWORDvalue: 12345678args: #定义minio集群配置定义每个节点- server- http://minio-{0...3}.minio.minio.svc.cluster.local/data# - http://minio-{4...7}.minio.minio.svc.cluster.local/data- --console-address- :5000ports:- name: tcp-9000containerPort: 9000protocol: TCP- name: http-5000containerPort: 5000protocol: TCPvolumeMounts: #配置数据目录- name: datamountPath: /datatolerations: #配置污点我这里是为了能在master节点上分配pod- key: node-role.kubernetes.io/control-planeoperator: Existseffect: NoSchedulevolumeClaimTemplates: #使用定义pvc模板去自动创建pvc- metadata:name: dataspec:accessModes: [ ReadWriteOnce ]storageClassName: minio-pv #配置存储类型的名称这里配置和上面pv配置的名称一致就会自动绑定关于此存储类型名称的pvresources:requests:storage: 100Gi 配置service使得外部能访问minio集群 vi service.yaml kind: Service apiVersion: v1 metadata:name: minionamespace: miniolabels:app: minio spec:type: NodePortports:- name: http-9000protocol: TCPport: 9000nodePort: 30004targetPort: 9000- name: http-5000protocol: TCPport: 5000nodePort: 30002targetPort: 5000selector:app: minio 创建命名空间 kubectl create namespace minio 创建各yaml服务 kubectl apply -f pv.yaml kubectl apply -f setafulset.yaml kubectl apply -f service.yaml 查看各服务是否正常 kubectl get all -n minio kubectl get pv  kubectl get pvc -n minio 查看minio web http://10.1.60.119:30002 输入配置setafulset时定义的用户名和密码 可以看到minio集群显示4个节点均正常 创建bucket上传文件后进行节点损坏实验 这里就不展示实验的过程了 直接讲述实验的结果本minio集群一共四个节点当存活节点只剩下n/2时即2个节点minio的bucket只能读取文件不能上传文件当存活节点剩下n/21时minio的bucket可以进行正常的读取文件、上传文件可以自行做实验尝试 注意minio集群部署后如果删除了pvc和pv重新创建会导致pod重新随机绑定一个pvc和pvpod随机绑定pvc后minio集群会出现问题会报错挂载磁盘信息不正确如果要解决的话需要删除该pv挂载路径下原来的数据所以一般不要动pvc和pv因为setafulset的特性只删除podpod会自动绑定原来的pvc即使把整个setafulset删除重新创建也是会绑定原来的pvc就不会导致集群出现问题 minio集群节点对等扩容 minio集群的扩容需要提前创建好需要扩容的pv个数再更改setafulset配置关于minio的扩容需要是4的倍数这样才能更好的发挥minio集群的特性以便最好地利用 Erasure Code并提供最佳的冗余和容错性这是因为 Erasure Code 将数据分为数据块和冗余块并将它们分布在不同的节点上确保了数据的可靠性和冗余另外使用对等扩容后minio的集群原来的节点和新加入的加点会分成两部分两部分不互相同步数据当数据上传到bucket时minio会根据算法去判断该数据存在哪一部分节点上 vi pv.yaml apiVersion: v1 #在之前的pv配置后面加上以下pv配置 kind: PersistentVolume metadata:name: minio-pv4 spec:storageClassName: minio-pv #定义了存储类型capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv4server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv5 spec:storageClassName: minio-pv #定义了存储类型capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv5server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv6 spec:storageClassName: minio-pv #定义了存储类型capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv6server: 10.1.13.99 --- apiVersion: v1 kind: PersistentVolume metadata:name: minio-pv7 spec:storageClassName: minio-pv #定义了存储类型capacity:storage: 100GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: Retainnfs:path: /volume2/k8s-data/minio/minio-pv7server: 10.1.13.99 vi setafulset apiVersion: apps/v1 kind: StatefulSet metadata:name: minionamespace: minio spec:podManagementPolicy: Parallel #平行启动pod不配置的话模式是按顺序启动podserviceName: minioreplicas: 8 #更改pod数量selector:matchLabels:app: miniotemplate:metadata:labels:app: miniospec:affinity:nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: appoperator: Invalues:- miniocontainers:- name: minioimage: minio/minioimagePullPolicy: IfNotPresentenv:- name: MINIO_ROOT_USERvalue: admin- name: MINIO_ROOT_PASSWORDvalue: Zyh022759args:- server- http://minio-{0...3}.minio.minio.svc.cluster.local/data- http://minio-{4...7}.minio.minio.svc.cluster.local/data #增加minio集群配置- --console-address- :5000ports:- name: tcp-9000containerPort: 9000protocol: TCP- name: http-5000containerPort: 5000protocol: TCPvolumeMounts:- name: datamountPath: /datatolerations:- key: node-role.kubernetes.io/control-planeoperator: Existseffect: NoSchedulevolumeClaimTemplates:- metadata:name: dataspec:accessModes: [ ReadWriteOnce ]storageClassName: minio-pvresources:requests:storage: 100Gi 执行yaml文件加载配置 kubectl apply -f pv.yaml kubectl apply -f setafulset.yaml 执行完成后minio集群就会扩容成8节点集群关于数据会随机分配到两部分节点上存储可以自行做实验验证
http://www.laogonggong.com/news/115455.html

相关文章:

  • 汕头网站制作专业美橙互联送的网站源代码
  • 建一个网站自己买服务器做网站
  • 来广营做网站公司兴国做网站
  • 做网站的宽度为多少钱曲阜人网站
  • 医疗网站制作网站建设师要求
  • 建设门户网站申请报告洛阳做天然气公司网站
  • 信誉好的昆明网站建设小手工在家做
  • 论坛网站开发的目的和意义手机浏览器 网页版
  • 建一个pc网站需要多少钱wordpress 随机展示
  • 制作小程序源码优化的概念
  • 网站开发工具c建设电动三轮车官方网站
  • 做软装设计能用到的网站有哪些详情页设计
  • 企业网站制作费做分录制作电子印章
  • 国外客户的网站电话什么是网站开发中的分页
  • wordpress怎么生成网站地图网页设计师的主要职责
  • 网站开发分层医保微信小程序是什么
  • 天津网站建设网络做截图网官网
  • 郑州网站建设贴吧app要多少钱才能开发
  • 提升自己网站个人网页可以做什么内容
  • 行政审批网站建设规范asp网站 会员注册
  • 雅安城市建设网站婚礼模板
  • 为什么建设旅游网站最强大的wordpress
  • 街道网站建设更新汇报网站建设数据保存在哪儿
  • 网站水印图片欣赏oa系统办公软件怎么用
  • 学做网站从什么开始做网站多少费用
  • 网站建设咨询话术技巧关键词seo如何优化
  • 架设一个网站需要多少钱网站建设公司信息
  • 怎么开始做网站网站底部留言代码
  • 网站设计服务平台设计 网站
  • 网站制作有前途吗北京百度关键词优化