草庐IT

k8s之Service

全部标签

k8s集群调度之固定节点调度

1.指定调度节点1.1.实例一:pod.spec.nodeName将pod直接调度到指定的Node节点上,会跳过Scheduler的调度策略,该匹配规则是强制匹配。vimpod.yamlapiVersion:apps/v1#这指定了使用的KubernetesAPI版本是apps/v1kind:Deployment#指定要创建的对象类型,这里是deploymentmetadata:#元数据信息,包括对象的名称、标签等信息name:my-nginx#对象的名称,这里是my-nginxspec:#指定deployment对象的配置信息replicas:4#指定需要运行的副本数,这里是4selecto

IDEA工具远程DEBUG调试K8S环境中的容器应用(Java应用)

应用场景:IDEA远程调试kubernetes环境中的容器应用(Java应用)应用场景:Java开发的项目在本地运行正常,然后将容器运行方式的项目发布到远端服务器上线运行后,出现了异常情况,此时频繁去修改代码发布镜像进行问题验证,将耗费较大的时间成本。为了提高问题定位和代码调试效率,使用端口代理的方式,将远端容器应用的端口映射出来,使用远端代码调试方式进行debug代码。1.修改服务部署的deployment.yaml文件修改指定服务的deployment.yaml文件,为容器添加远程调试的JVM配置参数:env:-name:JAVA_TOOL_OPTIONSvalue:-agentlib:j

node_modules/.bin/vue-cli-service: Permission denied

背景因为有一些前端依赖的库是私服的,只有在局域网中才能下载到。所以我直接把node_modules复制过来直接使用的。我是从windows系统中复制到macOS中使用。现象npmrunserve>fronted@0.1.0serve/Users/itkey/workspace/frontend>vue-cli-serviceservesh:/Users/itkey/workspace/node_modules/.bin/vue-cli-service:PermissiondeniednpmERR!codeELIFECYCLEnpmERR!errno126npmERR!fronted@0.1.0

kubernetes/k8s驱逐机制总结篇

概述k8s的驱逐机制是指在某些场景下,如node节点notReady、node节点压力较大等,将pod从某个node节点驱逐掉,让pod的上层控制器重新创建出新的pod来重新调度到其他node节点。这里也将kube-scheduler的抢占调度纳入到了驱逐的讨论范围内,因为当调度高优先级的pod时发现资源不足,会驱逐掉node节点上原有的低优先级的pod。根据发起驱逐的组件,驱逐可以分为3类:(1)由kubelet发起的驱逐:节点压力驱逐;kubelet周期性检查自身节点资源压力,当节点压力较大时,会驱逐自身node节点上的pod,以回收资源,降低节点资源压力;(2)由kube-control

java - 获取 java.net.UnknownHostException : hostname: Name or service not known while using spring-data-redis-starter

我正在尝试使用spring-boot-starter-data-redis和lettuce库以集群模式连接到Redis并遇到异常,2019-08-2100:55:42.695WARN75---[ioEventLoop-6-1]i.l.c.c.topology.ClusterTopologyRefresh:Unabletoconnecttomyhostname.service:6379java.util.concurrent.CompletionException:java.net.UnknownHostException:myhostname.service:Nameorservice

ruby-on-rails - 在部署到 EC2 之后,sidekiq 现在报告 SocketError : getaddrinfo: Name or service not known

应用程序是Rails4.1.4,Ruby2.1.2。使用sidekiq3.2.6、redis3.1.0、celluloid0.15.2。sidekiq实现是默认的,除了连接到远程redis队列(弹性缓存)。当处理某些事件时,我们使用sidekiq来排队调用外部API。API可通过托管我们应用程序的服务器的curl访问。所有其他功能似乎仍按预期执行。此功能已在当前服务器实现/架构上运行数周。在成功部署(使用Capistrano,通过Jenkins)到弹性负载均衡器后面的EC2实例之后,自动缩放组sidekiq将不再连接(?)到elasticcache。SocketError:getadd

从零开始安装EdgeX ONVIF Camera Device Service

本文将介绍从拿到一台新电脑开始,如何一步一步安装EdgeXONVIFCameraDeviceService,并找到ONVIFIPCamera第一步,安装Ubuntu20.04,安装完毕后,可以获得系统信息如下所示:Ubuntu20.04onIntelNUC第二步,安装向日葵远程控制软件或者Teamviewer,方便用笔记本远程控制这台安装了Ubuntu20.04的设备第三步,在Software&Updates中配置Ubuntu国内源选择国内Ubuntu服务器然后禁止自动升级。禁止自动升级第四步将IPCamera接入与NUC相同的局域网,并处于同一网段,然后为IPC设置用户和密码。本文使用的是T

Kubernetes(k8s)上搭建一主两从的mysql8集群

Kubernetes上搭建一主两从的mysql8集群环境准备搭建nfs服务器安装NFS暴露nfs目录开启nfs服务器安装MySQL集群创建命名空间创建MySQL密码的Secret安装MySQL主节点创建pv和pvc主节点的配置文件部署mysql主节点安装第一个MySQLSlave节点创建pv和pvc第一个从节点配置文件部署mysql从节点安装第二个MySQLSlave节点创建pv和pvc第二个从节点配置文件部署mysql第二个从节点使三台服务器组成一个集群查看主节点的状态连接第一个Slave连接第二个Slave测试主从集群环境准备本文章视频教程地址:https://www.bilibili.c

k8s之service五种负载均衡byte的区别

1,什么是Service?1.1Service的概念​在k8s中,service是一个固定接入层,客户端可以通过访问service的ip和端口访问到service关联的后端pod,这个service工作依赖于在kubernetes集群之上部署的一个附件,就是kubernetes的dns服务(不同kubernetes版本的dns默认使用的也是不一样的,1.11之前的版本使用的是kubeDNs,较新的版本使用的是coredns),service的名称解析是依赖于dns附件的,因此在部署完k8s之后需要再部署dns附件,kubernetes要想给客户端提供网络功能,需要依赖第三方的网络插件(flan

Redis StackExchange 客户端 - 频繁接收 "Timeout exceptions", "Redis connection exception", "No connection available to service"

我经常遇到下面提到的错误,项目中使用的dll版本是-1.0.488.0System.TimeoutException:执行GET超时StackExchange.Redis.RedisConnectionException:没有连接可用于服务此操作:GET没有可用于服务此操作的连接:EXISTS谁能帮我弄清楚问题出在哪里?还在StackExchange的Github存储库上针对相同问题创建了一个问题IssuecreatedonGithubforthesame 最佳答案 您的连接似乎中断了。当它发生时,任何已经发送到Redis的命令都会