当前位置:首页 > 科技  > 软件

五分钟k8s入门到实战-应用配置

来源: 责编: 时间:2023-09-28 10:08:10 421观看
导读背景在前面三节中已经讲到如何将我们的应用部署到 k8s 集群并提供对外访问的能力,x现在可以满足基本的应用开发需求了。现在我们需要更进一步,使用 k8s 提供的一些其他对象来标准化我的应用开发。首先就是 ConfigMap,从

背景

在前面三节中已经讲到如何将我们的应用部署到 k8s 集群并提供对外访问的能力,x现在可以满足基本的应用开发需求了。lj428资讯网——每日最新资讯28at.com

现在我们需要更进一步,使用 k8s 提供的一些其他对象来标准化我的应用开发。首先就是 ConfigMap,从它的名字也可以看出这是用于管理配置的对象。lj428资讯网——每日最新资讯28at.com

ConfigMap

不管我们之前是做 Java、Go 还是 Python 开发都会使用到配置文件,而 ConfigMap 的作用可以将我们原本写在配置文件里的内容转存到 k8s 中,然后和我们的 Container 进行绑定。lj428资讯网——每日最新资讯28at.com

存储到环境变量

绑定的第一种方式就是将配置直接写入到环境变量,这里我先定义一个 ConfigMap:lj428资讯网——每日最新资讯28at.com

apiVersion: v1  kind: ConfigMap  metadata:    name: k8s-combat-configmap  data:    PG_URL: "postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable"

重点是 data 部分,存储的是一个 KV 结构的数据,这里存储的是一个数据库连接。lj428资讯网——每日最新资讯28at.com

需要注意,KV 的大小不能超过 1MBlj428资讯网——每日最新资讯28at.com

接着可以在容器定义中绑定这个 ConfigMap 的所有 KV 到容器的环境变量:lj428资讯网——每日最新资讯28at.com

# Define all the ConfigMap's data as container environment variables envFrom:    - configMapRef:        name: k8s-combat-configmap

我将 ConfigMap 的定义也放在了同一个 deployment 中,直接 apply:lj428资讯网——每日最新资讯28at.com

❯ k apply -f deployment/deployment.yamldeployment.apps/k8s-combat createdconfigmap/k8s-combat-configmap created

此时 ConfigMap 也会被创建,我们可以使用lj428资讯网——每日最新资讯28at.com

❯ k get configmapNAME                   DATA   AGEk8s-combat-configmap   1      3m17s❯ k describe configmap k8s-combat-configmapData====PG_URL:----postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable

拿到刚才声明的配置信息。lj428资讯网——每日最新资讯28at.com


同时我在代码中也读取了这个环境变量:lj428资讯网——每日最新资讯28at.com

http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {     name, _ := os.Hostname()     url := os.Getenv("PG_URL")      fmt.Fprint(w, fmt.Sprintf("%s-%s", name, url))  })

访问这个接口便能拿到这个环境变量:lj428资讯网——每日最新资讯28at.com

root@k8s-combat-7b987bb496-pqt9s:/# curl http://127.0.0.1:8081k8s-combat-7b987bb496-pqt9s-postgres://postgres:postgres@localhost:5432/postgres?sslmode=disableroot@k8s-combat-7b987bb496-pqt9s:/# echo $PG_URLpostgres://postgres:postgres@localhost:5432/postgres?sslmode=disable

存储到文件

有些时候我们也需要将这些配置存储到一个文件中,比如在 Java 中可以使用 spring 读取,Go 也可以使用 configor 这些第三方库来读取,所有配置都在一个文件中也更方便维护。lj428资讯网——每日最新资讯28at.com

图片在 ConfigMap 中新增了一个 key:APP 存放了一个 yaml 格式的数据,然后在容器中使用 volumes 和 volumeMounts 将数据挂载到容器中的指定路径/go/bin/app.yamllj428资讯网——每日最新资讯28at.com

apply 之后我们可以在容器中查看这个文件是否存在:lj428资讯网——每日最新资讯28at.com

root@k8s-combat-7b987bb496-pqt9s:/# cat /go/bin/app.yamlname: k8s-combatpulsar:  url: "pulsar://localhost:6650"  token: "abc"

配置已经成功挂载到了这个路径,我们便可以在代码中读取这些数据。lj428资讯网——每日最新资讯28at.com

Secret

