sharder: fix host logged when send_shard_ranges fails
The ContainerSharder._send_shard_ranges method sets an 'x-backend-use-replication-network' header with value 'true', so if the PUT to the root container fails the log message should show the replication ip and port of the container server. Change-Id: I8c84f6ee15e6999f71b092bbeed414065a22ee8b
This commit is contained in:
parent
e15d6880e8
commit
6885b33676
@ -38,7 +38,8 @@ from swift.common.swob import str_to_wsgi
|
||||
from swift.common.utils import get_logger, config_true_value, \
|
||||
dump_recon_cache, whataremyips, Timestamp, ShardRange, GreenAsyncPile, \
|
||||
config_positive_int_value, quorum_size, parse_override_options, \
|
||||
Everything, config_auto_int_value, ShardRangeList, config_percent_value
|
||||
Everything, config_auto_int_value, ShardRangeList, config_percent_value, \
|
||||
node_to_string
|
||||
from swift.container.backend import ContainerBroker, \
|
||||
RECORD_TYPE_SHARD, UNSHARDED, SHARDING, SHARDED, COLLAPSED, \
|
||||
SHARD_UPDATE_STATES, sift_shard_ranges, SHARD_UPDATE_STAT_STATES
|
||||
@ -1196,13 +1197,13 @@ class ContainerSharder(ContainerSharderConf, ContainerReplicator):
|
||||
headers=headers, contents=body)
|
||||
except DirectClientException as err:
|
||||
self.warning(broker,
|
||||
'Failed to put shard ranges to %s:%s/%s %s/%s: %s',
|
||||
node['ip'], node['port'], node['device'],
|
||||
'Failed to put shard ranges to %s %s/%s: %s',
|
||||
node_to_string(node, replication=True),
|
||||
quote(account), quote(container), err.http_status)
|
||||
except (Exception, Timeout) as err:
|
||||
self.exception(broker,
|
||||
'Failed to put shard ranges to %s:%s/%s %s/%s: %s',
|
||||
node['ip'], node['port'], node['device'],
|
||||
'Failed to put shard ranges to %s %s/%s: %s',
|
||||
node_to_string(node, replication=True),
|
||||
quote(account), quote(container), err)
|
||||
else:
|
||||
return True
|
||||
|
@ -5187,14 +5187,14 @@ class TestSharder(BaseTestSharder):
|
||||
self.assertTrue(
|
||||
req_headers['User-Agent'].startswith('container-sharder'))
|
||||
self.assertEqual(sharder.ring.replica_count, len(hosts))
|
||||
return res, sharder
|
||||
return res, sharder, hosts
|
||||
|
||||
replicas = 3
|
||||
res, sharder = do_test(replicas, 202, 202, 202)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, 202)
|
||||
self.assertTrue(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 202, 202, 404)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, 404)
|
||||
self.assertTrue(res)
|
||||
self.assertEqual([True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5203,7 +5203,7 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 202, 202, Exception)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, Exception)
|
||||
self.assertTrue(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True], [
|
||||
@ -5212,7 +5212,7 @@ class TestSharder(BaseTestSharder):
|
||||
self.assertEqual([True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(replicas, 202, 404, 404)
|
||||
res, sharder, _ = do_test(replicas, 202, 404, 404)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5221,23 +5221,21 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 500, 500, 500)
|
||||
res, sharder, hosts = do_test(replicas, 500, 500, 500)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True, True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertEqual([True, True, True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertEqual(set(
|
||||
'Failed to put shard ranges to %s a/c: 500, path: a/c, db: %s' %
|
||||
(host, broker.db_file) for host in hosts),
|
||||
set(sharder.logger.get_lines_for_level('warning')))
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, Exception, Exception, 202)
|
||||
res, sharder, _ = do_test(replicas, Exception, Exception, 202)
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
self.assertEqual([True, True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(replicas, Exception, eventlet.Timeout(), 202)
|
||||
res, sharder, _ = do_test(replicas, Exception, eventlet.Timeout(), 202)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5247,11 +5245,11 @@ class TestSharder(BaseTestSharder):
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
|
||||
replicas = 2
|
||||
res, sharder = do_test(replicas, 202, 202)
|
||||
res, sharder, _ = do_test(replicas, 202, 202)
|
||||
self.assertTrue(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 202, 404)
|
||||
res, sharder, _ = do_test(replicas, 202, 404)
|
||||
self.assertTrue(res)
|
||||
self.assertEqual([True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5260,7 +5258,7 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 202, Exception)
|
||||
res, sharder, _ = do_test(replicas, 202, Exception)
|
||||
self.assertTrue(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True], [
|
||||
@ -5269,7 +5267,7 @@ class TestSharder(BaseTestSharder):
|
||||
self.assertEqual([True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(replicas, 404, 404)
|
||||
res, sharder, _ = do_test(replicas, 404, 404)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5278,16 +5276,14 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, Exception, Exception)
|
||||
res, sharder, hosts = do_test(replicas, Exception, Exception)
|
||||
self.assertFalse(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
self.assertEqual([True, True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(replicas, eventlet.Timeout(), Exception)
|
||||
self.assertEqual(set(
|
||||
'Failed to put shard ranges to %s a/c: FakeStatus Error, '
|
||||
'path: a/c, db: %s: ' % (host, broker.db_file) for host in hosts),
|
||||
set(sharder.logger.get_lines_for_level('error')))
|
||||
res, sharder, _ = do_test(replicas, eventlet.Timeout(), Exception)
|
||||
self.assertFalse(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True, True], [
|
||||
@ -5298,11 +5294,11 @@ class TestSharder(BaseTestSharder):
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
|
||||
replicas = 4
|
||||
res, sharder = do_test(replicas, 202, 202, 202, 202)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, 202, 202)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
self.assertTrue(res)
|
||||
res, sharder = do_test(replicas, 202, 202, 404, 404)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, 404, 404)
|
||||
self.assertTrue(res)
|
||||
self.assertEqual([True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5311,7 +5307,7 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 202, 202, Exception, Exception)
|
||||
res, sharder, _ = do_test(replicas, 202, 202, Exception, Exception)
|
||||
self.assertTrue(res)
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('warning'))
|
||||
self.assertEqual([True, True], [
|
||||
@ -5320,7 +5316,7 @@ class TestSharder(BaseTestSharder):
|
||||
self.assertEqual([True, True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(replicas, 202, 404, 404, 404)
|
||||
res, sharder, _ = do_test(replicas, 202, 404, 404, 404)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True, True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5329,7 +5325,7 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, 500, 500, 500, 202)
|
||||
res, sharder, _ = do_test(replicas, 500, 500, 500, 202)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True, True, True], [
|
||||
'Failed to put shard ranges' in line for line in
|
||||
@ -5338,7 +5334,7 @@ class TestSharder(BaseTestSharder):
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('warning')])
|
||||
self.assertFalse(sharder.logger.get_lines_for_level('error'))
|
||||
res, sharder = do_test(replicas, Exception, Exception, 202, 404)
|
||||
res, sharder, _ = do_test(replicas, Exception, Exception, 202, 404)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True], [
|
||||
all(msg in line for msg in ('Failed to put shard ranges', '404'))
|
||||
@ -5352,7 +5348,7 @@ class TestSharder(BaseTestSharder):
|
||||
self.assertEqual([True, True], [
|
||||
'path: a/c, db: %s' % broker.db_file in line for line in
|
||||
sharder.logger.get_lines_for_level('error')])
|
||||
res, sharder = do_test(
|
||||
res, sharder, _ = do_test(
|
||||
replicas, eventlet.Timeout(), eventlet.Timeout(), 202, 404)
|
||||
self.assertFalse(res)
|
||||
self.assertEqual([True], [
|
||||
|
Loading…
Reference in New Issue
Block a user