吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

K8S集群內Debug微服務的最佳實踐

Linux愛好者 ? 來源:Linux愛好者 ? 作者:Linux愛好者 ? 2021-02-02 14:39 ? 次閱讀

在 K8s 集群中調試微服務很困難。有時我們遇到在不真實的環境下難以復現的 bug。在本機用你最習慣的工具調試達到和在集群中運行服務一樣的效果,這其實只需要運行幾個命令。

所用工具

為了達到目標效果,我主要用如下工具:

Gebug

https://github.com/moshebe/gebug

這個開源工具讓調試容器化了的Go程序非常方便,它是通過開啟熱更新和debugger配置實現的。我就是這個工具的作者嘻嘻。

Telepresence

https://www.telepresence.io/

這是一個很厲害的 CNCF 項目,這個項目可以用來與集群網絡做網絡隧道。

我認為,熟悉一個工具最好的辦法就是去用它,接著就來配置demo環境。

Kubernetes集群

我們使用一個小kubernetes集群,跑一個hello-world deployment、暴露一個服務。

既然是要做demo,我就用minikube了。如果你已經有一個運行中的非生產環境集群,那么你就用你的集群。注意不要在生產環境做測試。

kubectlcreatedeploymenthello-world--image=datawire/hello-world
kubectlexposedeploymenthello-world--type=LoadBalancer--port=8000

當前kubernets集群狀態

8a5a8c46-5f10-11eb-8b86-12bb97331649.png

查看service external endpoint并跑些測試:

8ad2078a-5f10-11eb-8b86-12bb97331649.png

使用minikube提供的命令拉取外部地址。也可以通過kubectl get service hello world命令并查看 EXTERNAL_IP 字段內的信息。img

hello world 服務

我們的hello-world部署很成功。我們來做一次把http返回做成json格式。

當然也可以編譯你的程序、打鏡像、push到倉庫、編輯deployment、等等等等,最后搞定。我們來用短平快的辦法做這事。

這是個簡單HTTP server:

packagemain

import(
"fmt"
"net/http"
)

funcmain(){
http.HandleFunc("/",func(whttp.ResponseWriter,r*http.Request){
fmt.Println("Gotrequest")
fmt.Fprintf(w,`{"hello":"world"}`)
})
http.ListenAndServe(":8000",nil)
}

這是Gebug配置:

name:my-server
output_binary:/app
build_command:gobuild-gcflags="all=-N-l"-o/app
run_command:/app
runtime_image:golang:1.15.2
debugger_enabled:true
debugger_port:4321
expose_ports:
-8000:8000
networks:[]
environment:[]

注意,如果沒有安裝Gebug可以運行go get -u github.com/moshebe/gebug安裝。

Telepresence

這個強大的工具讓我們繞過了復雜難懂的網絡配置,可以直接把服務連接到集群中。

安裝指南: https://www.telepresence.io/reference/install

下一步是暴露本地的服務、把流量連接到集群,就可以替換掉已經存在的deployment了。

我們的deployment叫hello-world,暴露8000端口,命令如下:

telepresence--swap-deploymenthello-world--expose8000:8000--methodinject-tcp--rungebugstart

上面這個命令做了幾件事:

  • 開一個程序負責把命中的DNS和IP段的請求重定向到k8s集群上

  • swap-deployment 這個選項是讓Telepresence用運行在Telepresence代理上的東西替換掉已經存在的hello-world pod。一旦我們退出,老pod也會被恢復。

  • run 選項告訴Telepresence用Gebug工具運行我們的服務,把這個服務和網絡代理綁定。

只要 http server 在 telepresence 中運行著,就可以從 k8s 集群內部訪問這個服務。

展示一下

下面演示 debug 一個發到 k8s 暴露的 endpoint 的請求:

8b1c8c88-5f10-11eb-8b86-12bb97331649.gif

完成。希望你可以從中獲益,為你調試微服務提速。

責任編輯:xj

原文標題:K8S 集群內 Debug 微服務的最佳實踐

