为了找出响应速度慢,超时失败率高的接口,并定位出性能瓶颈的卡壳所在,我们需要一个apm性能监测工具。php是一个单进程的语言,性能卡壳主要就在于myql、redis、memcache等数据库操作以及curl等微服务调用过程,我们需要一个工具,能够帮助我们系统的看到整个接口的请求——响应过程,找出过程中的耗时点,有针对性的做出优化。skywalking是国产开源的apm性能管理工具,本教程在前面内容的基础上,基于k8s搭建一个自己的skywalking服务端,ui工具以及php的skywalking agent

mysql

我们的skywalking使用外部mysql作为数据存储仓库

mysql存储卷

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: mysql-data
  namespace: datacenter
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 2Gi
  storageClassName: local-path
  volumeMode: Filesystem

myql deployment中用环境变量指定时区和root密码,root密码来自于k8s配置的密钥

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    k8s.kuboard.cn/layer: db
    k8s.kuboard.cn/name: mysql
  name: mysql
  namespace: datacenter
spec:
  selector:
    matchLabels:
      k8s.kuboard.cn/layer: db
      k8s.kuboard.cn/name: mysql
  template:
    metadata:
      labels:
        k8s.kuboard.cn/layer: db
        k8s.kuboard.cn/name: mysql
    spec:
      containers:
        - env:
            - name: TZ
              value: Asia/Shanghai
          envFrom:
            - secretRef:
                name: passwords
          image: 'mysql:8.0'
          name: mysql
          ports:
            - containerPort: 3306
              name: mysql
              protocol: TCP
          volumeMounts:
            - mountPath: /var/lib/mysql
              name: volume-3k3ah
      volumes:
        - name: volume-3k3ah
          persistentVolumeClaim:
            claimName: mysql-data

skywalking-oap

skywalking连接mysql,需要自己下载mysql的jar包放到/skywalking/ext-libs 目录中,我这里使用共享数据卷的方式放入。在环境变量中配置连接方式为mysql以及mysql的连接信息从k8s的密钥中读取,时区设置一下

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    k8s.kuboard.cn/layer: monitor
    k8s.kuboard.cn/name: skywalking
  name: skywalking
  namespace: promethues
spec:
  selector:
    matchLabels:
      k8s.kuboard.cn/layer: monitor
      k8s.kuboard.cn/name: skywalking
  template:
    metadata:
      labels:
        k8s.kuboard.cn/layer: monitor
        k8s.kuboard.cn/name: skywalking
    spec:
      containers:
        - env:
            - name: TZ
              value: Asia/Shanghai
            - name: SW_STORAGE
              value: mysql
          envFrom:
            - secretRef:
                name: skywalking-db
          image: 'apache/skywalking-oap-server:9.0.0'
          name: skywalking
          ports:
            - containerPort: 12800
              name: sky-http
              protocol: TCP
            - containerPort: 11800
              name: sky-grpc
              protocol: TCP
          volumeMounts:
            - mountPath: /skywalking/ext-libs
              name: volume-r8etc
      volumes:
        - name: volume-r8etc
          persistentVolumeClaim:
            claimName: skywalking-jars

skywalking-ui

        skywalking-ui是skywalking的界面展示工具,需要连接到skywalking才能使用,环境变量中设置一下时区

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    k8s.kuboard.cn/layer: web
    k8s.kuboard.cn/name: skywalking-ui
  name: skywalking-ui
  namespace: promethues
spec:
  selector:
    matchLabels:
      k8s.kuboard.cn/layer: web
      k8s.kuboard.cn/name: skywalking-ui
  template:
    metadata:
      labels:
        k8s.kuboard.cn/layer: web
        k8s.kuboard.cn/name: skywalking-ui
    spec:
      containers:
        - env:
            - name: SW_OAP_ADDRESS
              value: 'http://skywalking:12800'
            - name: TZ
              value: Asia/Shanghai
          image: 'apache/skywalking-ui:8.9.0'
          name: skywalking-ui
          ports:
            - containerPort: 8080
              name: skywalking-ui
              protocol: TCP

php-agent

skywalking php客户端的编译需要依赖cargo 和 rust 环境 以及libcurl库

cargo和rust

export RUSTUP_HOME=/tmp/rustup && \
export CARGO_HOME=/tmp/cargo && \
curl https://sh.rustup.rs -sSf | sh -s -- -y --no-modify-path && \
ln -s $CARGO_HOME/bin/rustup /usr/local/bin/rustup && \
ln -s $CARGO_HOME/bin/rustc /usr/local/bin/rustc && \
ln -s $CARGO_HOME/bin/cargo /usr/local/bin/cargo && \
ln -s $CARGO_HOME/bin/rustfmt /usr/local/bin/rustfmt

libcurl

apt install -y libcurl4-openssl-dev

安装skywalking

rustup default stable && pecl install skywalking

skywaling的php配置文件内容如下

extension=skywalking
skywalking.enable = ${PHP_SKYWALKING_ENABLE}
skywalking.service = ${APP_NAME}
skywalking.oap_version = 9.0.0
skywalking.grpc_address = ${PHP_SKYWALKING_SERVER_ADDR}
skywalking.log_level = ${PHP_SKYWALKING_LOG_LEVEL}
skywalking.log_path = ${PHP_SKYWALKING_LOG_FILE}
skywalking.sample_n_per_3_secs = ${PHP_SKYWALKING_SAMPLE_PER_SECS}
skywalking.curl_response_enable = 1

具体内容从环境变量中读取

apiVersion: v1
data:
  PHP_SKYWALKING_ENABLE: 'On'
  PHP_SKYWALKING_LOG_FILE: /tmp/skywalking_agent.log
  PHP_SKYWALKING_LOG_LEVEL: INFO
  PHP_SKYWALKING_SERVER_ADDR: 'skywalking.promethues:11800'
  PHP_SKYWALKING_WORKER_THREADS: '1'
  PHP_SKYWALKING_SAMPLE_PER_SECS: '3'
kind: ConfigMap
metadata:
  name: test-api-env
  namespace: test-project1

skywalking 的 php agent通过 sky的grpc端口 11800 发送链路追踪数据。skywalking连接mysql存储这些数据,skywalking-ui 调用 sky的http端口 12800 查询数据做成报表。