![](/img/trans.png)
[英]NodeJS - Error: connect ECONNREFUSED 127.0.0.1:port (chrome-remote-interface)
[英]Fluentd Kubernetes Nodejs : Error: connect ECONNREFUSED 127.0.0.1:24224
编辑:我直接在我的 Express 应用程序中对 fluentd 服务 IP 进行了编码,它的工作..如何在不编码 ip 的情况下使其工作?
我在 Kubernetes 集群上运行了几个 pod (nodejs + express 服务器) 。
我想将日志从我的nodejs pod发送到Fluentd DeamonSet 。
但我收到此错误:
Fluentd error Error: connect ECONNREFUSED 127.0.0.1:24224
我正在使用https://github.com/fluent/fluent-logger-node ,我的配置非常简单:
const logger = require('fluent-logger')
logger.configure('pptr', {
host: 'localhost',
port: 24224,
timeout: 3.0,
reconnectInterval: 600000
});
我的 fluentd conf 文件:
<source>
@type forward
port 24224
bind 0.0.0.0
</source>
# Ignore fluent logs
<label @FLUENT_LOG>
<match fluent.*>
@type null
</match>
</label>
<match pptr.**>
@type elasticsearch
host "#{ENV['FLUENT_ELASTICSEARCH_HOST']}"
port "#{ENV['FLUENT_ELASTICSEARCH_PORT']}"
scheme "#{ENV['FLUENT_ELASTICSEARCH_SCHEME'] || 'http'}"
ssl_verify "#{ENV['FLUENT_ELASTICSEARCH_SSL_VERIFY'] || 'true'}"
user "#{ENV['FLUENT_ELASTICSEARCH_USER']}"
password "#{ENV['FLUENT_ELASTICSEARCH_PASSWORD']}"
reload_connections "#{ENV['FLUENT_ELASTICSEARCH_RELOAD_CONNECTIONS'] || 'true'}"
type_name fluentd
logstash_format true
</match>
这是 Fluentd DeamonSet 配置文件:
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: fluentd
namespace: kube-system
labels:
k8s-app: fluentd-logging
version: v1
spec:
selector:
matchLabels:
k8s-app: fluentd-logging
version: v1
template:
metadata:
labels:
k8s-app: fluentd-logging
version: v1
spec:
serviceAccount: fluentd
serviceAccountName: fluentd
tolerations:
- key: node-role.kubernetes.io/master
effect: NoSchedule
containers:
- name: fluentd
image: fluent/fluentd-kubernetes-daemonset:v1-debian-elasticsearch
ports:
- containerPort: 24224
env:
- name: FLUENT_ELASTICSEARCH_HOST
value: "xxx"
- name: FLUENT_ELASTICSEARCH_PORT
value: "xxx"
- name: FLUENT_ELASTICSEARCH_SCHEME
value: "https"
# Option to configure elasticsearch plugin with self signed certs
# ================================================================
- name: FLUENT_ELASTICSEARCH_SSL_VERIFY
value: "true"
# Option to configure elasticsearch plugin with tls
# ================================================================
- name: FLUENT_ELASTICSEARCH_SSL_VERSION
value: "TLSv1_2"
# X-Pack Authentication
# =====================
- name: FLUENT_ELASTICSEARCH_USER
value: "xxx"
- name: FLUENT_ELASTICSEARCH_PASSWORD
value: "xxx"
resources:
limits:
memory: 200Mi
requests:
cpu: 100m
memory: 200Mi
volumeMounts:
- name: config-volume
mountPath: /fluentd/etc/kubernetes.conf
subPath: kubernetes.conf
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
terminationGracePeriodSeconds: 30
volumes:
- name: config-volume
configMap:
name: fluentd-conf
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
我还尝试部署服务并公开24224端口:
apiVersion: v1
kind: Service
metadata:
name: fluentd
namespace: kube-system
labels:
app: fluentd
spec:
ports:
- name: "24224"
port: 24224
targetPort: 24224
selector:
k8s-app: fluentd-logging
status:
loadBalancer: {}
最后我的快递应用程序(部署)在这里:
apiVersion: apps/v1
kind: Deployment
metadata:
name: puppet
labels:
app: puppet
spec:
replicas: 5
selector:
matchLabels:
app: puppet
template:
metadata:
labels:
app: puppet
spec:
containers:
- name: puppet
image: myrepo/my-image
ports:
- containerPort: 8080
编辑:我直接在我的 Express 应用程序中对 fluentd 服务 IP 进行了编码,它的工作..如何在不编码 ip 的情况下使其工作?
关注问题的以下部分:
我想将日志从我的 nodejs pod 发送到 Fluentd DeamonSet。
编辑:我直接在我的 Express 应用程序中对 fluentd 服务 IP 进行了编码,它的工作..如何在不编码 ip 的情况下使其工作?
看起来 pod 和fluentd
服务之间的通信是正确的(硬编码 IP 工作)。 这里的问题是他们相互沟通的方式。
您可以通过服务的名称与fluentd
进行通信。 例如(从 pod 内部):
curl fluentd:24224
您只能通过名称(如fluentd
)与相同命名空间中的服务进行通信。 如果服务位于另一个命名空间中,您将需要使用它的完整 DNS 名称。 它的模板和示例如下:
service-name.namespace.svc.cluster.local
fluentd.kube-system.svc.cluster.local
您还可以使用ExternalName
类型的服务将您的服务的完整 DNS 名称映射到较短的版本,如下所示:
假设(示例):
nginx-namespace
命名空间:
$ kubectl create namespace nginx-namespace
nginx-namespace
有一个nginx
Deployment
和一个与之关联的服务:
$ kubectl create deployment nginx --image=nginx --namespace=nginx-namespace
$ kubectl expose deployment nginx --port=80 --type=ClusterIP --namespace=nginx-namespace
default
)与nginx
Deployment
通信您可以选择与上面的 pod 进行通信:
Pod
的 IP 地址
10.98.132.201
nginx.nginx-namespace.svc.cluster.local
ExternalName
类型的服务
nginx-service
ExternalName
类型服务的示例:
apiVersion: v1
kind: Service
metadata:
name: nginx-service
namespace: default # <- the same as the pod communicating with the service
spec:
type: ExternalName
externalName: nginx.nginx-namespace.svc.cluster.local
您可以通过以下任一方式将此信息传递给 pod:
其他资源:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.