forked from cloudfoundry/java-buildpack
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathkilljava
More file actions
executable file
·59 lines (50 loc) · 1.8 KB
/
killjava
File metadata and controls
executable file
·59 lines (50 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#!/usr/bin/env ruby
# Encoding: utf-8
# Cloud Foundry Java Buildpack
# Copyright (c) 2013 the original author or authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# Kill script for use as the parameter of OpenJDK's -XX:OnOutOfMemoryError.
#
# It should be placed in the buildpack diagnostic directory so it logs to
# the same log file as the rest of the buildpack.
require 'time'
$stdout.sync = true
module Kill
def self.log(log_data)
log_file_name = "#{File.dirname(__FILE__)}/@@LOG_FILE_NAME@@"
File.open(log_file_name, 'a') do |log_file|
log_file.sync = true
log_file.write "#{log_data} @ #{Kill.time_in_millis}\n"
log_file.fsync
end
end
def self.time_in_millis
Time.now.xmlschema(3).sub(/T/, ' ')
end
def self.log_process_tree
Kill.log(`ps -AHF`)
end
end
begin
Kill.log_process_tree
# Kill all processes whose parameters match -XX:OnOutOfMemoryError and the name of this script.
# This script can be renamed as necessary without modifying its code.
command = "pkill -9 -f .*-XX:OnOutOfMemoryError=.*#{File.basename(__FILE__)}.*"
Kill.log("#{__FILE__} attempting to kill Java processes using `#{command}`")
system command
Kill.log_process_tree
rescue => e
Kill.log("#{__FILE__} failed with exception #{e.inspect}, #{e.backtrace}\n")
abort e.message
end