diff options
author | Tom Judge <tj@FreeBSD.org> | 2012-12-08 20:48:41 +0000 |
---|---|---|
committer | Tom Judge <tj@FreeBSD.org> | 2012-12-08 20:48:41 +0000 |
commit | ce7b1a077535a88b887842cf6372f8c4dad8010d (patch) | |
tree | 3955dbafb41bf3b22e05cff3371eaefc9a1b09c6 /textproc/elasticsearch/files | |
parent | - Update to 0.04 (diff) |
Elasticsearch aims to be a Distributed, RESTful, Search Engine built on
top of
Apache Lucene.
WWW: http://www.elasticsearch.org/
PR: ports/168515
Feature safe: yes
Approved by: eadler (mentor)
Diffstat (limited to 'textproc/elasticsearch/files')
-rw-r--r-- | textproc/elasticsearch/files/elasticsearch-plugin.in | 17 | ||||
-rw-r--r-- | textproc/elasticsearch/files/elasticsearch.in | 127 | ||||
-rw-r--r-- | textproc/elasticsearch/files/patch-config-elasticsearch.yml | 35 |
3 files changed, 179 insertions, 0 deletions
diff --git a/textproc/elasticsearch/files/elasticsearch-plugin.in b/textproc/elasticsearch/files/elasticsearch-plugin.in new file mode 100644 index 000000000000..5f076c49f349 --- /dev/null +++ b/textproc/elasticsearch/files/elasticsearch-plugin.in @@ -0,0 +1,17 @@ +#!/bin/sh +# +# $FreeBSD$ +. /etc/rc.subr + +name=elasticsearch +rcvar=elasticsearch_enable +load_rc_config $name + +: ${elasticsearch_config:="%%PREFIX%%/etc/elasticsearch/elasticsearch.yml"} + +ES_LIB="%%PREFIX%%/lib/elasticsearch" +ES_CLASSPATH=$ES_LIB/elasticsearch-0.19.9.jar:$ES_LIB/*:$ES_LIB/sigar/* + +JAVA=%%LOCALBASE%%/bin/java + +exec $JAVA $JAVA_OPTS -Xmx64m -Xms16m -Delasticsearch -Des.config=${elasticsearch_config} -cp $ES_CLASSPATH org.elasticsearch.plugins.PluginManager $* diff --git a/textproc/elasticsearch/files/elasticsearch.in b/textproc/elasticsearch/files/elasticsearch.in new file mode 100644 index 000000000000..97a9a50e0c5f --- /dev/null +++ b/textproc/elasticsearch/files/elasticsearch.in @@ -0,0 +1,127 @@ +#!/bin/sh +# +# $FreeBSD$ +# +# PROVIDE: elasticsearch +# REQUIRE: NETWORKING SERVERS +# BEFORE: DAEMON +# KEYWORD: shutdown +# +# Add the following line to /etc/rc.conf to enable elasticsearch: +# +# elasticsearch_enable="YES" +# +# elasticsearch_user (username): Set to elasticsearch by default. +# Set it to required username. +# elasticsearch_group (group): Set to elasticsearch by default. +# Set it to required group. +# elasticsearch_config (path): Set to /usr/local/etc/elasticsearch/elasticsearch.yml by default. +# Set it to the config file location. +# elasticsearch_min_mem (num): Minumum JVM heap size, 256m by default. +# elasticsearch_max_mem (num): Maximum JVM heap size, 1g by default. +# elasticsearch_props (args): Additional java properties or arguments. +# elasticsearch_tmp (path): Set to /var/tmp/elasticsearch by default. +# Set it to the path to be used for temp files. +# +. /etc/rc.subr + +name=elasticsearch +rcvar=elasticsearch_enable +load_rc_config $name + +: ${elasticsearch_enable:="NO"} +: ${elasticsearch_user:=%%SEARCHUSER%%} +: ${elasticsearch_group:=%%SEARCHGROUP%%} +: ${elasticsearch_config:="%%PREFIX%%/etc/elasticsearch/elasticsearch.yml"} +: ${elasticsearch_min_mem:="256m"} +: ${elasticsearch_max_mem:="1g"} +: ${elasticsearch_props:=""} +: ${elasticsearch_tmp:="/var/tmp/elasticsearch"} + +# Force the JVM to use IPv4 stack +# elasticshearch_props"-Djava.net.preferIPv4Stack=true" + +required_files="${elasticsearch_config}" +pidfile="/var/run/${name}.pid" + +ES_LIB="%%PREFIX%%/lib/elasticsearch" +ES_CLASSPATH=$ES_LIB/elasticsearch-0.19.9.jar:$ES_LIB/*:$ES_LIB/sigar/* + + +java_options=" -server \ + -Xms${elasticsearch_min_mem} \ + -Xmx${elasticsearch_max_mem} \ + -Xss256k \ + -Djava.awt.headless=true \ + -XX:+UseParNewGC \ + -XX:+UseConcMarkSweepGC \ + -XX:CMSInitiatingOccupancyFraction=75 \ + -XX:+UseCMSInitiatingOccupancyOnly \ + -XX:+HeapDumpOnOutOfMemoryError \ + -Delasticsearch \ + -Des.config=${elasticsearch_config} \ + -cp ${ES_CLASSPATH}" + +extra_commands="console status" +console_cmd="elasticsearch_console" +start_precmd="elasticsearch_precmd" +status_cmd="elasticsearch_status" +stop_cmd="elasticsearch_stop" +command="/usr/sbin/daemon" +command_args="-f %%LOCALBASE%%/bin/java -Des.pidfile=${pidfile} ${elasticsearch_props} ${java_options} org.elasticsearch.bootstrap.ElasticSearch" + +elasticsearch_precmd() { + touch ${pidfile} + chown ${elasticsearch_user}:${elasticsearch_group} ${pidfile} + /usr/bin/install -d -o ${elasticsearch_user} -g ${elasticsearch_group} -m 750 ${elasticsearch_tmp} +} + +elasticsearch_console () { + %%LOCALBASE%%/bin/java -Des.foreground=yes ${elasticsearch_props} ${java_options} org.elasticsearch.bootstrap.ElasticSearch +} + + +elasticsearch_stop() { + rc_pid=$(elasticsearch_check_pidfile $pidfile) + + if [ -z "$rc_pid" ]; then + [ -n "$rc_fast" ] && return 0 + echo "${name} not running? (check $pidfile)." + return 1 + fi + + echo "Stopping ${name}." + kill ${rc_pid} 2> /dev/null +} + +elasticsearch_status() { + rc_pid=$(elasticsearch_check_pidfile $pidfile) + + if [ -z "$rc_pid" ]; then + [ -n "$rc_fast" ] && return 0 + echo "${name} not running? (check $pidfile)." + return 1 + fi + echo "${name} is running as pid ${rc_pid}." +} + +elasticsearch_check_pidfile() { + _pidfile=$1 + if [ -z "$_pidfile" ]; then + err 3 'USAGE: elasticsearch_check_pidfile pidfile' + fi + if [ ! -f $_pidfile ]; then + debug "pid file ($_pidfile): not readable." + return + fi + read _pid _junk < $_pidfile + if [ -z "$_pid" ]; then + debug "pid file ($_pidfile): no pid in file." + return + fi + if [ -n "`%%LOCALBASE%%/bin/jps -l | grep -e "^$_pid org.elasticsearch.bootstrap.ElasticSearch\$"`" ]; then + echo -n $_pid + fi +} +load_rc_config ${name} +run_rc_command "$1" diff --git a/textproc/elasticsearch/files/patch-config-elasticsearch.yml b/textproc/elasticsearch/files/patch-config-elasticsearch.yml new file mode 100644 index 000000000000..1c23ab037ead --- /dev/null +++ b/textproc/elasticsearch/files/patch-config-elasticsearch.yml @@ -0,0 +1,35 @@ +--- config/elasticsearch.yml.orig 2012-10-26 11:18:09.000000000 -0400 ++++ config/elasticsearch.yml 2012-10-26 11:25:29.000000000 -0400 +@@ -140,11 +140,11 @@ + + # Path to directory containing configuration (this file and logging.yml): + # +-# path.conf: /path/to/conf ++path.conf: %%PREFIX%%/etc/elasticsearch + + # Path to directory where to store index data allocated for this node. + # +-# path.data: /path/to/data ++path.data: /var/db/elasticsearch + # + # Can optionally include more than one location, causing data to be striped across + # the locations (à la RAID 0) on a file level, favouring locations with most free +@@ -154,15 +154,15 @@ + + # Path to temporary files: + # +-# path.work: /path/to/work ++path.work: /var/tmp/elasticsearch + + # Path to log files: + # +-# path.logs: /path/to/logs ++path.logs: /var/log/elasticsearch + + # Path to where plugins are installed: + # +-# path.plugins: /path/to/plugins ++path.plugins: %%PREFIX%%/lib/elasticsearch/plugins + + + #################################### Plugin ################################### |