文章出處:【微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 集群
    +關注

    關注

    0

    文章

    88

    瀏覽量

    17208
  • DEBUG
    +關注

    關注

    3

    文章

    94

    瀏覽量

    19976
  • 微服務器
    +關注

    關注

    0

    文章

    11

    瀏覽量

    8114

原文標題:K8S 集群內 Debug 微服務的最佳實踐

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    k8s和docker區別對比,哪個更強?

    Docker和Kubernetes(K8s)是容器化技術的兩大流行工具。Docker關注構建和打包容器,適用于本地開發和單主機管理;而K8s則提供容器編排和管理平臺,適用于多主機或云環境,具備自動化
    的頭像 發表于 12-11 13:55 ?180次閱讀

    k8s微服務架構就是云原生嗎?兩者是什么關系

    k8s微服務架構就是云原生嗎?K8s微服務架構并不等同于云原生,但兩者之間存在密切的聯系。Kubernetes在云原生架構中扮演著核心組件的角色,它簡化了容器化應用程序的管理,提供了彈
    的頭像 發表于 11-25 09:39 ?196次閱讀

    混合云部署k8s集群方法有哪些?

    混合云部署k8s集群方法是首先需在本地與公有云分別建立K8s集群,并確保網絡連接。接著,配置kubeconfig文件連接兩集群,并安裝云
    的頭像 發表于 11-07 09:37 ?189次閱讀

    k8s可以部署私有云嗎?私有云部署全攻略

    Kubernetes(簡稱K8S)可以部署私有云。Kubernetes是一個開源的容器編排引擎,能夠自動化容器的部署、擴展和管理,使得應用可以在各種環境中高效運行。通過使用Kubernetes,企業可以在自己的數據中心或私有云環境中搭建和管理容器化的應用,實現高度的靈活性和可擴展性。
    的頭像 發表于 10-25 09:32 ?207次閱讀

    k8s云原生開發要求

    IO性能。網絡要求穩定,建議使用私有網絡VPC,并配置與Kubernetes兼容的網絡插件。操作系統需與K8s版本匹配,虛擬化平臺支持Docker等。此外,還需關注安全配置,如禁用Swap、調整Sysctl等,以及etcd數據存儲后端的配置。合理配置硬件可確保K8s
    的頭像 發表于 10-24 10:03 ?276次閱讀
    <b class='flag-5'>k8s</b>云原生開發要求

    微服務架構與容器云的關系與區別

    微服務架構與容器云密切相關又有所區別。微服務將大型應用拆分為小型、獨立的服務,而容器云基于容器技術,為微服務提供構建、發布和運行的平臺。區別在于,
    的頭像 發表于 10-21 17:28 ?282次閱讀

    k8s容器啟動失敗的常見原因及解決辦法

    k8s容器啟動失敗的問題通常出現在開發者使用Kubernetes進行容器編排時,可能的原因有多種,例如:配置錯誤、鏡像問題、資源限制、依賴問題、網絡問題、節點狀態異常、其他因素等,以下是對這些常見原因的詳細分析:
    的頭像 發表于 10-11 10:12 ?323次閱讀

    服務器部署k8s需要什么配置?

    服務器部署K8s需要至少2核CPU、4GB內存、50GBSSD存儲的主節點用于管理集群,工作節點建議至少2核CPU、2GB內存、20GBSSD。還需安裝Docker,選擇兼容的Kubernetes版本,配置網絡插件,以及確保系
    的頭像 發表于 10-09 15:31 ?247次閱讀

    納尼?自建K8s集群日志收集還能通過JMQ保存到JES

    作者:京東科技 劉恩浩 一、背景 基于K8s集群的私有化交付方案中,日志收集采用了ilogtail+logstash+kafka+es方案,其中ilogtail負責日志收集,logstash負責對數
    的頭像 發表于 09-30 14:45 ?243次閱讀

    常用的k8s容器網絡模式有哪些?

    常用的k8s容器網絡模式包括Bridge模式、Host模式、Overlay模式、Flannel模式、CNI(ContainerNetworkInterface)模式。K8s的容器網絡模式多種多樣
    的頭像 發表于 09-19 11:29 ?299次閱讀

    K8S集群中使用JDOS KMS服務對敏感數據安全加密

    基本概念 KMS,Key Management Service,即密鑰管理服務,在K8S集群中,以驅動和插件的形式啟用對Secret,Configmap進行加密。以保護敏感數據, 驅動和插件需要
    的頭像 發表于 08-09 16:00 ?278次閱讀
    <b class='flag-5'>K8S</b><b class='flag-5'>集群</b>中使用JDOS KMS<b class='flag-5'>服務</b>對敏感數據安全加密

    K8S學習教程三:在PetaExpress KubeSphere 容器部署 Wiki 系統 wiki.js 并啟用中文全文檢索

    K8S學習教程(三):在PetaExpress KubeSphere 容器部署 Wiki 系統 wiki.js 并啟用中文全文檢索? 。
    的頭像 發表于 07-08 17:03 ?696次閱讀
    <b class='flag-5'>K8S</b>學習教程三:在PetaExpress KubeSphere 容器部署 Wiki 系統 wiki.js 并啟用中文全文檢索

    K8S學習教程(二):在 PetaExpress KubeSphere容器平臺部署高可用 Redis 集群

    并且需要手動重啟節點,相較之下,使用 PetaExpress 提供的 Kubernetes(k8s) 服務 進行 Redis 集群的部署,則展現出了顯著的優勢: 1、安裝便捷:使用鏡像或者 yaml 配置文件即可一件安裝,極大地
    的頭像 發表于 07-03 15:30 ?837次閱讀
    <b class='flag-5'>K8S</b>學習教程(二):在 PetaExpress KubeSphere容器平臺部署高可用 Redis <b class='flag-5'>集群</b>

     K8S學習教程一:使用PetaExpress云服務器安裝Minikube 集群

    使得開發人員能夠在本地機器上輕松創建一個單節點的 Kubernetes 集群,從而方便開發、測試和學習 Kubernetes。 我們看下如何使用PetaExpress云服務器安裝Minikube 集群
    的頭像 發表于 07-01 15:41 ?417次閱讀
     <b class='flag-5'>K8S</b>學習教程一:使用PetaExpress云<b class='flag-5'>服務</b>器安裝Minikube <b class='flag-5'>集群</b>

    K8S使用姿勢最佳實踐Check List

    就緒性和存活性探針沒有默認值,如果您未設置就緒探針,則kubelet會假定該應用程序已準備就緒,可以在容器啟動后立即接收流量。
    的頭像 發表于 04-16 11:45 ?611次閱讀
    <b class='flag-5'>K8S</b>使用姿勢<b class='flag-5'>最佳</b><b class='flag-5'>實踐</b>Check List
    百家乐官网游戏机出千| 百家乐官网娱乐官网| 百家乐棋牌正式版| bet365提款限制| 百家乐官网真人博彩的玩法技巧和规则 | 线上百家乐可靠吗| 香港六合彩的开奖结果| 百家乐官网九| 宝胜娱乐| 百家乐书包| 澳门百家乐官网庄闲和| 中国百家乐软件| 阿拉善左旗| 真人百家乐娱乐场开户注册| 百家乐官网7赢6| 威尼斯人娱乐平台代理| 百家乐官网单跳| 大发888娱乐开户| 新濠峰百家乐官网的玩法技巧和规则| 载大发888软件| 新澳门百家乐官网的玩法技巧和规则 | 澳门百家乐网上赌城| 百家乐官网投注限额| 大发888手机游戏| 缅甸百家乐官网的玩法技巧和规则 | 真人百家乐打法| 浦江县| 六合彩136| 稳赢百家乐的玩法技巧| 免费百家乐官网奥| 澳门网上| 大发888娱乐城网址| 桐庐棋牌世界| 百家乐强弱走势图| 百家乐庄闲比率| 百家乐官网羸钱法| 百家乐官网德州扑克轮盘| 拉斯维加斯娱乐城| 大发888心得| 乐中百家乐的玩法技巧和规则| 百家乐专打和局|