# Sermant Injector使用手册

Sermant Injector是基于Kubernetes准入控制器(Admission Controllers)特性开发而来。准入控制器位于k8s API Server中,能够拦截对API Server的请求,完成身份验证、授权、变更等操作。本文介绍在k8s环境下,如何通过Sermant Injector组件来实现宿主应用自动挂载Sermant Agent包的快速部署。

Sermant Injector属于变更准入控制器(MutatingAdmissionWebhook), 能够在创建容器资源前对请求进行拦截和修改。Sermant Injector部署在k8s后,只需在宿主应用部署的YAML文件中spec > template > metadata> labels层级加入sermant-injection: enabled即可实现自动挂载Sermant Agent。另外,Sermant Injector还支持通过annotations的方式配置环境变量。部署应用自动挂载Sermant并通过annotations配置环境变量的使用方式可参考下文部署宿主应用中的描述。

# 参数配置

# Sermant Injector的参数配置

本项目采用Helm进行Kubernetes包管理, 部署Sermant Injector相关参数需在sermant-injector/deployment/release/values.yaml (opens new window)中做修改配置。

namespace:
  name: default

injector:
  replicas: 2
  image:
    addr:
    pullPolicy: IfNotPresent
    pullSecrets: default-secret

agent:
  image:
    addr:
    pullPolicy: IfNotPresent

externalAgent:
  imageAddr:
  fileName:
  
config:
  type: ZOOKEEPER
  endpoints: http://localhost:30110
registry:
  endpoints: http://localhost:30100

configMap:
  enabled: false
  namespaces: [default]
  env:

参数说明如下:

主参数键 二层参数键 三层参数键 说明 是否必须
namespace name - 部署Sermant Injector所在的namespace
injector replicas - 部署Sermant Injector的实例个数
image addr Sermant Injector的镜像地址
pullPolicy Sermant Injector的镜像拉取策略:Always(总是拉取),IfNotPresent(默认值,本地有则使用本地镜像,不拉取),Never(只使用本地镜像,从不拉取)
pullSecrets 拉取镜像的密钥,默认为default-secret,按需修改
agent image addr Sermant Agent的镜像地址
pullPolicy Sermant Agent的镜像拉取策略:Always(总是拉取),IfNotPresent(默认值,本地有则使用本地镜像,不拉取),Never(只使用本地镜像,从不拉取)
externalAgent imageAddr - 启动Sermant时挂载的外部Agent的镜像(需参照本文镜像制作脚本的参数配置构建)
fileName - 启动Sermant时挂载的外部Agent的jar包名字
config type - Sermant Agent配置中心类型: 当前支持ZooKeeper、Kie和Nacos。也可在配置文件中配置
endpoints - Sermant Agent配置中心地址。也可在配置文件中配置
registry endpoints - Sermant Agent注册插件的注册中心地址。也可在配置文件中配置
configMap enabled - 通用环境变量配置开关,默认为false,如需开启请配置为true
namespaces - 注入configMap的namespace,需与业务应用的namespace保持一致
env 自定义key1 配置自定义value1
自定义key2 配置自定义value2

通用环境变量配置:

Sermant Injector支持为宿主应用所在pod配置自定义的环境变量,方法为在sermant-injector/deployment/release/injector/values.yaml中修改configMap.env的内容,前提是configMap.enabled配置为true,并正确配置configMap.namespaces。通用环境变量的配置方式如下(kv形式):

configMap:
  enabled: true
  namespaces: [default, test]
  env:
  	TEST_ENV1: abc
  	TEST_ENV2: 123456

例如,在Sermant使用过程中,某些配置为当前k8s集群下各pod共享的公共配置,例如Backend后端的ip和端口等。则可在此处配置:

configMap:
  enabled: true
  namespaces: [default]	
  env:
    gateway.nettyIp: 127.0.0.1
    gateway.nettyPort: 6888

即可使default命名空间下的所有pod挂载的Sermant都与该Backend后端连接。

注意:此处configMap配置的环境变量优先级低于宿主应用yaml中env的优先级。由于config.type,config.endpointsregistry.endpoints本质上是通过env的方式加载环境变量,因此优先级也高于configMap配置的相应的sermant的环境变量。

# 镜像制作脚本的参数配置

build-sermant-image.sh (opens new window)

参数名 说明 是否必须
sermantVersion sermant--x.x.x.tar.gz包的版本
imageName 构建的Sermant Agent镜像名称
imageVersion 构建的Sermant Agent镜像版本

build-injector-image.sh (opens new window)

参数名 说明 是否必须
imageName 构建的Sermant Injector镜像名称
imageVersion 构建的Sermant Injector镜像版本

build-external-agent-image.sh (opens new window)

参数名 说明 是否必须
imageName 构建的外部Agent的镜像名称
imageVersion 构建的外部Agent的镜像版本

注意,ExternalAgent.Dockerfile (opens new window)中外部Agent的jar包需要按照实际使用的Agent来修改。

# 支持版本

Sermant Injector当前支持在Kubernetes 1.15及以上版本进行部署,通过Helm v3版本来进行Kubernetes包管理。

# 启动和结果验证

在部署Sermant Injector前需要先构建Sermant Agent镜像以及Sermant Injector镜像。