可以看到 ConfigMap 中是明文存储数据的;lj428资讯网——每日最新资讯28at.com

k describe configmap k8s-combat-configmap

可以直接查看。lj428资讯网——每日最新资讯28at.com

对一些敏感数据就不够用了,这时我们可以使用 Secret:lj428资讯网——每日最新资讯28at.com

apiVersion: v1  kind: Secret  metadata:    name: k8s-combat-secret  type: Opaque  data:    PWD: YWJjCg==---env:    - name: PG_PWD      valueFrom:        secretKeyRef:          name: k8s-combat-secret          key: PWD

这里我新增了一个 Secret 用于存储密码,并在 container 中也将这个 key 写入到环境变量中。lj428资讯网——每日最新资讯28at.com

❯ echo 'abc' | base64YWJjCg==

Secret 中的数据需要使用 base64 进行编码,所以我这里存储的是 abc.lj428资讯网——每日最新资讯28at.com

apply 之后我们再查看这个 Secret 是不能直接查看原始数据的。lj428资讯网——每日最新资讯28at.com

❯ k describe secret k8s-combat-secretName:         k8s-combat-secretType:  OpaqueData====PWD:  4 bytes

Secret 相比 ConfigMap 多了一个 Type 选项。图片lj428资讯网——每日最新资讯28at.com

我们现阶段在应用中用的最多的就是这里的 Opaque,其他的暂时还用不上。lj428资讯网——每日最新资讯28at.com

总结

在实际开发过程中研发人员基本上是不会直接接触 ConfigMap,一般会给开发者在管理台提供维护配置的页面进行 CRUD。lj428资讯网——每日最新资讯28at.com

由于 ConfigMap 依赖于 k8s 与我们应用的语言无关,所以一些高级特性,比如实时更新就无法实现,每次修改后都得重启应用才能生效。lj428资讯网——每日最新资讯28at.com

类似于 Java 中常见的配置中心:Apollo,Nacos 使用上会有不小的区别,但这些是应用语言强绑定的,如果业务对这些配置中心特性有强烈需求的话也是可以使用的。lj428资讯网——每日最新资讯28at.com

但如果团队本身就是多语言研发,想要降低运维复杂度 ConfigMap 还是不二的选择。lj428资讯网——每日最新资讯28at.com

下一章节会更新大家都很感兴趣的服务网格 Istio,感兴趣的朋友多多点赞转发

本文链接:http://www.28at.com/showinfo-26-11853-0.html五分钟k8s入门到实战-应用配置

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Spring BOOT 启动参数

下一篇: 实时数据推送并非只有WebSocket一种选择

标签:
  • 热门焦点
  • Mate60手机壳曝光 致敬自己的经典设计

    8月3日消息,今天下午博主数码闲聊站带来了华为Mate60的第三方手机壳图,可以让我们在真机发布之前看看这款华为全新旗舰的大致轮廓。从曝光的图片看,Mate 60背后摄像头面积依然
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 石头智能洗地机A10 Plus体验:双向自清洁治好了我的懒癌

    一、前言和介绍专为家庭请假懒人而生的石头科技在近日又带来了自己的全新旗舰新品,石头智能洗地机A10 Plus。从这个产品名上就不难看出,这次石头推出的并不是常见的扫地机器
  • 2023年Q2用户偏好榜:12+256G版本成新主流

    3月份的性能榜、性价比榜和好评榜之后,就要轮到2023年的第二季度偏好榜了,上半年的新机潮已经过去,最明显的肯定就是大内存和存储的机型了,另外部分中端机也取消了屏幕塑料支架
  • 把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事“起猛了,我能看得懂日语了”。“为什么日本人说话我能听懂?”“中文不像中文,日语不像日语,但是我竟然看懂了”…&hell
  • 英特尔Xe HPG游戏显卡:拥有512EU,单风扇版本

    据10 月 30 日外媒 TheVerge 消息报道,英特尔 Xe HPG Arc Alchemist 的正面实被曝光,不仅拥有 512 EU 版显卡,还拥有 128EU 的单风扇版本。另外,这款显卡 PCB
  • 世界人工智能大会国际日开幕式活动在世博展览馆开启

    30日上午,世界人工智能大会国际日开幕式活动在世博展览馆开启,聚集国际城市代表、重量级院士专家、国际创新企业代表,共同打造人工智能交流平台。上海市副市
Top