X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=c5c719e6138663e77bc7cffe0baafccfed55c243;hb=ccc7b9c4b76a89faad66867b00d16ac45333b6de;hp=09fb9e214b5a39ddae399bf530c20a036be8933f;hpb=ab1947d3942ab4c821e6e1c99ca1fd6c03359df8;p=nodemanager.git diff --git a/Makefile b/Makefile index 09fb9e2..c5c719e 100644 --- a/Makefile +++ b/Makefile @@ -5,13 +5,23 @@ # Mark Huang # Copyright (C) 2006 The Trustees of Princeton University # -# $Id: Makefile,v 1.2 2006/11/13 20:04:44 mlhuang Exp $ -# # autoconf compatible variables datadir := /usr/share bindir := /usr/bin - +initdir=/etc/rc.d/init.d +systemddir := /usr/lib/systemd/system + +# call with either WITH_SYSTEMD=true or WITH_INIT=true +# otherwise we try to guess some reasonable default +ifeq "$(WITH_INIT)$(WITH_SYSTEMD)" "" +ifeq "$(wildcard $systemddir/*)" "" +WITH_INIT=true +else +WITH_SYSTEMD=true +endif +endif +#################### all: forward_api_calls python setup.py build @@ -19,20 +29,83 @@ forward_api_calls: forward_api_calls.c $(CC) -Wall -Os -o $@ $? strip $@ -install: +#################### install +install: install-miscell install-startup python setup.py install \ - --install-purelib=$(DESTDIR)/$(datadir)/NodeManager \ - --install-platlib=$(DESTDIR)/$(datadir)/NodeManager \ - --install-scripts=$(DESTDIR)/$(bindir) - install -m 444 README $(DESTDIR)/$(datadir)/NodeManager + --install-purelib=$(DESTDIR)/$(datadir)/NodeManager \ + --install-platlib=$(DESTDIR)/$(datadir)/NodeManager \ + --install-scripts=$(DESTDIR)/$(bindir) + +# might be better in setup.py ? +# NOTE: the sliver-initscripts/ and sliver-systemd stuff, being, well, for slivers, +# need to ship on all nodes regardless of WITH_INIT and WITH_SYSTEMD that +# impacts how nodemanager itself gets started +install-miscell: + install -d -m 755 $(DESTDIR)/var/lib/nodemanager + install -D -m 644 /dev/null $(DESTDIR)/etc/sysconfig/nodemanager + install -D -m 444 README $(DESTDIR)/$(datadir)/NodeManager/README + install -D -m 644 logrotate/nodemanager $(DESTDIR)/etc/logrotate.d/nodemanager + mkdir -p $(DESTDIR)/$(datadir)/NodeManager/sliver-initscripts + rsync -av sliver-initscripts/ $(DESTDIR)/$(datadir)/NodeManager/sliver-initscripts/ + chmod 755 $(DESTDIR)/$(datadir)/NodeManager/sliver-initscripts/ + mkdir -p $(DESTDIR)/$(datadir)/NodeManager/sliver-systemd + rsync -av sliver-systemd/ $(DESTDIR)/$(datadir)/NodeManager/sliver-systemd/ + chmod 755 $(DESTDIR)/$(datadir)/NodeManager/sliver-systemd/ + +# this now is for the startup of nodemanager itself +ifneq "$(WITH_SYSTEMD)" "" +install-startup: install-systemd +endif +ifneq "$(WITH_INIT)" "" +install-startup: install-init +endif + +install-init: + mkdir -p $(DESTDIR)$(initdir) + chmod 755 initscripts/* + rsync -av initscripts/ $(DESTDIR)$(initdir)/ +install-systemd: + mkdir -p $(DESTDIR)/$(systemddir) + rsync -av systemd/ $(DESTDIR)/$(systemddir) + +#################### clean clean: python setup.py clean rm -f forward_api_calls *.pyc build .PHONY: all install clean -########## +#################### debian-related +# This is called from the build with the following variables set +# (see build/Makefile and target_debian) +# (.) RPMTARBALL +# (.) RPMVERSION +# (.) RPMRELEASE +# (.) RPMNAME +DEBVERSION=$(RPMVERSION).$(RPMRELEASE) +DEBTARBALL=../$(RPMNAME)_$(DEBVERSION).orig.tar.bz2 +DATE=$(shell date -u +"%a, %d %b %Y %T") +force: + +debian: DESTDIR=debian/tmp +debian: forward_api_calls install debian/changelog debian.source debian.package + +debian/changelog: debian/changelog.in + sed -e "s|@VERSION@|$(DEBVERSION)|" -e "s|@DATE@|$(DATE)|" debian/changelog.in > debian/changelog + +debian.source: force + rsync -a $(RPMTARBALL) $(DEBTARBALL) + +debian.package: + debuild --set-envvar PREFIX=/usr -uc -us -b + +debian.clean: + $(MAKE) -f debian/rules clean + rm -rf build/ MANIFEST ../*.tar.gz ../*.dsc ../*.build + find . -name '*.pyc' -delete + +################################################## devel-oriented tags: (find . '(' -name '*.py' -o -name '*.c' -o -name '*.spec' ')' ; ls initscripts/*) | xargs etags @@ -40,8 +113,17 @@ tags: ########## sync # for use with the test framework; push local stuff on a test node -# make sync NODE=vnode01.inria.fr -# specify TESTMASTER and BUILD if the key is not available yet +# howto use: go on testmaster in the build you want to use and just run +# $ exp +# cut'n paste the result in a terminal in your working dir, e.g. (although all are not required) +# $ export BUILD=2013.07.02--lxc18 +# $ export PLCHOSTLXC=gotan.pl.sophia.inria.fr +# $ export GUESTNAME=2013.07.02--lxc18-1-vplc01 +# $ export GUESTHOSTNAME=vplc01.pl.sophia.inria.fr +# $ export KVMHOST=kvm64-6.pl.sophia.inria.fr +# $ export NODE=vnode01.pl.sophia.inria.fr +# and then just run +# $ make sync LOCAL_RSYNC_EXCLUDES := --exclude '*.pyc' RSYNC_EXCLUDES := --exclude .git --exclude .svn --exclude '*~' --exclude TAGS $(LOCAL_RSYNC_EXCLUDES) @@ -52,22 +134,56 @@ ifdef NODE NODEURL:=root@$(NODE):/ endif -sync: $(NODE).key.rsa +# this is for lxc only, we need to exclude the vs stuff that otherwise messes up everything on node +# WARNING: keep this in sync with setup.spec +LXC_EXCLUDES= --exclude sliver_vs.py --exclude coresched_vs.py --exclude drl.py + +# run with make SYNC_RESTART=false if you want to skip restarting nm +SYNC_RESTART=true + +sync:synclxc + +synclxc: $(NODE).key.rsa ifeq (,$(NODEURL)) @echo "sync: You must define NODE on the command line" @echo " e.g. make sync NODE=vnode01.inria.fr" @exit 1 else - +$(RSYNC) ./ $(NODEURL)/usr/share/NodeManager/ - +$(RSYNC) ./initscripts/nm $(NODEURL)/etc/init.d/nm + @echo xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx + @echo WARNING : this target might not be very reliable - use with care + @echo xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx + +$(RSYNC) $(LXC_EXCLUDES) --delete-excluded ./ $(NODEURL)/usr/share/NodeManager/ +# +$(RSYNC) ./initscripts/ $(NODEURL)/etc/init.d/ + +$(RSYNC) ./systemd/ $(NODEURL)/usr/lib/systemd/system/ + -$(SYNC_RESTART) && { ssh -i $(NODE).key.rsa root@$(NODE) service nm restart ; } ||: endif +# this is for vs only, we need to exclude the lxc stuff that otherwise messes up everything on node +# xxx keep this in sync with setup.spec +VS_EXCLUDES= --exclude sliver_libvirt.py --exclude sliver_lxc.py --exclude cgroups.py --exclude coresched_lxc.py --exclude privatebridge.py + +syncvs: $(NODE).key.rsa +ifeq (,$(NODEURL)) + @echo "syncvs: You must define NODE on the command line" + @echo " e.g. make sync NODE=vnode01.inria.fr" + @exit 1 +else + @echo xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx + @echo WARNING : this target might not be very reliable - use with care + @echo xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx + +$(RSYNC) $(VS_EXCLUDES) --delete-excluded ./ $(NODEURL)/usr/share/NodeManager/ + +$(RSYNC) ./initscripts/ $(NODEURL)/etc/init.d/ +# +$(RSYNC) ./systemd/ $(NODEURL)/usr/lib/systemd/system/ + -$(SYNC_RESTART) && { ssh -i $(NODE).key.rsa root@$(NODE) service nm restart ; } ||: +endif + + ### fetching the key TESTMASTER ?= testmaster.onelab.eu ifdef BUILD -KEYURL:=root@$(TESTMASTER):$(BUILD)/keys/key1.rsa +KEYURL:=root@$(TESTMASTER):$(BUILD)/keys/key_admin.rsa endif key: $(NODE).key.rsa @@ -83,15 +199,10 @@ else +scp $(KEYURL) $@ endif -### utility - find out the node name for a given BUILD +########## exp. too +SLICE=inri_sl1 -ifdef BUILD -NODEIPCOMMAND:=ssh root@$(TESTMASTER) cat $(BUILD)/arg-ips-node -endif - -nodename: -ifeq (,$(NODEIPCOMMAND)) - @echo "nodename: You must define TESTMASTER and BUILD on the command line" -else - $(NODEIPCOMMAND) -endif +syncvinit: + $(RSYNC) sliver-systemd/vinit.st* $(NODEURL)/vservers/$(SLICE)/usr/bin/ + $(RSYNC) sliver-systemd/vinit.service $(NODEURL)/vservers/$(SLICE)/usr/lib/systemd/system/ + echo "remember to run 'systemctl --system daemon-reload' within this slice"