本文介绍 IP Route
本文介绍 CentOS系统如何使用及常用命令
本文介绍分布式压测系统ngrinder及ngrinder工作原理 ngrinder源码解析
本文介绍负载均衡nginx及nginx配置
本文介绍开源搜索引擎elasticsearch
ES常见FAQ
链路追踪 skywalking
├── agent-docker                         # 构建包含agent的docker镜像
│   ├── apm-toolkit-log                  # java日志增强库
│   ├── Makefile                         # 批量构建脚本
│   ├── ngcp-auth                        # auth服务的构建脚本
│   ├── ngcp-uus                         # uus服务的构建脚本
│   ├── README.md                        # 说明文档
│   └── skywalking-agent.tar.gz          # skywalking-agent包,会添加都镜像中,在启动java时加载
├── agent-kubernetes                     # 存放已经打入skywalking-agent的applications的kubernetes脚本
├── README.md                            # 说明文档
├── skywalking-6.0.0-GA-docker           # skywalking的docker镜像脚本
│   ├── base                             # 基础镜像
│   ├── compose                          # docker-compose脚本
│   ├── Makefile                         # 批量构建docker镜像脚本
│   ├── oap                              # oap-server服务构建脚本
│   ├── oap-patch                        # 包装原镜像增加上海时区
│   ├── README.md                        # 说明文档
│   ├── ui                               # skywalking-UI的构建脚本
│   └── ui-patch                         # 包装原镜像增加上海时区
└── skywalking-6.0.0-GA-kubernetes       # skywalking kubernetes 部署脚本
    ├── elasticsearch                    # elasticsearch相关脚本
    ├── istio                            # istio相关脚本
    ├── namespace.yml                    # 创建skywalking命名空间
    ├── oap                              # skywalking服务相关脚本
    ├── README.md                        # 说明文档
    └── ui                               # skywalking界面相关脚本
没有现成的elasticsearch需要创建es服务,相关脚本在skywalking-6.0.0-GA-kubernetes/elasticsearch下,
es没有配置存储,需要的话自行配置。
skywalking-6.0.0-GA-docker/oap_patch脚本构建上海时区的oap镜像make oap_patch命令构建oap镜像并上传仓库修改es配置 使用真实的es集群的IP:端口
路径:skywalking-6.0.0-GA-kubernetes/oap/01-config.yml
  application.yml:
    storage:
      elasticsearch:
        clusterNodes: 192.168.1.108:9200
192.168.29.2:5000/apache/skywalking-oap-server:6.0.0-GA-timezoneskywalking-6.0.0-GA-kubernetes/oap下的脚本在kubernetes平台执行skywalking-6.0.0-GA-kubernetes/ui下的脚本在kubernetes平台执行skywalking-6.0.0-GA-kubernetes/istio下的脚本在kubernetes平台执行agent-docker/Makefile提取了相关参数对应修改
# 构建镜像版本
export AGENT_VER = latest
# docker镜像仓库地址
export DOCKER_REGISTRY = 192.168.29.2:5000
# oap服务地址 
export COLLECTOR_BACKEND_SERVICES = 192.168.136.8:31180
在agent-docker目录下执行make ngcp-uus构建uus镜像并上传仓库
使用agent-kubernetes/ngcp-uus.yaml脚本在kubernetes平台执行创建uus服务
在agent-docker目录下执行make ngcp-auth构建auth镜像并上传仓库
使用agent-kubernetes/ngcp-auth.yaml脚本在kubernetes平台执行创建auth服务
RUN apk add -U tzdata
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN apk del tzdata
        "initContainers":[
          {
            "name":"increase-the-timezone",
            "image": "busybox",
            "command":["sh","-c","echo 'Asia/Shanghai' > /etc/timezone"],
            "securityContext":{
                "privileged": true
             }
          }
        ]
在项目maven中增加相关日志增强依赖
        <dependency>
            <artifactId>apm-application-toolkit</artifactId>
            <artifactId>apm-toolkit-log4j-1.x</artifactId>
            <version>6.1.0-SNAPSHOT</version>
        </dependency>
        <!--或者-->
        <dependency>
            <artifactId>apm-application-toolkit</artifactId>
            <artifactId>apm-toolkit-log4j-2.x</artifactId>
            <version>6.1.0-SNAPSHOT</version>
        </dependency>        
        <!--或者-->
        <dependency>
            <artifactId>apm-application-toolkit</artifactId>
            <artifactId>apm-toolkit-logback-1.x</artifactId>
            <version>6.1.0-SNAPSHOT</version>
        </dependency>        
配置日志配置文件比如logback
logback使用增强的TraceIdPatternLogbackLayout
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.TraceIdPatternLogbackLayout">
      <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %tid - %msg%n</pattern>
    </layout>
  </appender>
或则在构建镜像时动态加入日志依赖
脚本pre.sh
mkdir tmp
cp ngcp-auth-0.1.0-SNAPSHOT.jar tmp/ngcp.jar
cd tmp
jar -xf ngcp.jar
rm -rf ngcp.jar
cp ../../lib/* lib/
cp ../logback.xml .
jar -cfM0 ../ngcp-auth-0.1.0-SNAPSHOT.jar *
cd ../
rm -rf tmp
本文记录 hbase