224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
|
# File 'lib/new_relic/agent/system_info.rb', line 224
def self.parse_docker_container_id(cgroup_info)
cpu_cgroup = parse_cgroup_ids(cgroup_info)['cpu']
return unless cpu_cgroup
container_id = case cpu_cgroup
when /[0-9a-f]{64,}/
if $&.length == 64
$&
else ::NewRelic::Agent.logger.debug("Ignoring docker ID of invalid length: '#{cpu_cgroup}'")
return
end
when '/' then nil
when /docker\/.*[^0-9a-f]/
::NewRelic::Agent.logger.debug("Cgroup indicates docker but container_id has invalid characters: '#{cpu_cgroup}'")
return
when /docker/
::NewRelic::Agent.logger.debug("Cgroup indicates docker but container_id unrecognized: '#{cpu_cgroup}'")
::NewRelic::Agent.increment_metric('Supportability/utilization/docker/error')
return
else
::NewRelic::Agent.logger.debug("Ignoring unrecognized cgroup ID format: '#{cpu_cgroup}'")
return
end
if container_id && container_id.size != 64
::NewRelic::Agent.logger.debug("Found docker container_id with invalid length: #{container_id}")
::NewRelic::Agent.increment_metric('Supportability/utilization/docker/error')
nil
else
container_id
end
end
|