本文整理匯總了Python中elasticsearch.RequestsHttpConnection方法的典型用法代碼示例。如果您正苦於以下問題:Python elasticsearch.RequestsHttpConnection方法的具體用法?Python elasticsearch.RequestsHttpConnection怎麽用?Python elasticsearch.RequestsHttpConnection使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類elasticsearch
的用法示例。
在下文中一共展示了elasticsearch.RequestsHttpConnection方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: __init__
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def __init__(self, conf):
"""
:arg conf: es_conn_config dictionary. Ref. :func:`~util.build_es_conn_config`
"""
super(ElasticSearchClient, self).__init__(host=conf['es_host'],
port=conf['es_port'],
url_prefix=conf['es_url_prefix'],
use_ssl=conf['use_ssl'],
verify_certs=conf['verify_certs'],
ca_certs=conf['ca_certs'],
connection_class=RequestsHttpConnection,
http_auth=conf['http_auth'],
timeout=conf['es_conn_timeout'],
send_get_body_as=conf['send_get_body_as'],
client_cert=conf['client_cert'],
client_key=conf['client_key'])
self._conf = copy.copy(conf)
self._es_version = None
示例2: __init__
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def __init__(self, clair, hosts, index, doc_type, suffix=None, timedelta=None):
"""
Constructor
:param clair: ClairRequest object
:param hosts: elasticsearch hosts ex:[{'host': '172.18.8.10', 'port': 9200}]
:param index: elasticsearch index
:param doc_type: elasticsearch doc_type
:param suffix: index suffix (ex: one index a day)
:param timedelta: timedelta from today for suffix
"""
super().__init__(clair, "Legacy")
self._es = Elasticsearch(hosts, connection_class=RequestsHttpConnection)
self.index = index
self.doc_type = doc_type
if suffix is not None:
timedelta = timedelta or {}
self.index += (datetime.datetime.today() + datetime.timedelta(**timedelta)).strftime(suffix)
示例3: connect_es
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def connect_es(endpoint):
# Handle aws auth for es
session = boto3.Session()
credentials = session.get_credentials()
awsauth = AWS4Auth(credentials.access_key, credentials.secret_key, session.region_name, 'es',
session_token=credentials.token)
print('Connecting to the ES Endpoint: {endpoint}'.format(endpoint=endpoint))
try:
es_client = Elasticsearch(
hosts=[{'host': endpoint, 'port': 443}],
use_ssl=True,
verify_certs=True,
http_auth=awsauth,
connection_class=RequestsHttpConnection)
except Exception as e:
print("Unable to connect to {endpoint}:".format(endpoint=endpoint), e)
else:
print('Connected to elasticsearch')
return es_client
示例4: return_es
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def return_es():
return Elasticsearch(
hosts = [{'host': 'elasticsearch', 'port': 9200}],
connection_class = RequestsHttpConnection,
)
示例5: __autorefresh_studies
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def __autorefresh_studies(self, cfg):
"""Execute autorefresh for areas of code study if configured"""
if 'studies' not in self.conf[self.backend_section] or \
'enrich_areas_of_code:git' not in self.conf[self.backend_section]['studies']:
logger.debug("Not doing autorefresh for studies, Areas of Code study is not active.")
return
aoc_index = self.conf['enrich_areas_of_code:git'].get('out_index', GitEnrich.GIT_AOC_ENRICHED)
# if `out_index` exists but has no value, use default
if not aoc_index:
aoc_index = GitEnrich.GIT_AOC_ENRICHED
logger.debug("Autorefresh for Areas of Code study index: %s", aoc_index)
es = Elasticsearch([self.conf['es_enrichment']['url']], timeout=100, retry_on_timeout=True,
verify_certs=self._get_enrich_backend().elastic.requests.verify,
connection_class=RequestsHttpConnection)
if not es.indices.exists(index=aoc_index):
logger.debug("Not doing autorefresh, index doesn't exist for Areas of Code study")
return
logger.debug("Doing autorefresh for Areas of Code study")
# Create a GitEnrich backend tweaked to work with AOC index
aoc_backend = GitEnrich(self.db_sh, None, cfg['projects']['projects_file'],
self.db_user, self.db_password, self.db_host)
aoc_backend.mapping = None
aoc_backend.roles = ['author']
elastic_enrich = get_elastic(self.conf['es_enrichment']['url'],
aoc_index, clean=False, backend=aoc_backend)
aoc_backend.set_elastic(elastic_enrich)
self.__autorefresh(aoc_backend, studies=True)
示例6: es
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def es():
class Elasticsearch(object):
def __init__(self, url):
verify = default.from_env("PYTHONHTTPSVERIFY") == "1"
self.es = elasticsearch.Elasticsearch(url,
verify_certs=verify,
connection_class=elasticsearch.RequestsHttpConnection)
self.index = "apm-*"
def clean(self):
self.es.indices.delete(self.index)
self.es.indices.refresh()
def term_q(self, filters):
clauses = []
for field, value in filters:
if isinstance(value, list):
clause = {"terms": {field: value}}
else:
clause = {"term": {field: {"value": value}}}
clauses.append(clause)
return {"query": {"bool": {"must": clauses}}}
@timeout_decorator.timeout(10)
def count(self, q):
ct = 0
while ct == 0:
time.sleep(3)
s = self.es.count(index=self.index, body=q)
ct = s['count']
return ct
return Elasticsearch(getElasticsearchURL())
示例7: _elasticsearch_builder
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def _elasticsearch_builder(self):
"""Builds an Elasticsearch obj with the necessary credentials, proxy settings and secure connection."""
return Elasticsearch(hosts=[self._server], connection_class=RequestsHttpConnection, http_auth=self._http_auth,
verify_certs=self._insecure, proxies=self._proxy, api_key=self._api_key)
示例8: _elasticsearch_connect
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def _elasticsearch_connect():
"""
Connect to configured Elasticsearch domain.
:return: An Elasticsearch connection object.
"""
auth = AWSRequestsAuth(
aws_access_key=settings.AWS_ACCESS_KEY_ID,
aws_secret_access_key=settings.AWS_SECRET_ACCESS_KEY,
aws_host=settings.ELASTICSEARCH_URL,
aws_region=settings.ELASTICSEARCH_AWS_REGION,
aws_service='es'
)
auth.encode = lambda x: bytes(x.encode('utf-8'))
_es = Elasticsearch(
host=settings.ELASTICSEARCH_URL,
port=settings.ELASTICSEARCH_PORT,
connection_class=RequestsHttpConnection,
timeout=10,
max_retries=1,
retry_on_timeout=True,
http_auth=auth,
wait_for_status='yellow'
)
_es.info()
return _es
示例9: test03_upstream_indexed
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def test03_upstream_indexed(self):
"""
Check that the data has been successfully indexed in Elasticsearch.
"""
es = Elasticsearch(
host='localhost',
port=60001,
connection_class=RequestsHttpConnection,
timeout=10,
max_retries=10,
retry_on_timeout=True,
http_auth=None,
wait_for_status='yellow'
)
es_query = {
"query": {
"match_all": {}
}
}
es.indices.refresh(index='image')
search_response = es.search(
index="image",
body=es_query
)
msg = 'There should be 1000 documents in Elasticsearch after ingestion.'
self.assertEquals(search_response['hits']['total'], 1000, msg)
示例10: test05_removed_from_source_not_indexed
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def test05_removed_from_source_not_indexed(self):
id_to_check = 10494466 #Index for which we changed manually False to True
es = Elasticsearch(
host='localhost',
port=60001,
connection_class=RequestsHttpConnection,
timeout=10,
max_retries=10,
retry_on_timeout=True,
http_auth=None,
wait_for_status='yellow'
)
es_query = {
"query": {
"match": {
"_id": id_to_check
}
}
}
es.indices.refresh(index='image')
search_response = es.search(
index="image",
body=es_query
)
num_hits = search_response['hits']['total']
msg = "id {} should not show up in search results.".format(id_to_check)
self.assertEqual(0, num_hits, msg)
示例11: init_es
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def init_es(timeout=TIMEOUT):
log.info("connecting to %s %s", settings.ELASTICSEARCH_URL, settings.ELASTICSEARCH_PORT)
auth = AWSRequestsAuth(aws_access_key=settings.AWS_ACCESS_KEY_ID,
aws_secret_access_key=settings.AWS_SECRET_ACCESS_KEY,
aws_host=settings.ELASTICSEARCH_URL,
aws_region='us-west-1',
aws_service='es')
auth.encode = lambda x: bytes(x.encode('utf-8'))
es = Elasticsearch(host=settings.ELASTICSEARCH_URL,
port=settings.ELASTICSEARCH_PORT,
connection_class=RequestsHttpConnection,
timeout=timeout,
max_retries=10, retry_on_timeout=True,
http_auth=auth)
return es
示例12: new_es_client
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def new_es_client(hosts):
return Elasticsearch(hosts=hosts,
maxsize=50,
timeout=1800,
# sniff_on_connection_fail=True,
# sniff_on_start=True,
# sniffer_timeout=60,
retry_on_timeout=True,
max_retries=10,
connection_class=RequestsHttpConnection,
verify_certs=True)
示例13: make_elasticsearch_client
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def make_elasticsearch_client(elasticsearch_endpoint):
awsauth = AWSRequestsAuth(
aws_access_key=os.environ['AWS_ACCESS_KEY_ID'],
aws_secret_access_key=os.environ['AWS_SECRET_ACCESS_KEY'],
aws_token=os.environ['AWS_SESSION_TOKEN'],
aws_host=elasticsearch_endpoint,
aws_region=os.environ['AWS_REGION'],
aws_service='es'
)
return Elasticsearch(
hosts=['{0}:443'.format(elasticsearch_endpoint)],
use_ssl=True,
connection_class=RequestsHttpConnection,
http_auth=awsauth
)
示例14: __init__
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def __init__(self):
"""Open connection on Elasticsearch DataBase"""
super(Elasticsearch, self).__init__()
self.search = True
self.conn = ES([{"host": self.conf.get('host'),
"port": int(self.conf.get('port'))}],
connection_class=RequestsHttpConnection)
self.base_url = self.conn.transport.get_connection().base_url
示例15: lambda_handler
# 需要導入模塊: import elasticsearch [as 別名]
# 或者: from elasticsearch import RequestsHttpConnection [as 別名]
def lambda_handler(event, context):
'''
lambda handler to create index templates
'''
status = True
host = os.environ['ElasticsearchEndpoint']
logger.info('REQUEST RECEIVED:\n {}'.format(event))
logger.info('REQUEST RECEIVED:\n {}'.format(context))
try:
if event['RequestType'] == 'Create':
logger.info('CREATE!')
session = boto3.Session()
credentials = session.get_credentials()
awsauth = AWS4Auth(credentials.access_key, credentials.secret_key, session.region_name, 'es', session_token=credentials.token)
es = Elasticsearch([{'host': host, 'port': 443}], http_auth = awsauth, use_ssl = True, verify_certs=True, connection_class = RequestsHttpConnection)
result = es.indices.put_template(name='jobtemplate', body=job_index_template)
status1 = result.get('acknowledged', False)
result = es.indices.put_template(name='metrictemplate', body=metric_index_template)
status2 = result.get('acknowledged', False)
if (status1 == False or status2 == False):
send(event, context, "FAILED", { "Message": "Resource creation failed!" }, None)
else:
send(event, context, "SUCCESS", { "Message": "Resource creation successful!" }, None)
elif event['RequestType'] == 'Update':
logger.info('UPDATE!')
send(event, context, "SUCCESS", { "Message": "Resource update successful!" }, None)
elif event['RequestType'] == 'Delete':
logger.info('DELETE!')
send(event, context, "SUCCESS", { "Message": "Resource deletion successful!" }, None)
else:
logger.info('FAILED!')
send(event, context, "FAILED", { "Message": "Unexpected event received from CloudFormation" }, None)
except Exception as e:
message = "Unexected error creating mapping: {}".format(e)
send(event, context, "FAILED", { "Message": message }, None)
return status