# 1 构建Sermant Agent镜像

# 准备Sermant Agent包

点击 here (opens new window)下载release包,也可以在项目中自行打包。

# 制作Sermant Agent镜像

修改文件夹 sermant-injector/images/sermant-agentbuild-sermant-image.sh 脚本中sermantVersion,imageNameimageVerison的值。

在k8s节点下,将build-sermant-image.shSermant.Dockerfile置于release包sermant-x.x.x.tar.gz同一目录下,执行build-sermant-image.sh脚本,完成Sermant Agent镜像制作。

sh build-sermant-image.sh

如需将镜像推送至镜像仓库,请执行docker push ${imageName}:{imageVerison} 命令。

# 2 构建Sermant Injector镜像

# 准备Sermant Injector包

在Sermant Injector项目下执行mvn clean package命令,在项目目录下生成sermant-injector.jar文件

# 制作Sermant Injector镜像

修改文件夹 sermant-injector/images/injectorbuild-injector-image.sh 脚本中imageNameimageVerison的值:

在k8s节点下,将build-injector-image.shstart.shInjector.Dockerfile置于Sermant Injector包sermant-injector.jar同一目录下,执行build-injector-image.sh脚本,完成Sermant Injector镜像制作。

sh build-injector-image.sh

如需将镜像推送至镜像仓库,请执行docker push ${imageName}:{imageVerison} 命令。

# 3 构建外部Agent镜像(可选)

# 准备外部Agent包

首先准备好外部Agent的jar包文件(如果有其他配套文件请一并准备),例如OpenTelemetry Agent可以从此下载 (opens new window)

# 制作外部Agent镜像

如果您需要在Sermant启动时自动挂载外部Agent(例如OpenTelemetry Agent),请参考在Sermant中使用和管理外部JavaAgent中借助Sermant Injector自动挂载的使用介绍,并按照以下操作构建镜像。

修改文件夹 sermant-injector/images/external-agentbuild-external-agent-image.sh 脚本中imageNameimageVerison的值:

在k8s节点下,将build-external-agent-image.shExternalAgent.Dockerfile置于外部Agent包例如opentelemetry-javaagent.jar同一目录下,执行build-external-agent-image.sh脚本,完成外部Agent包镜像制作。

sh build-external-agent-image.sh

如需将镜像推送至镜像仓库,请执行docker push ${imageName}:{imageVerison} 命令。

# 4 部署Sermant Injector实例

在宿主应用容器化部署前,需要先部署Sermant Injector实例。本项目采用Helm进行Kubernetes包管理,使用sermant-injector/deployment/release下的injectorChart模版。

按实际环境修改values.yaml中的模版变量,修改完成后,执行helm install命令在k8s中部署Sermant Injector实例:

helm install sermant-injector sermant-injector/deployment/release/injector

检查Sermant Injector部署pod状态为running。

至此,宿主应用部署前的环境配置工作完成。

# 5 部署宿主应用

# 自动挂载Sermant

在完成上述Sermant Injector部署后,用户根据实际应用编写yaml部署K8s Deployment资源,只需在spec > template > metadata> labels层级加入sermant-injection: enabled即可实现自动挂载Sermant Agent。(如后续不希望挂载,删除后重新启动应用即可)

# 通过annotations方式配置环境变量

如果用户希望在Deployment中配置自定义环境变量,只需在spec > template > metadata> annotations层级添加相应的键值对即可。配置方式可参考下文示例。

env.sermant.io/key1: "value1"为例,配置规则为:env.sermant.io/为通过annotations配置环境变量的标准前缀,key1为用户按需配置的自定义环境变量名称,value1为用户按需配置的自定义环境变量值。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: demo-test
  namespace: default
  labels:
    app: demo-test
spec:
  replicas: 1
  selector:
    matchLabels:
      app: demo-test
  template:
    metadata:
      labels:
        app: demo-test
        sermant-injection: enabled
      annotations:
        env.sermant.io/key1: "value1"
        env.sermant.io/key2: "value2"
    spec:
      containers:
      - name: image
        # 请替换成您的应用镜像
        image: image:1.0.0
        ports: 
        - containerPort: 8080

若pod无法创建,请检查Sermant Injector是否正确部署以及Sermant Agent镜像是否正确构建。

# 6 验证

pod创建成功后,执行如下命令,其中${pod_name}为宿主应用的pod名称

kubectl get po/${pod_name} -o yaml
  1. 查看上述命令输出内容spec > containers > env下是否包含环境变量:name为JAVA_TOOL_OPTIONS,value为 -javaagent:/home/sermant-agent/agent/sermant-agent.jar=appName=default

  2. 查看上述命令输出内容spec > containers > initContainers > image 的值是否为构建Sermant Agent镜像时的镜像地址。

执行如下命令,其中${pod_name}为用户应用的pod名称,${namespace}为用户部署应用的namespace名称

kubectl logs ${pod_name} -n ${namespace}
  1. 查看上述命令输出内容pod日志开头部分是否包含:
[INFO] Loading sermant agent...

如果上述信息无误,则表明Sermant Agent已成功挂载至用户应用中。

上次更新: 2025/1/20 06:41:14