2
我有一些麻烦从logthon登录到python。从python登录到logstash
我使用的码头工人图像从sebp /麋鹿(http://elk-docker.readthedocs.io)和python-logstash(https://pypi.python.org/pypi/python-logstash)作为记录处理程序
的搬运工图像暴露端口5044的节拍接口(http://elk-docker.readthedocs.io/#usage)。每当我尝试登录到此端口什么都不会发生......有没有其他的端口我应该使用?
我已验证logstash作品这样做:
/opt/logstash/bin/logstash -e 'input { stdin { } } output { elasticsearch { hosts => ["localhost"] } }' --path.data /root/data
Python代码(如官方在Python-logstash):
import logging
from logging import StreamHandler
import logstash
import sys
host = 'localhost'
test_logger = logging.getLogger('python-logstash-logger')
test_logger.setLevel(logging.INFO)
test_logger.addHandler(logstash.TCPLogstashHandler(host, 5044, version=1))
test_logger.addHandler(StreamHandler())
try:
test_logger.error('python-logstash: test logstash error message.')
test_logger.info('python-logstash: test logstash info message.')
test_logger.warning('python-logstash: test logstash warning message.')
# add extra field to logstash message
extra = {
'test_string': 'python version: ' + repr(sys.version_info),
'test_boolean': True,
'test_dict': {'a': 1, 'b': 'c'},
'test_float': 1.23,
'test_integer': 123,
'test_list': [1, 2, '3'],
}
test_logger.info('python-logstash: test extra fields', extra=extra)
except:
print("Error")
我不知道为什么这是行不通的。这可能与Beats有关吗?
它确实有一些跟拍,用这个来代替搬运工: https://github.com/deviantony/docker-elk,一切都像魅力一样 – user3594184