Index: head/sysutils/docker-freebsd/Makefile =================================================================== --- head/sysutils/docker-freebsd/Makefile (revision 442738) +++ head/sysutils/docker-freebsd/Makefile (revision 442739) @@ -1,36 +1,37 @@ # Created by: kmoore@FreeBSD.org # $FreeBSD$ PORTNAME= docker-freebsd PORTVERSION= 20150625 +PORTREVISION= 1 CATEGORIES= sysutils MAINTAINER= amutu@amutu.com COMMENT= Docker containment system LICENSE= APACHE20 LICENSE_FILE= ${WRKSRC}/LICENSE BUILD_DEPENDS= go>=1.4:lang/go \ bash:shells/bash \ sqlite3:databases/sqlite3 RUN_DEPENDS= go>=1.4:lang/go \ bash:shells/bash \ sqlite3:databases/sqlite3 USE_GITHUB= yes GH_ACCOUNT= kvasdopil GH_PROJECT= docker GH_TAGNAME= 582db78 PLIST_FILES= bin/docker USE_RC_SUBR= docker do-build: @cd ${WRKSRC} && export AUTO_GOPATH=1 && export DOCKER_GITCOMMIT=${GH_TAGNAME} && ./hack/make.sh binary do-install: @${MKDIR} ${STAGEDIR}${PREFIX}/bin ${INSTALL_PROGRAM} ${WRKSRC}/bundles/latest/binary/docker ${STAGEDIR}${PREFIX}/bin/ .include Index: head/sysutils/docker-freebsd/files/docker.in =================================================================== --- head/sysutils/docker-freebsd/files/docker.in (revision 442738) +++ head/sysutils/docker-freebsd/files/docker.in (revision 442739) @@ -1,82 +1,83 @@ #!/bin/sh # PROVIDE: docker # REQUIRE: DAEMON # KEYWORD: nojail shutdown . /etc/rc.subr name="docker" rcvar="docker_enable" stop_cmd="docker_stop" start_cmd="docker_start" command="%%PREFIX%%/bin/docker" load_rc_config $name : ${docker_enable=NO} : ${docker_dir=/usr/docker} : ${docker_nat_pf=YES} : ${docker_nat_iface=NONE} +: ${docker_flags=} docker_start() { if [ ! -d "${docker_dir}" ] ; then echo "Missing ${docker_dir}! Please create / mount a ZFS dataset at this location." exit 1 fi if [ -e "/var/run/docker.pid" ] ; then pgrep -F /var/run/docker.pid 2>/dev/null >/dev/null if [ $? -eq 0 ] ; then echo "Docker already running? /var/run/docker.pid" exit 1 fi fi echo "Starting docker..." - daemon -p /var/run/docker.pid ${command} -d -e jail -s zfs -g ${docker_dir} -D >/var/log/docker.log 2>/var/log/docker.log + daemon -p /var/run/docker.pid ${command} -d -e jail -s zfs -g ${docker_dir} -D ${docker_flags} >/var/log/docker.log 2>/var/log/docker.log # Check for linux 64bit support and enable kldstat | grep -q 'linux64' if [ $? -ne 0 -a -e "/boot/kernel/linux64.ko" ] ; then kldload linux64 fi # Check for NAT support via PF # This is an ugly experimental hack for now, eventually will go away if [ "${docker_nat_pf}" != "YES" ] ; then return ; fi # Load PF if not already kldstat | grep -q 'pf.ko' if [ $? -ne 0 -a -e "/boot/kernel/pf.ko" ] ; then kldload pf fi # Check if PF rules already loaded /sbin/pfctl -s nat 2>/dev/null | grep -q 172.17 if [ $? -eq 0 ] ; then return ; fi if [ "${docker_nat_iface}" != "NONE" ] ; then iface="${docker_nat_iface}" else iface=`/usr/bin/netstat -f inet -nrW | grep '^default' | awk '{ print $6 }'` fi echo "nat on ${iface} from 172.17.0.0/16 to any -> (${iface})" > /tmp/pf-nat-docker.$$ /sbin/pfctl -f /tmp/pf-nat-docker.$$ 2>/dev/null /sbin/pfctl -e 2>/dev/null rm /tmp/pf-nat-docker.$$ } docker_stop() { if [ -e "/var/run/docker.pid" ] ; then echo "Stopping docker..." pkill -F /var/run/docker.pid fi } run_rc_command "$1"