blob: c777a702a393b6acafce6f5ee0b18873b6277201 (
plain)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
#!/bin/sh
# PROVIDE: kafka_connect
# REQUIRE: NETWORKING SERVERS DAEMON
# KEYWORD: shutdown
#
# Add kafka_connect_enable="YES" to /etc/rc.conf to enable Kafka Connect:
#
# Additional variables you can define are:
#
# kafka_connect_user: Username to run Kafka Connect
# Default: %%KAFKA_USER%%
# kafka_connect_group: Group to run Kafka Connect
# Default: %%KAFKA_GROUP%%
# kafka_connect_config: Configuration file to run Kafka Connect
# Default: %%ETCDIR%%/connect.properties
# kafka_connect_log4j_config: Configuration file for Kafka Connect logging
# Default: %%ETCDIR%%/connect-log4j.properties
# kafka_connect_log_dir: Directory to store Kafka Connect logs
# Default: %%KAFKA_LOGDIR%%
# kafka_connect_java_opts: Options passed to JVM to start Kafka Connect
# Default: None
# kafka_connect_pidfile: Full path of the Kafka Connect process PID file
# Default: /var/run/kafka_connect.pid
# kafka_connect_syslog_output_enable: Set to enable syslog output.
# Default: YES
# kafka_connect_syslog_output_tag: Set syslog tag if syslog enabled.
# Default: kafka_connect
# kafka_connect_syslog_output_priority: Set syslog priority if syslog enabled.
# Default: info
# kafka_connect_syslog_output_facility: Set syslog facility if syslog enabled.
# Default: daemon
. /etc/rc.subr
name=kafka_connect
rcvar=kafka_connect_enable
load_rc_config "${name}"
: ${kafka_connect_enable:="NO"}
: ${kafka_connect_user:="%%KAFKA_USER%%"}
: ${kafka_connect_group:="%%KAFKA_GROUP%%"}
: ${kafka_connect_config:="%%ETCDIR%%/connect.properties"}
: ${kafka_connect_log4j_config:="%%ETCDIR%%/connect-log4j.properties"}
: ${kafka_connect_log_dir:="%%KAFKA_LOGDIR%%"}
: ${kafka_connect_pidfile:=/var/run/kafka_connect.pid}
: ${kafka_connect_syslog_output_enable:="YES"}
: ${kafka_connect_standalone:="YES"}
start_precmd="kafka_connect_start_precmd"
if checkyesno kafka_connect_syslog_output_enable; then
if [ -n "${kafka_syslog_output_tag}" ]; then
kafka_connect_syslog_output_flags="-T ${kafka_connect_syslog_output_tag}"
else
kafka_connect_syslog_output_flags="-T ${name}"
fi
if [ -n "${kafka_connect_syslog_output_priority}" ]; then
kafka_connect_syslog_output_flags="${kafka_connect_syslog_output_flags} -s ${kafka_connect_syslog_output_priority}"
fi
if [ -n "${kafka_connect_syslog_output_facility}" ]; then
kafka_connect_syslog_output_flags="${kafka_connect_syslog_output_flags} -l ${kafka_connect_syslog_output_facility}"
fi
fi
if checkyesno kafka_connect_standalone; then
kafka_connect_class="org.apache.kafka.connect.cli.ConnectStandalone"
else
kafka_connect_class="org.apache.kafka.connect.cli.ConnectDistributed"
fi
JAVA="%%JAVA%%"
CLASSPATH=":%%DATADIR%%/libs/*"
kafka_connect_log_opts="-Dkafka_connect.log.dir=${kafka_connect_log_dir} -Dlog4j.configuration=file:${kafka_connect_log4j_config}"
kafka_connect_main="${kafka_connect_java_opts} ${kafka_connect_log_opts} -cp ${CLASSPATH} ${kafka_connect_class} ${kafka_connect_config}"
pidfile="${kafka_connect_pidfile}"
required_dirs="${kafka_connect_log_dir}"
required_files="${kafka_connect_config} ${kafka_connect_log4j_config}"
command="/usr/sbin/daemon"
command_args="-f ${kafka_connect_syslog_output_flags} -P ${pidfile} -t ${name} ${JAVA} ${kafka_connect_main}"
kafka_connect_start_precmd()
{
if [ ! -e "${pidfile}" ]; then
install -m 0600 -o "${kafka_connect_user}" -g "${kafka_connect_group}" /dev/null "${pidfile}"
fi
}
run_rc_command "$1"
|