我在Google-Container-Engine中运行我系统的新模块。我想将stdout和stderr从他们(在pods中运行)带到我的集中式logstash。有没有一种简单的方法可以将日志从pod转发到外部日志服务,例如logstash或elasticsearch?
答案 0 :(得分:4)
我决定直接登录 elasticsearch ,这是一个可以在elasticsearch.c.my-project.internal
访问的外部虚拟机(我在Google-Cloud-Platform上)。这很容易:
设置一个名为: elasticsearch 的ExternalService,它指向elasticsearch实例:
apiVersion: v1
kind: Service
metadata:
name: elasticsearch-logging
namespace: kube-system
labels:
k8s-app: elasticsearch
kubernetes.io/name: "elasticsearch"
spec:
type: ExternalName
externalName: elasticsearch.c.my-project.internal
ports:
- port: 9200
targetPort: 9200
将一个流畅的弹性搜索部署为DeamonSet。 fluentd-elasticsearch将自动连接到名为elasticsearch-logging
的服务(基于fluentd-elasticsearch deployment defintion:
apiVersion: extensions/v1beta1
kind: DaemonSet
metadata:
name: fluentd-elasticsearch
namespace: kube-system
labels:
tier: monitoring
app: fluentd-logging
k8s-app: fluentd-logging
spec:
template:
metadata:
labels:
name: fluentd-elasticsearch
spec:
containers:
- name: fluentd-elasticsearch
image: gcr.io/google_containers/fluentd-elasticsearch:1.19
volumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
terminationGracePeriodSeconds: 30
volumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
使用kubectl logs fluentd-elasticsearch-...
检查您是否能够连接到elasticsearach实例。
现在,您可以访问kibana并查看日志。
答案 1 :(得分:3)
您可以在stack-driver
到pub-sub
的日志中创建接收器,然后使用logstash-input-google_pubsub
插件 - 将所有日志导出为弹性
使用logstash-input-google_pubsub image,
见source code
在pubsub中创建主题和订阅 按照指示here
在日志查看器page中点击create export
,确保您已过滤到应用的日志(GKE容器 - >群集名称,应用名称) ,
输入接收器名称,选择Cloud Pubsub作为接收服务,现在在接收器目的地中选择您的主题。
日志将导出到pub-sub
这是pubsub-elastic.conf
文件:
input {
google_pubsub {
project_id => "my-gcloud-project-id"
topic => "elastic-pubsub-test"
subscription => "elastic-pubsub-test"
json_key_file => "/etc/logstash/gcloud-service-account-key.json"
}
}
output {
elasticsearch {
hosts => "https://example.us-east-1.aws.found.io:9243"
user => "elastic"
password => "mypassword"
}
}
这是我的Docker文件:
FROM sphereio/logstash-input-google_pubsub
# Logstash config
COPY gcloud-service-account-key.json /etc/logstash/gcloud-service-account-key.json
COPY config /etc/logstash/conf.d
COPY logstash.yml /etc/logstash/logstash.yml
现在您应该构建图像并运行
如果在kubernetes上运行,请使用以下命令:
这里是deployment.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: logstash-input-google-pubsub
spec:
replicas: 1
strategy:
type: RollingUpdate
template:
metadata:
labels:
app: logstash-input-google-pubsub
spec:
containers:
- name: logstash-input-google-pubsub
image: us.gcr.io/my-gcloud-project-id/logstash-input-google_pubsub:1.0.0
构建您的图片并推送到注册表
docker build --rm -t us.gcr.io/my-gcloud-project-id/logstash-input-google_pubsub:1.0.0 .
gcloud docker -- push us.gcr.io/my-gcloud-project-id/logstash-input-google_pubsub:1.0.0
现在创建实例kubectl create -f deployment.yaml
完成!!
答案 2 :(得分:2)
因为elasticsearch 6.00你可以使用filebeats
请参阅blog
curl -L -O https://raw.githubusercontent.com/elastic/beats/6.0/deploy/kubernetes/filebeat-kubernetes.yaml
- name: ELASTICSEARCH_HOST
value: elasticsearch
- name: ELASTICSEARCH_PORT
value: "9200"
- name: ELASTICSEARCH_USERNAME
value: elastic
- name: ELASTICSEARCH_PASSWORD
value: changeme
kubectl create -f filebeat-kubernetes.yaml
答案 3 :(得分:0)
您可以尝试安装以下kubernetes插件:https://github.com/kubernetes/kubernetes/tree/master/cluster/addons/fluentd-elasticsearch
Haven自己尝试过,但我也在寻找合适的伐木方法。 GCE记录在某种程度上仅限于我的观点。