Compare commits
164 Commits
release-4.
...
lib-vs-sha
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
555ce383d3 | ||
|
|
b29117be02 | ||
|
|
ff7ded28e8 | ||
|
|
f0691c9a38 | ||
|
|
76d9d59510 | ||
|
|
5342b04ac7 | ||
|
|
01e525106b | ||
|
|
5146706536 | ||
|
|
dfa32a97ca | ||
|
|
c409759745 | ||
|
|
149b92af77 | ||
|
|
a4b3c9c568 | ||
|
|
dbb9124666 | ||
|
|
f2d30eaa63 | ||
|
|
0709308c1f | ||
|
|
d3baf1f8ba | ||
|
|
d7f219f160 | ||
|
|
bc054b1b02 | ||
|
|
f18285943c | ||
|
|
780839988d | ||
|
|
025e20a1f1 | ||
|
|
9330b79d51 | ||
|
|
979b6fb166 | ||
|
|
57c7d13c48 | ||
|
|
1de424a69d | ||
|
|
505950dae0 | ||
|
|
0c8b5d25c4 | ||
|
|
bce580658e | ||
|
|
b451260f0d | ||
|
|
af6e1435aa | ||
|
|
290ca33840 | ||
|
|
a1838d9030 | ||
|
|
30ae761c27 | ||
|
|
9182aaccb7 | ||
|
|
a2aa1b8a02 | ||
|
|
03506de7e4 | ||
|
|
f71460358b | ||
|
|
8c2a2878df | ||
|
|
2e69bee531 | ||
|
|
e985d4151b | ||
|
|
a4a4b7a8e7 | ||
|
|
a297aa4f5b | ||
|
|
6423a67982 | ||
|
|
4dbb6fe189 | ||
|
|
d38718b24b | ||
|
|
53c013f1cc | ||
|
|
6a59d0fd9b | ||
|
|
4e7f58785f | ||
|
|
e240c63c8b | ||
|
|
c39628cbe4 | ||
|
|
73dabead05 | ||
|
|
ce1624b83e | ||
|
|
97553c50fb | ||
|
|
3456849ec8 | ||
|
|
dc5b36f8ef | ||
|
|
00623e2327 | ||
|
|
c6caa0a0ad | ||
|
|
13dbf65793 | ||
|
|
d6144d45ea | ||
|
|
b682ad1817 | ||
|
|
61df2a6c51 | ||
|
|
c1e7cb717a | ||
|
|
a223eedf0b | ||
|
|
987cf32458 | ||
|
|
dd15b27b85 | ||
|
|
0defc0f0e3 | ||
|
|
1f70c8f5d7 | ||
|
|
39c6bb5974 | ||
|
|
02240309b3 | ||
|
|
ed2c2d5a14 | ||
|
|
931f88f99a | ||
|
|
5d0bd617e0 | ||
|
|
70e0115f94 | ||
|
|
1d16c86eba | ||
|
|
e15d6cfd5e | ||
|
|
ae33f60680 | ||
|
|
459f418f12 | ||
|
|
448a176e58 | ||
|
|
0a7544c57a | ||
|
|
4830ce8b8a | ||
|
|
00b316a2c4 | ||
|
|
1efbc72676 | ||
|
|
8bd56bd67e | ||
|
|
ab9b033068 | ||
|
|
16dd2d9f2f | ||
|
|
00bb137012 | ||
|
|
4c3e4abff7 | ||
|
|
6b64dcc122 | ||
|
|
9a9fa39f69 | ||
|
|
ffa0ac5681 | ||
|
|
b5499e48b4 | ||
|
|
2d79f13714 | ||
|
|
de9d3f2814 | ||
|
|
9da26382f4 | ||
|
|
85f7d1b9fe | ||
|
|
d2f935b823 | ||
|
|
68d548ef60 | ||
|
|
ea23c79431 | ||
|
|
76fbd23423 | ||
|
|
494ec02a7c | ||
|
|
83eede665c | ||
|
|
8f1f298551 | ||
|
|
e57e7f16eb | ||
|
|
b54d5b84f9 | ||
|
|
b99ca853e1 | ||
|
|
e7b710d43a | ||
|
|
6f2814f414 | ||
|
|
874d1fcfb0 | ||
|
|
814adbd85a | ||
|
|
74ef51eb26 | ||
|
|
ff4620c39a | ||
|
|
bac1d6c63b | ||
|
|
0842ddd128 | ||
|
|
026e47ac83 | ||
|
|
b116f1cca7 | ||
|
|
a87b0d1b2c | ||
|
|
80edc04573 | ||
|
|
3b7750e9a9 | ||
|
|
a7cc86c567 | ||
|
|
442021849d | ||
|
|
446e157b80 | ||
|
|
1dbb1f191f | ||
|
|
adca82e808 | ||
|
|
324fff9f7e | ||
|
|
7b908a4069 | ||
|
|
b233cb614d | ||
|
|
8523d76c14 | ||
|
|
35477c6172 | ||
|
|
b692dbbe75 | ||
|
|
26b4c1ed90 | ||
|
|
7860d5ac4e | ||
|
|
bb54ee7868 | ||
|
|
6a5506768c | ||
|
|
d6e33edb5b | ||
|
|
611d6c4eb4 | ||
|
|
0cde7cdf39 | ||
|
|
cde5617a29 | ||
|
|
74411f970b | ||
|
|
3383b6dacf | ||
|
|
d9f8a3fc31 | ||
|
|
5703f8b5c9 | ||
|
|
f67c7e25c8 | ||
|
|
8dbd0ef7dc | ||
|
|
58a050218f | ||
|
|
3ce7398cf6 | ||
|
|
0ec64f6926 | ||
|
|
fa9a420490 | ||
|
|
c212cfb08f | ||
|
|
c400b6644a | ||
|
|
917d3d6b2a | ||
|
|
8ba16d0e7a | ||
|
|
f58a9faa6a | ||
|
|
b1476676fe | ||
|
|
a23f31077a | ||
|
|
34ccb63f64 | ||
|
|
ed91f1fc43 | ||
|
|
65d76b6aa4 | ||
|
|
0f71f545df | ||
|
|
2de01d8cbc | ||
|
|
1d45cd33ab | ||
|
|
eabb327786 | ||
|
|
8835b9134b | ||
|
|
fec2114caf | ||
|
|
24cd27b737 |
4
.gitignore
vendored
4
.gitignore
vendored
@@ -5,7 +5,6 @@
|
|||||||
.*
|
.*
|
||||||
# but we _wan't_ those dot-files
|
# but we _wan't_ those dot-files
|
||||||
!.gitignore
|
!.gitignore
|
||||||
!.hgignore
|
|
||||||
!.mailmap
|
!.mailmap
|
||||||
|
|
||||||
# ChangeLog is generated during make
|
# ChangeLog is generated during make
|
||||||
@@ -29,3 +28,6 @@
|
|||||||
|
|
||||||
# backups created by "make update-version"
|
# backups created by "make update-version"
|
||||||
*.bak
|
*.bak
|
||||||
|
|
||||||
|
# Devel::Cover cache
|
||||||
|
cover_db/
|
||||||
|
|||||||
27
BUGS
27
BUGS
@@ -1,27 +0,0 @@
|
|||||||
|
|
||||||
Reporting Bugs
|
|
||||||
--------------
|
|
||||||
|
|
||||||
To report a bug please use the xen-tools-discuss mailing list:
|
|
||||||
|
|
||||||
http://xen-tools.org/software/xen-tools/lists.html
|
|
||||||
|
|
||||||
If you're capable of fixing it yourself a patch is appreciated,
|
|
||||||
and a test case would be a useful bonus.
|
|
||||||
|
|
||||||
|
|
||||||
Known Bugs
|
|
||||||
----------
|
|
||||||
|
|
||||||
The Debian bug tracker contains a list of all currently
|
|
||||||
open issues which have been reported by the users of the Debian
|
|
||||||
package (the primary user-base):
|
|
||||||
|
|
||||||
http://bugs.debian.org/xen-tools
|
|
||||||
|
|
||||||
If you're running the code on a Debian host system then reporting
|
|
||||||
bugs against this package is a good thing to do; by doing so you
|
|
||||||
allow others to view issues, and I check the bug-page regularly.
|
|
||||||
|
|
||||||
Steve
|
|
||||||
--
|
|
||||||
23
BUGS.markdown
Normal file
23
BUGS.markdown
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
Reporting Bugs
|
||||||
|
==============
|
||||||
|
|
||||||
|
To report a bug please use the [xen-tools-discuss* mailing
|
||||||
|
list](http://xen-tools.org/software/xen-tools/lists.html).
|
||||||
|
|
||||||
|
If you're capable of fixing it yourself a patch is appreciated, and a
|
||||||
|
test case would be a useful bonus.
|
||||||
|
|
||||||
|
|
||||||
|
Known Bugs
|
||||||
|
==========
|
||||||
|
|
||||||
|
The Debian bug tracker contains a [list of all currently open
|
||||||
|
issues](http://bugs.debian.org/xen-tools) which have been reported by
|
||||||
|
the users of the Debian package (the primary user-base).
|
||||||
|
|
||||||
|
If you're running the code on a Debian host system then reporting bugs
|
||||||
|
against this package is a good thing to do; by doing so you allow
|
||||||
|
others to view issues, and I check the bug-page regularly.
|
||||||
|
|
||||||
|
--
|
||||||
|
The Xen-Tools Developer Team
|
||||||
46
KNOWN_BUGS
46
KNOWN_BUGS
@@ -1,46 +0,0 @@
|
|||||||
KNOWN BUGS in xen-tools
|
|
||||||
|
|
||||||
Bugs to fix before a 4.3 release
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
* xen-delete-image doesn't remove all logical volumes if --partitions is used.
|
|
||||||
|
|
||||||
See the link below for details how to reproduce. Reproducable at
|
|
||||||
least with --lvm. Thanks to Antoine Benkemoun for reporting.
|
|
||||||
|
|
||||||
http://xen-tools.org/pipermail/xen-tools-discuss/2010-May/000757.html
|
|
||||||
|
|
||||||
* xen-delete-image ignores extension setting
|
|
||||||
|
|
||||||
* partitions were mounted in config file order, not in mountpoint order.
|
|
||||||
That implies that if you specified :
|
|
||||||
/boot
|
|
||||||
/
|
|
||||||
in that order, / was mounted _over_ /boot, and you would not _see_ /boot.
|
|
||||||
Xen-Tools would then install boot on your / partition, and your boot device
|
|
||||||
was just empty and unbootable.
|
|
||||||
|
|
||||||
Workaround for 4.2 is to write your partition file such as mounts overlap
|
|
||||||
correctly when mounted in specified order.
|
|
||||||
|
|
||||||
Current (unreleased) fix is to sort by mountpoint length.
|
|
||||||
|
|
||||||
Fix would be to reproduce what mount does with mount -a.
|
|
||||||
|
|
||||||
* xen-create-image doesn't unmount the tempdir properly if /proc wasn't mounted inside
|
|
||||||
|
|
||||||
* xen-create-image says on startup summary that the Debian mirror is
|
|
||||||
used even if Ubuntu is going to be installed (and works)
|
|
||||||
|
|
||||||
* xen-list-images does not honour --extension
|
|
||||||
|
|
||||||
* --extension='' (i.e. empty string) no more works
|
|
||||||
|
|
||||||
|
|
||||||
Bugs to fix later
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
t/xen-tools.t can't really test Xen::Tools as the latter requires a
|
|
||||||
local Xen installation. For proper testing, a dummy set of Xen
|
|
||||||
configuration files and configurable paths to them in Xen::Tools would
|
|
||||||
be necessary.
|
|
||||||
43
KNOWN_BUGS.markdown
Normal file
43
KNOWN_BUGS.markdown
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
KNOWN BUGS in xen-tools
|
||||||
|
=======================
|
||||||
|
|
||||||
|
Bugs to fix before next release
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
[None so far]
|
||||||
|
|
||||||
|
Bugs to fix rather soon
|
||||||
|
-----------------------
|
||||||
|
|
||||||
|
* `xen-delete-image` doesn't remove all logical volumes if `--partitions` is used.
|
||||||
|
|
||||||
|
See the link below for details how to reproduce. Reproducable at
|
||||||
|
least with `--lvm`. Thanks to Antoine Benkemoun for reporting.
|
||||||
|
|
||||||
|
[Bug Report](http://xen-tools.org/pipermail/xen-tools-discuss/2010-May/000757.html)
|
||||||
|
|
||||||
|
* partitions were mounted in config file order, not in mountpoint order.
|
||||||
|
That implies that if you specified :
|
||||||
|
|
||||||
|
/boot
|
||||||
|
/
|
||||||
|
|
||||||
|
in that order, `/` was mounted _over_ `/boot`, and you would not
|
||||||
|
_see_ `/boot`. Xen-Tools would then install `boot` on your `/`
|
||||||
|
partition, and your boot device was just empty and unbootable.
|
||||||
|
|
||||||
|
Workaround for 4.2 is to write your partition file such as mounts overlap
|
||||||
|
correctly when mounted in specified order.
|
||||||
|
|
||||||
|
Current (unreleased) fix is to sort by mountpoint length.
|
||||||
|
|
||||||
|
Fix would be to reproduce what mount does with mount `-a`.
|
||||||
|
|
||||||
|
|
||||||
|
Bugs to fix later
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
`t/xen-tools.t` can't really test Xen::Tools as the latter requires a
|
||||||
|
local Xen installation. For proper testing, a dummy set of Xen
|
||||||
|
configuration files and configurable paths to them in `Xen::Tools`
|
||||||
|
would be necessary.
|
||||||
2
LICENSE
2
LICENSE
@@ -3,7 +3,7 @@ xen-tools
|
|||||||
---------
|
---------
|
||||||
|
|
||||||
Copyright (c) 2005-2009: Steve Kemp. All rights reserved.
|
Copyright (c) 2005-2009: Steve Kemp. All rights reserved.
|
||||||
Copyright (c) 2010-2012: The Xen-Tools Development Team, currently consisting of:
|
Copyright (c) 2010-2013: The Xen-Tools Development Team, currently consisting of:
|
||||||
Axel Beckert <abe@deuxchevaux.org>,
|
Axel Beckert <abe@deuxchevaux.org>,
|
||||||
Dmitry Nedospasov <dmitry@nedos.net>, and
|
Dmitry Nedospasov <dmitry@nedos.net>, and
|
||||||
Stéphane Jourdois <sjourdois@gmail.com>
|
Stéphane Jourdois <sjourdois@gmail.com>
|
||||||
|
|||||||
131
Makefile
131
Makefile
@@ -14,17 +14,16 @@
|
|||||||
#
|
#
|
||||||
TMP ?= /tmp
|
TMP ?= /tmp
|
||||||
DIST_PREFIX = ${TMP}
|
DIST_PREFIX = ${TMP}
|
||||||
VERSION = 4.3rc1
|
VERSION = 4.4~dev
|
||||||
DEBVERSION = $(shell echo $(VERSION)|sed 's/\(rc\|pre\|beta\|alpha\)/~\1/')
|
DEBVERSION = $(shell echo $(VERSION)|sed 's/\(rc\|pre\|beta\|alpha\)/~\1/')
|
||||||
BASE = xen-tools
|
BASE = xen-tools
|
||||||
VCS = $(shell if git ls-files > /dev/null; then echo git; \
|
VCS = git
|
||||||
elif hg st > /dev/null; then echo hg; \
|
|
||||||
else echo cannot-determine-used-vcs; fi)
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Installation prefix, useful for the Debian package.
|
# Installation prefix, useful for the Debian package.
|
||||||
#
|
#
|
||||||
prefix=
|
DESTDIR=
|
||||||
|
prefix=${DESTDIR}
|
||||||
|
|
||||||
|
|
||||||
nop:
|
nop:
|
||||||
@@ -70,6 +69,7 @@ clean:
|
|||||||
@if [ -d debian/xen-tools ]; then rm -rf ./debian/xen-tools; fi
|
@if [ -d debian/xen-tools ]; then rm -rf ./debian/xen-tools; fi
|
||||||
@if [ -e $(BASE)-$(VERSION).tar.gz ]; then rm $(BASE)-$(VERSION).tar.gz ; fi
|
@if [ -e $(BASE)-$(VERSION).tar.gz ]; then rm $(BASE)-$(VERSION).tar.gz ; fi
|
||||||
@if [ -e $(BASE)-$(VERSION).tar.gz.asc ]; then rm $(BASE)-$(VERSION).tar.gz.asc ; fi
|
@if [ -e $(BASE)-$(VERSION).tar.gz.asc ]; then rm $(BASE)-$(VERSION).tar.gz.asc ; fi
|
||||||
|
cd t; $(MAKE) clean
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -95,7 +95,7 @@ fixup-perms:
|
|||||||
chmod 644 etc/xen-tools.conf
|
chmod 644 etc/xen-tools.conf
|
||||||
chmod 644 etc/xm.tmpl
|
chmod 644 etc/xm.tmpl
|
||||||
chmod 644 etc/xm-nfs.tmpl
|
chmod 644 etc/xm-nfs.tmpl
|
||||||
chmod 644 misc/xen-tools misc/README
|
chmod 644 misc/*
|
||||||
|
|
||||||
#
|
#
|
||||||
# Install files to /etc/
|
# Install files to /etc/
|
||||||
@@ -110,8 +110,10 @@ install-etc:
|
|||||||
cp etc/xm.tmpl ${prefix}/etc/xen-tools/
|
cp etc/xm.tmpl ${prefix}/etc/xen-tools/
|
||||||
cp etc/xm-nfs.tmpl ${prefix}/etc/xen-tools/
|
cp etc/xm-nfs.tmpl ${prefix}/etc/xen-tools/
|
||||||
cp partitions/*-* ${prefix}/etc/xen-tools/partitions.d/
|
cp partitions/*-* ${prefix}/etc/xen-tools/partitions.d/
|
||||||
-mkdir -p ${prefix}/etc/bash_completion.d
|
-mkdir -p ${prefix}/etc/bash_completion.d/
|
||||||
cp misc/xen-tools ${prefix}/etc/bash_completion.d/
|
cp misc/xen-tools.bash-completion ${prefix}/etc/bash_completion.d/xen-tools
|
||||||
|
-mkdir -p ${prefix}/etc/initramfs-tools/conf.d/
|
||||||
|
cp misc/xen-tools.initramfs-tools ${prefix}/etc/initramfs-tools/conf.d/xen-tools
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -145,60 +147,62 @@ install-bin:
|
|||||||
#
|
#
|
||||||
install-hooks:
|
install-hooks:
|
||||||
for i in roles/* ; do if [ -f $$i ]; then cp $$i ${prefix}/etc/xen-tools/role.d; fi ; done
|
for i in roles/* ; do if [ -f $$i ]; then cp $$i ${prefix}/etc/xen-tools/role.d; fi ; done
|
||||||
for i in ${prefix}/usr/lib/xen-tools/*.d; do if [ -L "$$i" ]; then rm -vf "$$i"; fi; done
|
for i in ${prefix}/usr/share/xen-tools/*.d; do if [ -L "$$i" ]; then rm -vf "$$i"; fi; done
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-4.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/centos-4.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-5.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/centos-5.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-6.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/centos-6.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/fedora-core-6.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/fedora-core-6.d/
|
||||||
cp -R hooks/centos-4/*-* ${prefix}/usr/lib/xen-tools/centos-4.d
|
cp -R hooks/centos-4/*-* ${prefix}/usr/share/xen-tools/centos-4.d
|
||||||
cp -R hooks/centos-5/*-* ${prefix}/usr/lib/xen-tools/centos-5.d
|
cp -R hooks/centos-5/*-* ${prefix}/usr/share/xen-tools/centos-5.d
|
||||||
cp -R hooks/centos-6/*-* ${prefix}/usr/lib/xen-tools/centos-6.d
|
cp -R hooks/centos-6/*-* ${prefix}/usr/share/xen-tools/centos-6.d
|
||||||
cp -R hooks/fedora-core-6/*-* ${prefix}/usr/lib/xen-tools/fedora-core-6.d
|
cp -R hooks/fedora-core-6/*-* ${prefix}/usr/share/xen-tools/fedora-core-6.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-4.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-4.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-5.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-5.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-7.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-7.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-8.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-8.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-9.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-9.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-10.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-10.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-11.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-11.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-12.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-12.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-13.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-13.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-14.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-14.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-15.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-15.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-16.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-16.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s fedora-core-6.d fedora-core-17.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-17.d
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/debian.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/debian.d/
|
||||||
cp -R hooks/debian/*-* ${prefix}/usr/lib/xen-tools/debian.d
|
cp -R hooks/debian/*-* ${prefix}/usr/share/xen-tools/debian.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d sarge.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d sarge.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d etch.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d etch.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d lenny.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d lenny.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d squeeze.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d squeeze.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d wheezy.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d wheezy.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d sid.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d jessie.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d testing.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d sid.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d stable.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d testing.d
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/gentoo.d/
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d stable.d
|
||||||
cp -R hooks/gentoo/*-* ${prefix}/usr/lib/xen-tools/gentoo.d
|
mkdir -p ${prefix}/usr/share/xen-tools/gentoo.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/dapper.d/
|
cp -R hooks/gentoo/*-* ${prefix}/usr/share/xen-tools/gentoo.d
|
||||||
cp -R hooks/dapper/*-* ${prefix}/usr/lib/xen-tools/dapper.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/dapper.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/edgy.d/
|
cp -R hooks/dapper/*-* ${prefix}/usr/share/xen-tools/dapper.d/
|
||||||
cp -R hooks/edgy/*-* ${prefix}/usr/lib/xen-tools/edgy.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/edgy.d/
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d feisty.d
|
cp -R hooks/edgy/*-* ${prefix}/usr/share/xen-tools/edgy.d/
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d gutsy.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d feisty.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d hardy.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d gutsy.d
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/intrepid.d/
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d hardy.d
|
||||||
cp -R hooks/intrepid/*-* ${prefix}/usr/lib/xen-tools/intrepid.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/intrepid.d/
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s intrepid.d jaunty.d
|
cp -R hooks/intrepid/*-* ${prefix}/usr/share/xen-tools/intrepid.d/
|
||||||
mkdir -p ${prefix}/usr/lib/xen-tools/karmic.d/
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s intrepid.d jaunty.d
|
||||||
cp -R hooks/karmic/*-* ${prefix}/usr/lib/xen-tools/karmic.d/
|
mkdir -p ${prefix}/usr/share/xen-tools/karmic.d/
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d lucid.d
|
cp -R hooks/karmic/*-* ${prefix}/usr/share/xen-tools/karmic.d/
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d maverick.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d lucid.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d natty.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d maverick.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d oneiric.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d natty.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d precise.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d oneiric.d
|
||||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d quantal.d
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d precise.d
|
||||||
cp hooks/common.sh ${prefix}/usr/lib/xen-tools
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d quantal.d
|
||||||
cp -r hooks/common ${prefix}/usr/lib/xen-tools
|
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d raring.d
|
||||||
|
cp hooks/common.sh ${prefix}/usr/share/xen-tools
|
||||||
|
cp -r hooks/common ${prefix}/usr/share/xen-tools
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -240,7 +244,6 @@ release: tidy fixup-perms update-version update-modules clean changelog
|
|||||||
rm -f $(DIST_PREFIX)/$(BASE)-$(VERSION).tar.gz
|
rm -f $(DIST_PREFIX)/$(BASE)-$(VERSION).tar.gz
|
||||||
cp -R . $(DIST_PREFIX)/$(BASE)-$(VERSION)
|
cp -R . $(DIST_PREFIX)/$(BASE)-$(VERSION)
|
||||||
rm -rf $(DIST_PREFIX)/$(BASE)-$(VERSION)/debian
|
rm -rf $(DIST_PREFIX)/$(BASE)-$(VERSION)/debian
|
||||||
rm -rf $(DIST_PREFIX)/$(BASE)-$(VERSION)/.hg*
|
|
||||||
rm -rf $(DIST_PREFIX)/$(BASE)-$(VERSION)/.git*
|
rm -rf $(DIST_PREFIX)/$(BASE)-$(VERSION)/.git*
|
||||||
cd $(DIST_PREFIX) && tar -cvf $(DIST_PREFIX)/$(BASE)-$(VERSION).tar $(BASE)-$(VERSION)/
|
cd $(DIST_PREFIX) && tar -cvf $(DIST_PREFIX)/$(BASE)-$(VERSION).tar $(BASE)-$(VERSION)/
|
||||||
gzip $(DIST_PREFIX)/$(BASE)-$(VERSION).tar
|
gzip $(DIST_PREFIX)/$(BASE)-$(VERSION).tar
|
||||||
@@ -300,7 +303,9 @@ uninstall:
|
|||||||
-rm -rf ${prefix}/etc/xen-tools/skel
|
-rm -rf ${prefix}/etc/xen-tools/skel
|
||||||
-rmdir ${prefix}/etc/xen-tools/
|
-rmdir ${prefix}/etc/xen-tools/
|
||||||
-rm -f ${prefix}/etc/bash_completion.d/xen-tools
|
-rm -f ${prefix}/etc/bash_completion.d/xen-tools
|
||||||
|
# Maybe needed to remove older releases of xen-tools
|
||||||
rm -rf ${prefix}/usr/lib/xen-tools
|
rm -rf ${prefix}/usr/lib/xen-tools
|
||||||
|
rm -rf ${prefix}/usr/share/xen-tools
|
||||||
rm -f ${prefix}/usr/share/man/man8/xen-create-image.8.gz
|
rm -f ${prefix}/usr/share/man/man8/xen-create-image.8.gz
|
||||||
rm -f ${prefix}/usr/share/man/man8/xen-delete-image.8.gz
|
rm -f ${prefix}/usr/share/man/man8/xen-delete-image.8.gz
|
||||||
rm -f ${prefix}/usr/share/man/man8/xen-list-images.8.gz
|
rm -f ${prefix}/usr/share/man/man8/xen-list-images.8.gz
|
||||||
|
|||||||
@@ -1,3 +1,24 @@
|
|||||||
|
xen-tools 4.3.1 (released 30-Jun-2012)
|
||||||
|
======================================
|
||||||
|
|
||||||
|
Bugfix Release only
|
||||||
|
|
||||||
|
|
||||||
|
xen-tools 4.3 (released 26-Jun-2012)
|
||||||
|
====================================
|
||||||
|
|
||||||
|
Bug Fixes
|
||||||
|
---------
|
||||||
|
|
||||||
|
* Fix several testuite failures depending on the build host's
|
||||||
|
installation.
|
||||||
|
|
||||||
|
Other Changes
|
||||||
|
-------------
|
||||||
|
|
||||||
|
* Remove most Mercurial traces
|
||||||
|
|
||||||
|
|
||||||
xen-tools 4.3rc1 (released 08 Jun 2012)
|
xen-tools 4.3rc1 (released 08 Jun 2012)
|
||||||
=======================================
|
=======================================
|
||||||
|
|
||||||
173
README
173
README
@@ -1,173 +0,0 @@
|
|||||||
xen-tools
|
|
||||||
---------
|
|
||||||
|
|
||||||
Homepage:
|
|
||||||
http://www.xen-tools.org/software/xen-tools
|
|
||||||
|
|
||||||
Git Repository:
|
|
||||||
http://gitorious.org/xen-tools
|
|
||||||
|
|
||||||
Mailing Lists:
|
|
||||||
http://www.xen-tools.org/software/xen-tools/lists.html
|
|
||||||
|
|
||||||
About:
|
|
||||||
Xen-tools contains a collection of Perl scripts for working with Xen
|
|
||||||
guest images under Linux.
|
|
||||||
|
|
||||||
Using this software, you can easily create new Xen guests configured
|
|
||||||
to be accessible over the network via OpenSSH.
|
|
||||||
|
|
||||||
xen-tools currently has scripts to install most releases of Debian
|
|
||||||
(starting with 3.1 "Sarge") and Ubuntu (starting with 6.06 LTS
|
|
||||||
"Dapper") and some RPM-based distributions. On the Dom0 side all
|
|
||||||
current Xen supporting distributions should work.
|
|
||||||
|
|
||||||
However, currently only Debian and Ubuntu releases are tested and
|
|
||||||
known to work, i.e.:
|
|
||||||
|
|
||||||
Debian:
|
|
||||||
* Sarge 3.1 (i386 and DomU only)
|
|
||||||
* Etch 4.0 (Dom0 no more tested)
|
|
||||||
* Lenny 5.0
|
|
||||||
* Squeeze 6.0
|
|
||||||
* Wheezy 7.0
|
|
||||||
* Sid (works at least at the moment of writing :-)
|
|
||||||
|
|
||||||
Ubuntu (only DomUs tested):
|
|
||||||
* Dapper Drake 6.06
|
|
||||||
* Edgy Eft 6.10
|
|
||||||
* Feisty Fawn 7.04
|
|
||||||
* Gutsy Gibbon 7.10
|
|
||||||
* Hardy Heron 8.04 (see [1])
|
|
||||||
* Interpid Ibex 8.10
|
|
||||||
* Jaunty Jackaplope 9.04
|
|
||||||
* Karmic Koala 9.10
|
|
||||||
* Lucid Lynx 10.04
|
|
||||||
* Maverick Meerkat 10.10
|
|
||||||
* Natty Narwhal 11.04
|
|
||||||
* Oneiric Ocelot 11.10
|
|
||||||
* Precise Pangolin 12.04
|
|
||||||
* Quantal Quetzal 12.10 (preliminary support as it's not yet available)
|
|
||||||
|
|
||||||
CentOS (only DomUs tested, pygrub support incomplete):
|
|
||||||
* CentOS 5
|
|
||||||
* CentOS 6
|
|
||||||
|
|
||||||
[1] There is an issue with debootstrap on hardy not installing ksyslogd
|
|
||||||
This can be fixed by chrooting into the newly installed system
|
|
||||||
and removing the startup scripts. See:
|
|
||||||
http://www.linux-vserver.org/Installing_Ubuntu_8.04_Hardy_as_guest
|
|
||||||
|
|
||||||
Xen-Tools are available prepackaged in Debian and as source tar-ball
|
|
||||||
for local installation. Installing from source should work flawlessly
|
|
||||||
on most Linux systems that meet the installation requirements.
|
|
||||||
|
|
||||||
Requirements
|
|
||||||
------------
|
|
||||||
|
|
||||||
To use these tools you'll need the following software:
|
|
||||||
|
|
||||||
* debootstrap
|
|
||||||
* Perl
|
|
||||||
* The Perl module "Text::Template"
|
|
||||||
* The Perl module "Config::IniFiles"
|
|
||||||
- Both of these modules are available as Debian packages,
|
|
||||||
or direct from http://www.cpan.org/ for non-Debian distributions.
|
|
||||||
* Make, if you are not installing through a package manager
|
|
||||||
|
|
||||||
You can try to install RPM-based distributions such as CentOS, or
|
|
||||||
Fedora Core, but you will need a correctly installed and configured
|
|
||||||
"rinse" package. This is currently not supported.
|
|
||||||
|
|
||||||
If you wish to create new Xen instances which may be controlled by
|
|
||||||
users via a login shell you can have a look at the (currently
|
|
||||||
unmaintained) xen-shell package which is available from:
|
|
||||||
|
|
||||||
http://xen-tools.org/software/xen-shell/
|
|
||||||
|
|
||||||
|
|
||||||
Installation
|
|
||||||
------------
|
|
||||||
|
|
||||||
As root or with sudo, execute "make install".
|
|
||||||
|
|
||||||
See debian/README.source how to build the Debian package from a
|
|
||||||
checked out copy of the git repository (i.e. without a source tar
|
|
||||||
ball).
|
|
||||||
|
|
||||||
|
|
||||||
The Scripts
|
|
||||||
-----------
|
|
||||||
|
|
||||||
Here is a brief description of each included script, for more
|
|
||||||
thorough documentation please consult the appropriate man page.
|
|
||||||
|
|
||||||
|
|
||||||
xen-create-image
|
|
||||||
----------------
|
|
||||||
|
|
||||||
This script is designed to create new images which may be used
|
|
||||||
with the Xen hypervisor.
|
|
||||||
|
|
||||||
This script performs the initial setup, then delegates the real
|
|
||||||
work to a collection of helper scripts:
|
|
||||||
|
|
||||||
* xt-install-image
|
|
||||||
Installs a distribution into a directory.
|
|
||||||
|
|
||||||
* xt-customize-image
|
|
||||||
Run a collection of hook scripts to configure the freshly
|
|
||||||
installed system.
|
|
||||||
|
|
||||||
* xt-create-xen-config
|
|
||||||
Create a configuration file in /etc/xen such that Xen can
|
|
||||||
boot the newly created machine.
|
|
||||||
|
|
||||||
* xt-guess-suite-and-mirror
|
|
||||||
In case of a Debian or Ubuntu Dom0, this script tries to guess
|
|
||||||
the most suitable suite and mirror for DomUs based on the Dom0's
|
|
||||||
/etc/apt/sources.list.
|
|
||||||
|
|
||||||
|
|
||||||
xen-create-nfs
|
|
||||||
--------------
|
|
||||||
|
|
||||||
This script is similar in spirit to xen-create-image, but much
|
|
||||||
less complex. It allows the creation of Xen guests which are
|
|
||||||
diskless, mounting their root filesystem over a remote NFS-share.
|
|
||||||
|
|
||||||
There are not many options to tweak, but still a useful addition
|
|
||||||
to the suite.
|
|
||||||
|
|
||||||
|
|
||||||
xen-delete-image
|
|
||||||
----------------
|
|
||||||
|
|
||||||
This script will allow you to completely remove Xen instances
|
|
||||||
which have previously been created by xen-create-image, this
|
|
||||||
includes removing the storage block devices from the system,
|
|
||||||
and deleting the Xen configuration file.
|
|
||||||
|
|
||||||
|
|
||||||
xen-list-images
|
|
||||||
---------------
|
|
||||||
|
|
||||||
List all the created images beneath a given root directory along
|
|
||||||
with a brief overview of their setup details.
|
|
||||||
|
|
||||||
|
|
||||||
xen-update-image
|
|
||||||
----------------
|
|
||||||
|
|
||||||
This script runs "apt-get update; apt-get upgrade" for a given
|
|
||||||
Xen image.
|
|
||||||
|
|
||||||
NOTES:
|
|
||||||
|
|
||||||
* The image should not be running or corruption will occur!
|
|
||||||
* The script should only be used for Xen instances of Debian or
|
|
||||||
a Debian-derived distribution.
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
The Xen-Tools Developer Team
|
|
||||||
179
README.markdown
Normal file
179
README.markdown
Normal file
@@ -0,0 +1,179 @@
|
|||||||
|
xen-tools
|
||||||
|
=========
|
||||||
|
|
||||||
|
* [Homepage](http://www.xen-tools.org/software/xen-tools)
|
||||||
|
* Git Repository:
|
||||||
|
* [at Gitorious](http://gitorious.org/xen-tools)
|
||||||
|
* [at GitHub](http://github.com/xtaran/xen-tools)
|
||||||
|
* [Mailing Lists](http://www.xen-tools.org/software/xen-tools/lists.html)
|
||||||
|
|
||||||
|
About
|
||||||
|
-----
|
||||||
|
|
||||||
|
xen-tools contains a collection of Perl scripts for working with Xen
|
||||||
|
guest images under Linux.
|
||||||
|
|
||||||
|
Using this software, you can easily create new
|
||||||
|
[Xen](http://www.xen.org) guests configured to be accessible over the
|
||||||
|
network via [OpenSSH](http://www.openssh.org/).
|
||||||
|
|
||||||
|
xen-tools currently has scripts to install most releases of
|
||||||
|
[Debian](http://www.debian.org/) (starting with 3.1 "Sarge") and
|
||||||
|
[Ubuntu](http://www.ubuntu.com/) (starting with 6.06 LTS "Dapper") and
|
||||||
|
some RPM-based distributions. On the Dom0 side all current Xen
|
||||||
|
supporting distributions should work.
|
||||||
|
|
||||||
|
However, currently only Debian and Ubuntu releases are tested and
|
||||||
|
known to work reliably, i.e.:
|
||||||
|
|
||||||
|
### Debian
|
||||||
|
|
||||||
|
* Sarge 3.1 (i386 and DomU only)
|
||||||
|
* Etch 4.0 (Dom0 no more tested)
|
||||||
|
* Lenny 5.0
|
||||||
|
* Squeeze 6.0
|
||||||
|
* Wheezy 7.0
|
||||||
|
* Jessie 8.0 (preliminary support as it's not yet available)
|
||||||
|
* Sid (works at least at the moment of writing :-)
|
||||||
|
|
||||||
|
### Ubuntu
|
||||||
|
|
||||||
|
(only DomUs tested)
|
||||||
|
|
||||||
|
* Dapper Drake 6.06 (needs editing of `/usr/share/debootstrap/scripts/dapper` since at least debootstrap version 1.0.37, see [#659360][1])
|
||||||
|
* Edgy Eft 6.10 (needs editing of `/usr/share/debootstrap/scripts/edgy` since at least debootstrap version 1.0.37, see [#659360][1])
|
||||||
|
* Feisty Fawn 7.04
|
||||||
|
* Gutsy Gibbon 7.10
|
||||||
|
* Hardy Heron 8.04 (see [Installing Ubuntu 8.04 as DomU][2])
|
||||||
|
* Interpid Ibex 8.10
|
||||||
|
* Jaunty Jackaplope 9.04
|
||||||
|
* Karmic Koala 9.10
|
||||||
|
* Lucid Lynx 10.04
|
||||||
|
* Maverick Meerkat 10.10
|
||||||
|
* Natty Narwhal 11.04
|
||||||
|
* Oneiric Ocelot 11.10
|
||||||
|
* Precise Pangolin 12.04
|
||||||
|
* Quantal Quetzal 12.10
|
||||||
|
* Raring Ringtail 13.04 (preliminary support as it's not yet available)
|
||||||
|
|
||||||
|
[1]: http://bugs.debian.org/659360
|
||||||
|
"debootstrap in Wheezy can no more build Ubuntu Edgy or earlier"
|
||||||
|
|
||||||
|
[2]: http://www.linux-vserver.org/Installing_Ubuntu_8.04_Hardy_as_guest
|
||||||
|
"There is an issue with debootstrap on hardy not installing ksyslogd."
|
||||||
|
|
||||||
|
### CentOS
|
||||||
|
|
||||||
|
(only DomUs tested, pygrub support incomplete)
|
||||||
|
|
||||||
|
* CentOS 5
|
||||||
|
* CentOS 6
|
||||||
|
|
||||||
|
Packages
|
||||||
|
--------
|
||||||
|
|
||||||
|
xen-tools are available prepackaged in Debian (and derivates) and as
|
||||||
|
source tar-ball for local installation. Installing from source should
|
||||||
|
work flawlessly on most Linux systems that meet the installation
|
||||||
|
requirements.
|
||||||
|
|
||||||
|
Requirements
|
||||||
|
------------
|
||||||
|
|
||||||
|
To use these tools you'll need the following software:
|
||||||
|
|
||||||
|
* [debootstrap](http://packages.debian.org/debootstrap)
|
||||||
|
* Perl
|
||||||
|
* The Perl module [Text::Template](http://search.cpan.org/dist/Text-Template/)
|
||||||
|
([Debian Package libtext-template-perl](http://packages.debian.org/libtext-template-perl))
|
||||||
|
* The Perl module [Config::IniFiles](http://search.cpan.org/dist/Config-IniFiles/)
|
||||||
|
([Debian Package libconfig-inifiles-perl](http://packages.debian.org/libconfig-inifiles-perl))
|
||||||
|
* Make, if you are not installing through a package manager
|
||||||
|
|
||||||
|
You can try to install RPM-based distributions such as CentOS, or
|
||||||
|
Fedora Core, but you will need a correctly installed and configured
|
||||||
|
[rinse](http://packages.debian.org/rinse) package. This is currently
|
||||||
|
not fully supported.
|
||||||
|
|
||||||
|
If you wish to create new Xen instances which may be controlled by
|
||||||
|
users via a login shell you can have a look at the (currently
|
||||||
|
unmaintained) [xen-shell](http://xen-tools.org/software/xen-shell/)
|
||||||
|
project.
|
||||||
|
|
||||||
|
|
||||||
|
Installation
|
||||||
|
------------
|
||||||
|
|
||||||
|
As root or with sudo, execute `make instal`.
|
||||||
|
|
||||||
|
See `debian/README.source` how to build the Debian package from a
|
||||||
|
checked out copy of the git repository (i.e. without a source tar
|
||||||
|
ball).
|
||||||
|
|
||||||
|
|
||||||
|
The Scripts
|
||||||
|
-----------
|
||||||
|
|
||||||
|
Here is a brief description of each included script, for more thorough
|
||||||
|
documentation please consult the appropriate man page.
|
||||||
|
|
||||||
|
|
||||||
|
### xen-create-image
|
||||||
|
|
||||||
|
This script is designed to create new images which may be used
|
||||||
|
with the Xen hypervisor.
|
||||||
|
|
||||||
|
This script performs the initial setup, then delegates the real
|
||||||
|
work to a collection of helper scripts:
|
||||||
|
|
||||||
|
* `xt-install-image`: Installs a distribution into a directory.
|
||||||
|
|
||||||
|
* `xt-customize-image`: Run a collection of hook scripts to configure
|
||||||
|
the freshly installed system.
|
||||||
|
|
||||||
|
* `xt-create-xen-config`: Create a configuration file in `/etc/xen`
|
||||||
|
such that Xen can boot the newly created machine.
|
||||||
|
|
||||||
|
* `xt-guess-suite-and-mirror`: In case of a Debian or Ubuntu Dom0,
|
||||||
|
this script tries to guess the most suitable suite and mirror for
|
||||||
|
DomUs based on the Dom0's `/etc/apt/sources.list`.
|
||||||
|
|
||||||
|
|
||||||
|
### xen-create-nfs
|
||||||
|
|
||||||
|
This script is similar in spirit to `xen-create-image`, but much less
|
||||||
|
complex. It allows the creation of Xen guests which are diskless,
|
||||||
|
mounting their root filesystem over a remote NFS-share.
|
||||||
|
|
||||||
|
There are not many options to tweak, but still a useful addition
|
||||||
|
to the suite.
|
||||||
|
|
||||||
|
|
||||||
|
### xen-delete-image
|
||||||
|
|
||||||
|
This script will allow you to completely remove Xen instances which
|
||||||
|
have previously been created by `xen-create-image`, this includes
|
||||||
|
removing the storage block devices from the system, and deleting the
|
||||||
|
Xen configuration file.
|
||||||
|
|
||||||
|
|
||||||
|
### xen-list-images
|
||||||
|
|
||||||
|
List all the created images beneath a given root directory along with
|
||||||
|
a brief overview of their setup details.
|
||||||
|
|
||||||
|
|
||||||
|
### xen-update-image
|
||||||
|
|
||||||
|
This script runs "apt-get update; apt-get upgrade" for a given Xen
|
||||||
|
image.
|
||||||
|
|
||||||
|
#### NOTES
|
||||||
|
|
||||||
|
* The image should not be running or corruption will occur!
|
||||||
|
* The script should only be used for Xen instances of Debian or a
|
||||||
|
Debian-derived distribution.
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
The Xen-Tools Developer Team
|
||||||
42
SUPPORT
42
SUPPORT
@@ -1,42 +0,0 @@
|
|||||||
|
|
||||||
Mailing List
|
|
||||||
------------
|
|
||||||
|
|
||||||
For assistance on using, or customising, these scripts please
|
|
||||||
consult the manpages initially, then the website:
|
|
||||||
|
|
||||||
http://xen-tools.org/software/xen-tools/
|
|
||||||
|
|
||||||
If these are not sufficient resources please consider posting
|
|
||||||
any queries you might have to the mailing list:
|
|
||||||
|
|
||||||
http://xen-tools.org/software/xen-tools/lists.html
|
|
||||||
|
|
||||||
Included with the release you should find the file "BUGS" which
|
|
||||||
contains some notes on reporting bugs.
|
|
||||||
|
|
||||||
|
|
||||||
Xen Queries
|
|
||||||
-----------
|
|
||||||
|
|
||||||
If your query is mostly related to Xen, rather than these tools,
|
|
||||||
then please consider joining the xen-users mailing list:
|
|
||||||
|
|
||||||
http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-users
|
|
||||||
|
|
||||||
The members of that list are very good at diagnosing issues with
|
|
||||||
networking, block devices, and other Xen oddities.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Contact The Author
|
|
||||||
------------------
|
|
||||||
|
|
||||||
As a last resort feel free to contact the author at <steve@steve.org.uk>.
|
|
||||||
|
|
||||||
I say last resort not because I'm unwilling to help, but because
|
|
||||||
it will take longer for me to respond to you personally and I hate
|
|
||||||
answering the same question multiple times.
|
|
||||||
|
|
||||||
Steve
|
|
||||||
--
|
|
||||||
41
SUPPORT.markdown
Normal file
41
SUPPORT.markdown
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
Mailing List
|
||||||
|
============
|
||||||
|
|
||||||
|
For assistance on using, or customising, these scripts please consult
|
||||||
|
the manpages initially, then the
|
||||||
|
[website](http://xen-tools.org/software/xen-tools/).
|
||||||
|
|
||||||
|
If these are not sufficient resources please consider posting any
|
||||||
|
queries you might have to the [mailing
|
||||||
|
list](http://xen-tools.org/software/xen-tools/lists.html)
|
||||||
|
|
||||||
|
Included with the release you should find the file `BUGS.markdown`
|
||||||
|
which contains some notes on reporting bugs.
|
||||||
|
|
||||||
|
|
||||||
|
Xen Queries
|
||||||
|
===========
|
||||||
|
|
||||||
|
If your query is mostly related to Xen, rather than these tools, then
|
||||||
|
please consider joining the [xen-users mailing
|
||||||
|
list](http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-users)
|
||||||
|
|
||||||
|
The members of that list are very good at diagnosing issues with
|
||||||
|
networking, block devices, and other Xen oddities.
|
||||||
|
|
||||||
|
There's also the IRC channel `##xen` (the double hashmark is not a
|
||||||
|
typo) on the [Freenode](http://freenode.net/) IRC network.
|
||||||
|
|
||||||
|
|
||||||
|
Contact The Author
|
||||||
|
==================
|
||||||
|
|
||||||
|
As a last resort you can to contact the current maintainer, Axel
|
||||||
|
Beckert, at <abe@deuxchevaux.org>.
|
||||||
|
|
||||||
|
As the previous xen-tools maintainer and original author, Steve
|
||||||
|
Kemp, said, I say last resort not because I'm unwilling to help, but
|
||||||
|
because it may take longer for me to respond to you personally.
|
||||||
|
|
||||||
|
--
|
||||||
|
Axel
|
||||||
209
TODO
209
TODO
@@ -1,209 +0,0 @@
|
|||||||
TODO
|
|
||||||
====
|
|
||||||
|
|
||||||
See KNOWN_BUGS for real bugs.
|
|
||||||
|
|
||||||
Bugs to fix and features to add for 4.3
|
|
||||||
---------------------------------------
|
|
||||||
|
|
||||||
Refactor TLS disabling. Seems to be happen twice, once in 20-setup-apt
|
|
||||||
and once in 10-disable-tls.
|
|
||||||
|
|
||||||
Bugs to fix and features to add for 5.0
|
|
||||||
---------------------------------------
|
|
||||||
|
|
||||||
* xen-create-image man page overhaul:
|
|
||||||
|
|
||||||
- ambiguous option list with regards to parameters
|
|
||||||
- Set Fail in more situations where the script has clearly failed
|
|
||||||
i.e.: lvm exists
|
|
||||||
|
|
||||||
* Test and support more file system types.
|
|
||||||
|
|
||||||
Actually this should be pretty simple now that the parameters are
|
|
||||||
stored in the configuration hash.
|
|
||||||
|
|
||||||
* Setup locales in the hooks?
|
|
||||||
|
|
||||||
Currently no locales are set and this causes several domU errors
|
|
||||||
which appear in the domU's logs.
|
|
||||||
|
|
||||||
* Documentation overhaul
|
|
||||||
|
|
||||||
Better explain what roles /should be/ used for, and that roles
|
|
||||||
are examples, and shouldn't cover every single scenario. They
|
|
||||||
are also easy to write.
|
|
||||||
|
|
||||||
* Think again about disk_device checks :
|
|
||||||
|
|
||||||
Newer Xen provides "xvda", older provided "sda". The current check for
|
|
||||||
valid values of disk_device (used for root device in domU /etc/fstab)
|
|
||||||
does only allow those values.
|
|
||||||
This forbids any deployment of LVM/RAID _inside_ domU, which cannot
|
|
||||||
be created by xen-tools anyway. So the current check is fine with the
|
|
||||||
current possibilities of xen-tools, but could become a limitation.
|
|
||||||
- Is it possible/wanted to "query" xend for default device names ?
|
|
||||||
- Is it possible to create /dev/mapper devices with xend conf ?
|
|
||||||
- Can we just avoid to ask for this value and not specify the device
|
|
||||||
in /etc/fstab (and use /dev/root, /dev/by-uuid, or anything ?)
|
|
||||||
|
|
||||||
* xen-create-image --dist=... / sources.list generation should be more fine-grained
|
|
||||||
|
|
||||||
xen-tools should offer the possibility to enable/disable
|
|
||||||
security/volatile/backports as well as
|
|
||||||
contrib/non-free/universe/restricted/multiverse for each of them
|
|
||||||
not only based on defaults plus the Dom0's sources.list
|
|
||||||
|
|
||||||
One idea is to allow parameters like
|
|
||||||
|
|
||||||
--dist="lenny:main,contrib,non-free;security;volatile:main"
|
|
||||||
|
|
||||||
and maybe (if the default will be to include security) to also
|
|
||||||
allow
|
|
||||||
|
|
||||||
--dist="lenny;no-security"
|
|
||||||
|
|
||||||
The second idea (by Mathieu Parent) is to have an
|
|
||||||
/etc/xen-tools/sources.list.d/ which then contains files like
|
|
||||||
lenny.list, lenny-server.list, karmic.list, etc. which defaults to
|
|
||||||
$dist.list, but can be also select with --sources-list=lenny-server
|
|
||||||
(which looks for ./lenny-server.list, ./lenny-server,
|
|
||||||
/etc/xen-tools/sources.list.d/lenny-server.list and
|
|
||||||
/etc/xen-tools/sources.list.d/lenny-server in that order).
|
|
||||||
|
|
||||||
Third variant is to use /etc/xen-tools/sources.lists/ instead of
|
|
||||||
/etc/xen-tools/sources.list.d/ because that directory is no
|
|
||||||
runparts-like directory.
|
|
||||||
|
|
||||||
* LVM snapshot support as an install source.
|
|
||||||
|
|
||||||
* Clean up mounts on Ctrl-C, causes error while installing otherwise:
|
|
||||||
|
|
||||||
Removing /dev/vg0/acromantula-domu1-disk - since we're forcing the
|
|
||||||
install Can't remove open logical volume "acromantula-domu1-disk"
|
|
||||||
this should be a matter of unmounting the mounted volume from /tmp.
|
|
||||||
|
|
||||||
* Generic grub support
|
|
||||||
|
|
||||||
This will generate a much nicer menu.lst as a side effect, as its
|
|
||||||
currently generated once at install, and is never updated. Installing
|
|
||||||
a full grub into the domU should update the menu.lst every time a
|
|
||||||
new kernel is installed and will also use the domU distro's menu.lst
|
|
||||||
conform.
|
|
||||||
|
|
||||||
* pv-grub support
|
|
||||||
|
|
||||||
This is a ways away and will probably start with a xen-pv-grub
|
|
||||||
package.
|
|
||||||
|
|
||||||
* Move the hooks directory to /etc/xen-tools/ to officially allow
|
|
||||||
added and modified hooks.
|
|
||||||
|
|
||||||
* Clean up the hooks directory
|
|
||||||
|
|
||||||
We still have a link farm for hooks and a meta link farm for distro
|
|
||||||
releases created on "make install". It probably would be better if
|
|
||||||
we would just have one directory per distro (like with debian) but
|
|
||||||
without the need to created symlinks on "make install"
|
|
||||||
|
|
||||||
Currently CentOS's 25-setup-kernel creates an fstab and
|
|
||||||
90-make-fstab does again. It works, but that cries for debugging
|
|
||||||
hell.
|
|
||||||
|
|
||||||
centos-5/25-setup-kernel centos-6/25-setup-kernel still differ and
|
|
||||||
I'm not sure if that's necessary respectively what's the common
|
|
||||||
denominator.
|
|
||||||
|
|
||||||
80-install-kernel is not yet merged into one hook script.
|
|
||||||
|
|
||||||
Common oneliners for code deduplication in the hooks/ directory:
|
|
||||||
|
|
||||||
$ find -L . -not -xtype l -not -type d -not -path '*/common/*' | sort -t / -k3
|
|
||||||
$ fdupes -r1 . | sort -t / -k3
|
|
||||||
$ find . -type f | sim_text -ipTt 50 | tac | column -t
|
|
||||||
|
|
||||||
|
|
||||||
* Create users, add ssh pubkeys to .ssh/authorized_keys
|
|
||||||
|
|
||||||
Still have to think of a good way of doing this. It would be nice
|
|
||||||
To specify a directory of public keys, parsing the hostnames
|
|
||||||
parsing the usernames from the ssh comment line
|
|
||||||
|
|
||||||
* More generic roles
|
|
||||||
|
|
||||||
Deploy a web server or setup ssmtp directly via flag when setting up
|
|
||||||
the machine. Open to suggestions, should just be some general use-cases
|
|
||||||
that are fairly common.
|
|
||||||
|
|
||||||
* Sections for the xen-tools.conf file
|
|
||||||
|
|
||||||
Currently it's really annoying when you are trying to create VMs
|
|
||||||
on multiple subnets. It would be nice to specify with a flag what
|
|
||||||
"type" of configuration you want, and a set of options specific to
|
|
||||||
that flag could be parsed from xen-tools.conf
|
|
||||||
|
|
||||||
* Refactor the code for less variants of calling cp, rm, mv, etc.
|
|
||||||
|
|
||||||
E.g. always use either cp() from File::Copy or /bin/cp, but not
|
|
||||||
both. To allow verbose copying, I (Axel) would prefer /bin/cp over
|
|
||||||
cp();
|
|
||||||
|
|
||||||
* Parse numerical parameters transparently for the user
|
|
||||||
|
|
||||||
The user shouldn't have to know weather he should specify size
|
|
||||||
as <size>G or <size>Gb or <size>. This should be parsed without
|
|
||||||
user interaction and rely on a common format.
|
|
||||||
|
|
||||||
* xen-update-image should mount /dev/pts before running apt-get
|
|
||||||
|
|
||||||
* xen-update-image should have options for using ...
|
|
||||||
|
|
||||||
... aptitude instead of apt-get
|
|
||||||
|
|
||||||
... dist-upgrade instead of upgrade
|
|
||||||
|
|
||||||
* Support cpu_weight and other features from
|
|
||||||
http://wiki.xensource.com/xenwiki/CreditScheduler
|
|
||||||
|
|
||||||
* Code Deduplication / Refactor the code for less code duplication
|
|
||||||
|
|
||||||
bin/x* currently contain the same or similar code like e.g. in the
|
|
||||||
function readConfigurationFile. This needs to be cleaned up.
|
|
||||||
|
|
||||||
* Use Perl::Critic
|
|
||||||
|
|
||||||
Stuff from Steve's TODO list / Generic TODOs
|
|
||||||
--------------------------------------------
|
|
||||||
|
|
||||||
* Write more test cases.
|
|
||||||
|
|
||||||
* xen-delete-image should unallocate any used IP addresses.
|
|
||||||
|
|
||||||
Axel's Break-Backwards-Compatibility Wishlist
|
|
||||||
---------------------------------------------
|
|
||||||
|
|
||||||
* Make empty extension the default
|
|
||||||
|
|
||||||
This would ease tab completion and CLI parameter reusage with "xm
|
|
||||||
create" and friends.
|
|
||||||
|
|
||||||
* Check if we can reduce MAKEDEV invocations in hooks/common/55-create-dev
|
|
||||||
|
|
||||||
MAKEDEV std is called in any case. First comment says "Early
|
|
||||||
termination if we have a couple of common devices present should
|
|
||||||
speed up installs which use --copy/--tar" and then "We still need
|
|
||||||
to make sure the basic devices are present" and calls MAKEDEV more
|
|
||||||
often than otherwise.
|
|
||||||
|
|
||||||
Additionally the 55-create-dev for CentOS/Fedora just created
|
|
||||||
console, zero and null. zero and null are part of "MAKEDEV std",
|
|
||||||
perhaps can we reduce it to that. console is part of "MAKEDEV
|
|
||||||
generic".
|
|
||||||
|
|
||||||
Additionally the devices hda, sda and tty1 may not necessary in any
|
|
||||||
case, but instead hvc0 should be created for sure in many
|
|
||||||
cases. Nothing cares about $serial_device there either.
|
|
||||||
|
|
||||||
Current MAKEDEV implementation support more than one device as
|
|
||||||
parameter. That could reduce the MAKEDEV calls from currently six
|
|
||||||
to two.
|
|
||||||
234
TODO.markdown
Normal file
234
TODO.markdown
Normal file
@@ -0,0 +1,234 @@
|
|||||||
|
TODO
|
||||||
|
====
|
||||||
|
|
||||||
|
See KNOWN_BUGS.markdown for real bugs.
|
||||||
|
|
||||||
|
Bugs to fix and features to add for 5.0
|
||||||
|
---------------------------------------
|
||||||
|
|
||||||
|
* `xen-create-image` man page overhaul:
|
||||||
|
|
||||||
|
* ambiguous option list with regards to parameters
|
||||||
|
* Set Fail in more situations where the script has clearly failed
|
||||||
|
i.e.: lvm exists
|
||||||
|
|
||||||
|
* Test and support more file system types.
|
||||||
|
|
||||||
|
Actually this should be pretty simple now that the parameters are
|
||||||
|
stored in the configuration hash.
|
||||||
|
|
||||||
|
* Setup locales in the hooks?
|
||||||
|
|
||||||
|
Currently no locales are set and this causes several domU errors
|
||||||
|
which appear in the domU's logs.
|
||||||
|
|
||||||
|
* Documentation overhaul
|
||||||
|
|
||||||
|
Better explain what roles /should be/ used for, and that roles
|
||||||
|
are examples, and shouldn't cover every single scenario. They
|
||||||
|
are also easy to write.
|
||||||
|
|
||||||
|
* Think again about disk_device checks :
|
||||||
|
|
||||||
|
Newer Xen provides `xvda`, older provided `sda`. The current check for
|
||||||
|
valid values of `disk_device` (used for root device in DomU `/etc/fstab`)
|
||||||
|
does only allow those values.
|
||||||
|
|
||||||
|
This forbids any deployment of LVM/RAID _inside_ DomU, which cannot
|
||||||
|
be created by xen-tools anyway. So the current check is fine with the
|
||||||
|
current possibilities of xen-tools, but could become a limitation.
|
||||||
|
* Is it possible/wanted to "query" xend for default device names?
|
||||||
|
* Is it possible to create `/dev/mapper` devices with xend conf?
|
||||||
|
* Can we just avoid to ask for this value and not specify the device
|
||||||
|
in `/etc/fstab` (and use `/dev/root`, `/dev/by-uuid`, or anything?)
|
||||||
|
|
||||||
|
* `xen-create-image --dist=…` / sources.list generation should be more fine-grained
|
||||||
|
|
||||||
|
xen-tools should offer the possibility to enable/disable
|
||||||
|
security/volatile/backports as well as
|
||||||
|
contrib/non-free/universe/restricted/multiverse for each of them not
|
||||||
|
only based on defaults plus the Dom0's sources.list
|
||||||
|
|
||||||
|
One idea is to allow parameters like
|
||||||
|
|
||||||
|
--dist="lenny:main,contrib,non-free;security;volatile:main"
|
||||||
|
|
||||||
|
and maybe (if the default will be to include security) to also
|
||||||
|
allow
|
||||||
|
|
||||||
|
--dist="lenny;no-security"
|
||||||
|
|
||||||
|
The second idea (by Mathieu Parent) is to have an
|
||||||
|
`/etc/xen-tools/sources.list.d/` which then contains files like
|
||||||
|
`lenny.list`, `lenny-server.list`, `karmic.list`, etc. which
|
||||||
|
defaults to `$dist.list`, but can be also select with
|
||||||
|
`--sources-list=lenny-server` (which looks for
|
||||||
|
`./lenny-server.list`, `./lenny-server`,
|
||||||
|
`/etc/xen-tools/sources.list.d/lenny-server.list` and
|
||||||
|
`/etc/xen-tools/sources.list.d/lenny-server` in that order).
|
||||||
|
|
||||||
|
Third variant is to use `/etc/xen-tools/sources.lists/` instead of
|
||||||
|
`/etc/xen-tools/sources.list.d/` because that directory is no
|
||||||
|
runparts-like directory.
|
||||||
|
|
||||||
|
* LVM snapshot support as an install source.
|
||||||
|
|
||||||
|
* Clean up mounts on `Ctrl-C`, causes error while installing otherwise:
|
||||||
|
|
||||||
|
Removing /dev/vg0/acromantula-domu1-disk - since we're forcing the
|
||||||
|
install Can't remove open logical volume "acromantula-domu1-disk"
|
||||||
|
this should be a matter of unmounting the mounted volume from /tmp.
|
||||||
|
|
||||||
|
* Generic grub support
|
||||||
|
|
||||||
|
This will generate a much nicer `menu.lst` as a side effect, as its
|
||||||
|
currently generated once at install, and is never updated. Installing
|
||||||
|
a full grub into the domU should update the `menu.lst` every time a
|
||||||
|
new kernel is installed and will also use the domU distro's `menu.lst`
|
||||||
|
conform.
|
||||||
|
|
||||||
|
* pv-grub support
|
||||||
|
|
||||||
|
This is a ways away and will probably start with a `xen-pv-grub`
|
||||||
|
package.
|
||||||
|
|
||||||
|
* Move the hooks directory to `/etc/xen-tools/` to officially allow
|
||||||
|
added and modified hooks.
|
||||||
|
|
||||||
|
* Clean up the hooks directory
|
||||||
|
|
||||||
|
We still have a link farm for hooks and a meta link farm for distro
|
||||||
|
releases created on `make install`. It probably would be better if
|
||||||
|
we would just have one directory per distro (like with debian) but
|
||||||
|
without the need to created symlinks on `make install`.
|
||||||
|
|
||||||
|
Currently CentOS's `25-setup-kernel` creates an fstab and
|
||||||
|
`90-make-fstab` does again. It works, but that cries for debugging
|
||||||
|
hell.
|
||||||
|
|
||||||
|
`centos-5/25-setup-kernel` and `centos-6/25-setup-kernel` still
|
||||||
|
differ and I'm not sure if that's necessary respectively what's the
|
||||||
|
common denominator.
|
||||||
|
|
||||||
|
`80-install-kernel` is not yet merged into one hook script.
|
||||||
|
|
||||||
|
Common oneliners for code deduplication in the hooks/ directory:
|
||||||
|
|
||||||
|
$ find -L . -not -xtype l -not -type d -not -path '*/common/*' | sort -t / -k3
|
||||||
|
$ fdupes -r1 . | sort -t / -k3
|
||||||
|
$ find . -type f | sim_text -ipTt 50 | tac | column -t
|
||||||
|
|
||||||
|
* Create users, add ssh pubkeys to `.ssh/authorized_keys`
|
||||||
|
|
||||||
|
Still have to think of a good way of doing this. It would be nice
|
||||||
|
To specify a directory of public keys, parsing the hostnames
|
||||||
|
parsing the usernames from the ssh comment line.
|
||||||
|
|
||||||
|
Potential ideas are to add options to add a given file as
|
||||||
|
`authorized_keys` (e.g. a users public key) or to just add the Dom0's
|
||||||
|
`/root/.ssh/authorized_keys` as the DomU's one.
|
||||||
|
|
||||||
|
* More generic roles
|
||||||
|
|
||||||
|
Deploy a web server or setup ssmtp directly via flag when setting up
|
||||||
|
the machine. Open to suggestions, should just be some general use-cases
|
||||||
|
that are fairly common.
|
||||||
|
|
||||||
|
* Sections for the xen-tools.conf file
|
||||||
|
|
||||||
|
Currently it's really annoying when you are trying to create VMs
|
||||||
|
on multiple subnets. It would be nice to specify with a flag what
|
||||||
|
"type" of configuration you want, and a set of options specific to
|
||||||
|
that flag could be parsed from xen-tools.conf
|
||||||
|
|
||||||
|
* Refactor the code for less variants of calling `cp`, `rm`, `mv`, etc.
|
||||||
|
|
||||||
|
E.g. always use either `cp()` from `File::Copy` or `/bin/cp`, but
|
||||||
|
not both. To allow verbose copying, I (Axel) would prefer `/bin/cp`
|
||||||
|
over `cp();`.
|
||||||
|
|
||||||
|
* Parse numerical parameters transparently for the user
|
||||||
|
|
||||||
|
The user shouldn't have to know whether he should specify size as
|
||||||
|
`<size>G` or `<size>Gb` or `<size>`. This should be parsed without
|
||||||
|
user interaction and rely on a common format.
|
||||||
|
|
||||||
|
* `xen-update-image` should mount `/dev/pts` before running apt-get
|
||||||
|
|
||||||
|
* `xen-update-image` should have options for using …
|
||||||
|
|
||||||
|
* aptitude instead of apt-get
|
||||||
|
* dist-upgrade instead of upgrade
|
||||||
|
|
||||||
|
* Support `cpu_weight` and other features from
|
||||||
|
http://wiki.xensource.com/xenwiki/CreditScheduler
|
||||||
|
|
||||||
|
* Make used Xen toolstack configurable, i.e. via --xen-toolstack=xl
|
||||||
|
|
||||||
|
* Code Deduplication / Refactor the code for less code duplication
|
||||||
|
|
||||||
|
`bin/x*` currently contain the same or similar code like e.g. in the
|
||||||
|
function readConfigurationFile. This needs to be cleaned up.
|
||||||
|
|
||||||
|
* Unify --debug and --dumpconfig. Likely make --debug exit
|
||||||
|
gracefully. Document --debug if --dumpconfig is removed.
|
||||||
|
|
||||||
|
* Use `Perl::Critic`
|
||||||
|
|
||||||
|
* Refactor the different Ubuntu hooks directories so that only one
|
||||||
|
ubuntu hooks directory is left.
|
||||||
|
|
||||||
|
Then also refactor TLS disabling so that it works on all
|
||||||
|
distributions the same. Currently Debian is a special case and
|
||||||
|
Ubuntu half a special case.
|
||||||
|
|
||||||
|
* Replace findBinary() with File::Which
|
||||||
|
|
||||||
|
* Remove from the (unused) Xen::Tools what's already in the used
|
||||||
|
Xen::Tools::Common.
|
||||||
|
|
||||||
|
Stuff from Steve's TODO list / Generic TODOs
|
||||||
|
--------------------------------------------
|
||||||
|
|
||||||
|
* Write more test cases.
|
||||||
|
|
||||||
|
* `xen-delete-image` should unallocate any used IP addresses.
|
||||||
|
|
||||||
|
* `installGentooPackage` in `hooks/common.sh` is a stub and does
|
||||||
|
nothing yet.
|
||||||
|
|
||||||
|
Axel's Break-Backwards-Compatibility Wishlist
|
||||||
|
---------------------------------------------
|
||||||
|
|
||||||
|
* Make empty extension the default
|
||||||
|
|
||||||
|
This would ease tab completion and CLI parameter reusage with "xm
|
||||||
|
create" and friends.
|
||||||
|
|
||||||
|
* Check if we can reduce `MAKEDEV` invocations in
|
||||||
|
`hooks/common/55-create-dev`
|
||||||
|
|
||||||
|
`MAKEDEV std` is called in any case. First comment says "Early
|
||||||
|
termination if we have a couple of common devices present should
|
||||||
|
speed up installs which use `--copy`/`--tar`" and then "We still
|
||||||
|
need to make sure the basic devices are present" and calls `MAKEDEV`
|
||||||
|
more often than otherwise.
|
||||||
|
|
||||||
|
Additionally the `55-create-dev` for CentOS/Fedora just created
|
||||||
|
`console`, `zero` and `null`. `zero` and `null` are part of `MAKEDEV
|
||||||
|
std`, perhaps can we reduce it to that. `console` is part of
|
||||||
|
`MAKEDEV generic`.
|
||||||
|
|
||||||
|
Additionally the devices `hda`, `sda` and `tty1` may not necessary
|
||||||
|
in any case, but instead `hvc0` should be created for sure in many
|
||||||
|
cases. Nothing cares about `$serial_device` there either.
|
||||||
|
|
||||||
|
Current `MAKEDEV` implementation support more than one device as
|
||||||
|
parameter. That could reduce the `MAKEDEV` calls from currently six
|
||||||
|
to two.
|
||||||
|
|
||||||
|
* Uncouple generating auto start symlinks from `--boot`.
|
||||||
|
|
||||||
|
Maybe add some `--autostart` or such.
|
||||||
|
|
||||||
|
* Maybe replace findBinary with File::Which
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -112,7 +112,7 @@ use Env;
|
|||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
use Text::Template;
|
use Text::Template;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -131,7 +131,7 @@ $CONFIG{ 'template' } = '/etc/xen-tools/xm-nfs.tmpl';
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
# store version number away.
|
# store version number away.
|
||||||
@@ -141,7 +141,7 @@ $CONFIG{ 'xen_tools_version' } = $RELEASE;
|
|||||||
#
|
#
|
||||||
# Read the global configuration file.
|
# Read the global configuration file.
|
||||||
#
|
#
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -170,7 +170,7 @@ if ( -e "/etc/xen/$CONFIG{'hostname'}.cfg" )
|
|||||||
#
|
#
|
||||||
if ( $CONFIG{ 'admins' } )
|
if ( $CONFIG{ 'admins' } )
|
||||||
{
|
{
|
||||||
setupAdminUsers();
|
setupAdminUsers(\%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -186,88 +186,6 @@ createNewConfigurationFile();
|
|||||||
exit;
|
exit;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the specified configuration file, and update our global configuration
|
|
||||||
hash with the values found in it.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
# Don't read the file if it doesn't exist.
|
|
||||||
return if ( !-e $file );
|
|
||||||
|
|
||||||
|
|
||||||
my $line = "";
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
while ( defined( $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Parse the command line arguments this script was given.
|
Parse the command line arguments this script was given.
|
||||||
@@ -324,13 +242,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.13 $';
|
logprint("xen-create-nfs release $RELEASE\n");
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
logprint("xen-create-nfs release $RELEASE - CVS: $REVISION\n");
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -409,82 +321,6 @@ sub testArguments
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
This routine is designed to ensure that any users specified with
|
|
||||||
the --admins flag are setup as administrators of the new instance.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub setupAdminUsers
|
|
||||||
{
|
|
||||||
|
|
||||||
#
|
|
||||||
# If we're not root we can't modify users.
|
|
||||||
#
|
|
||||||
return if ( $EFFECTIVE_USER_ID != 0 );
|
|
||||||
|
|
||||||
#
|
|
||||||
# If we don't have a sudoers file then we'll also ignore this.
|
|
||||||
#
|
|
||||||
return if ( !-e "/etc/sudoers" );
|
|
||||||
|
|
||||||
#
|
|
||||||
# Find the path to the xen-login-shell
|
|
||||||
#
|
|
||||||
my $shell = undef;
|
|
||||||
$shell = "/usr/bin/xen-login-shell" if ( -x "/usr/bin/xen-login-shell" );
|
|
||||||
$shell = "/usr/local/bin/xen-login-shell"
|
|
||||||
if ( -x "/usr/bin/local/xen-login-shell" );
|
|
||||||
|
|
||||||
return if ( !defined($shell) );
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# For each user make sure they exist, and setup the
|
|
||||||
# login shell for them.
|
|
||||||
#
|
|
||||||
foreach my $user ( split( /,/, $ENV{ 'admins' } ) )
|
|
||||||
{
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$user =~ s/^\s+//;
|
|
||||||
$user =~ s/\s+$//;
|
|
||||||
|
|
||||||
# Ignore root
|
|
||||||
next if ( $user =~ /^root$/i );
|
|
||||||
|
|
||||||
# Does the user exist?
|
|
||||||
if ( getpwnam($user) )
|
|
||||||
{
|
|
||||||
|
|
||||||
# Change shell.
|
|
||||||
$CONFIG{ 'verbose' } && print "Changing shell for $user: $shell\n";
|
|
||||||
system( "chsh", "-s", $shell, $user );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
|
|
||||||
# Add a new user.
|
|
||||||
$CONFIG{ 'verbose' } && print "Adding new user: $user\n";
|
|
||||||
system( "useradd", "-s", $shell, $user );
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
|
||||||
# Add the entry to /etc/sudoers.
|
|
||||||
#
|
|
||||||
open( SUDOERS, ">>", "/etc/sudoers" ) or
|
|
||||||
warn "Failed to add user to sudoers file : $user - $!";
|
|
||||||
print SUDOERS
|
|
||||||
"$user ALL = NOPASSWD: /usr/sbin/xm, /usr/bin/xen-create-image\n";
|
|
||||||
close(SUDOERS);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Create the Xen configuration file for our new Xen guest.
|
Create the Xen configuration file for our new Xen guest.
|
||||||
|
|||||||
@@ -8,6 +8,10 @@ xen-delete-image - Delete previously created Xen instances.
|
|||||||
|
|
||||||
xen-delete-image [options] [--hostname=]imageName1 [--hostname=]imageName2
|
xen-delete-image [options] [--hostname=]imageName1 [--hostname=]imageName2
|
||||||
|
|
||||||
|
Filename Options:
|
||||||
|
--extension Specify the file extension to use. An empty extension is equal
|
||||||
|
to any extension.
|
||||||
|
|
||||||
Help Options:
|
Help Options:
|
||||||
--help Show help information.
|
--help Show help information.
|
||||||
--manual Read the manual for this script.
|
--manual Read the manual for this script.
|
||||||
@@ -23,7 +27,8 @@ xen-delete-image - Delete previously created Xen instances.
|
|||||||
--hostname Specify the image name to delete.
|
--hostname Specify the image name to delete.
|
||||||
|
|
||||||
Testing options:
|
Testing options:
|
||||||
--test Don't complain if we're not invoked by root.
|
--test Don't complain if we're not invoked by root.
|
||||||
|
--no-xen-ok Don't complain if xen seems not installed or xend is not running
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
@@ -141,7 +146,7 @@ Show the version number and exit.
|
|||||||
|
|
||||||
=head1 LICENSE
|
=head1 LICENSE
|
||||||
|
|
||||||
Copyright (c) 2005-2009 by Steve Kemp, (c) 2010 by The Xen-Tools
|
Copyright (c) 2005-2009 by Steve Kemp, (c) 2010-2013 by The Xen-Tools
|
||||||
Development Team. All rights reserved.
|
Development Team. All rights reserved.
|
||||||
|
|
||||||
This module is free software;
|
This module is free software;
|
||||||
@@ -158,6 +163,7 @@ use English;
|
|||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
use File::Path;
|
use File::Path;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -171,16 +177,26 @@ my %CONFIG;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find xen toolstack command
|
||||||
|
#
|
||||||
|
$CONFIG{ 'xm' } = findXenToolstack();
|
||||||
|
|
||||||
|
#
|
||||||
|
# Default values
|
||||||
|
#
|
||||||
|
$CONFIG{ 'extension' } = '.cfg';
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Read the global configuration file if it exists.
|
# Read the global configuration file if it exists.
|
||||||
#
|
#
|
||||||
if ( -e "/etc/xen-tools/xen-tools.conf" )
|
if ( -e "/etc/xen-tools/xen-tools.conf" )
|
||||||
{
|
{
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -220,7 +236,7 @@ E_O_ROOT
|
|||||||
#
|
#
|
||||||
while ( my $name = shift )
|
while ( my $name = shift )
|
||||||
{
|
{
|
||||||
if ( !xenRunning($name) )
|
if ( $CONFIG{ 'no_xen_ok' } or !xenRunning($name, \%CONFIG) )
|
||||||
{
|
{
|
||||||
deleteXenImage($name);
|
deleteXenImage($name);
|
||||||
}
|
}
|
||||||
@@ -236,7 +252,9 @@ while ( my $name = shift )
|
|||||||
my $hosts = $CONFIG{ 'hostname' };
|
my $hosts = $CONFIG{ 'hostname' };
|
||||||
foreach my $name (@$hosts)
|
foreach my $name (@$hosts)
|
||||||
{
|
{
|
||||||
if ( !xenRunning($name) )
|
my %PER_HOST_CONFIG = %CONFIG;
|
||||||
|
$PER_HOST_CONFIG{ 'hostname' } = $name;
|
||||||
|
if ( $CONFIG{ 'no_xen_ok' } or !xenRunning($name, \%PER_HOST_CONFIG) )
|
||||||
{
|
{
|
||||||
deleteXenImage($name);
|
deleteXenImage($name);
|
||||||
}
|
}
|
||||||
@@ -253,81 +271,6 @@ exit 0;
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the configuration file specified.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
my $line = "";
|
|
||||||
|
|
||||||
while ( defined( $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
@@ -350,9 +293,11 @@ sub parseCommandLineArguments
|
|||||||
"dry-run", \$CONFIG{ 'dry-run' },
|
"dry-run", \$CONFIG{ 'dry-run' },
|
||||||
"lvm=s", \$CONFIG{ 'lvm' },
|
"lvm=s", \$CONFIG{ 'lvm' },
|
||||||
"evms=s", \$CONFIG{ 'evms' },
|
"evms=s", \$CONFIG{ 'evms' },
|
||||||
|
"extension:s", \$CONFIG{ 'extension' },
|
||||||
"hostname=s@", \$CONFIG{ 'hostname' },
|
"hostname=s@", \$CONFIG{ 'hostname' },
|
||||||
"test", \$CONFIG{ 'test' },
|
"test", \$CONFIG{ 'test' },
|
||||||
"verbose", \$CONFIG{ 'verbose' },
|
"verbose", \$CONFIG{ 'verbose' },
|
||||||
|
"no-xen-ok", \$CONFIG{ 'no_xen_ok' },
|
||||||
"help", \$HELP,
|
"help", \$HELP,
|
||||||
"manual", \$MANUAL,
|
"manual", \$MANUAL,
|
||||||
"version", \$VERSION
|
"version", \$VERSION
|
||||||
@@ -364,14 +309,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.41 $';
|
print "xen-delete-image release $RELEASE\n";
|
||||||
|
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
print "xen-delete-image release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -424,33 +362,6 @@ sub checkArguments
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Test to see if the given instance is running.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub xenRunning
|
|
||||||
{
|
|
||||||
my ($hostname) = (@_);
|
|
||||||
|
|
||||||
my $running = 0;
|
|
||||||
|
|
||||||
open( CMD, "xm list $hostname 2>/dev/null |" ) or
|
|
||||||
die "Failed to run 'xm list $hostname'";
|
|
||||||
while (<CMD>)
|
|
||||||
{
|
|
||||||
my $line = $_;
|
|
||||||
$running = 1 if ( $line =~ /\Q$hostname\E/ );
|
|
||||||
}
|
|
||||||
close(CMD);
|
|
||||||
|
|
||||||
return ($running);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Delete the named image, and the corresponding configuration file
|
Delete the named image, and the corresponding configuration file
|
||||||
@@ -472,17 +383,17 @@ sub deleteXenImage
|
|||||||
#
|
#
|
||||||
# Delete the Xen auto-start file if it exists.
|
# Delete the Xen auto-start file if it exists.
|
||||||
#
|
#
|
||||||
if ( -e "/etc/xen/auto/$hostname.cfg" )
|
if ( -e "/etc/xen/auto/$hostname".$CONFIG{ 'extension' } )
|
||||||
{
|
{
|
||||||
push( @delete, "/etc/xen/auto/$hostname.cfg" );
|
push( @delete, "/etc/xen/auto/$hostname".$CONFIG{ 'extension' } );
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# Delete the Xen configuration file if it exists.
|
# Delete the Xen configuration file if it exists.
|
||||||
#
|
#
|
||||||
if ( -e "/etc/xen/$hostname.cfg" )
|
if ( -e "/etc/xen/$hostname".$CONFIG{ 'extension' } )
|
||||||
{
|
{
|
||||||
push( @delete, "/etc/xen/$hostname.cfg" );
|
push( @delete, "/etc/xen/$hostname".$CONFIG{ 'extension' } );
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -539,7 +450,7 @@ sub deleteXenImage
|
|||||||
print "Would remove LVM swap volume /dev/$CONFIG{'lvm'}/$hostname-swap\n";
|
print "Would remove LVM swap volume /dev/$CONFIG{'lvm'}/$hostname-swap\n";
|
||||||
} else {
|
} else {
|
||||||
print "Removing swap volume\n";
|
print "Removing swap volume\n";
|
||||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-swap --force");
|
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-swap --force", \%CONFIG);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -549,7 +460,7 @@ sub deleteXenImage
|
|||||||
print "Would remove LVM disk volume /dev/$CONFIG{'lvm'}/$hostname-disk\n";
|
print "Would remove LVM disk volume /dev/$CONFIG{'lvm'}/$hostname-disk\n";
|
||||||
} else {
|
} else {
|
||||||
print "Removing LVM disk volume\n";
|
print "Removing LVM disk volume\n";
|
||||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-disk --force");
|
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-disk --force", \%CONFIG);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -571,8 +482,8 @@ sub deleteXenImage
|
|||||||
print "Would remove EVMS swap volume: $CONFIG{'evms'}/$hostname-swap\n";
|
print "Would remove EVMS swap volume: $CONFIG{'evms'}/$hostname-swap\n";
|
||||||
} else {
|
} else {
|
||||||
print "Removing EVMS swap volume\n";
|
print "Removing EVMS swap volume\n";
|
||||||
runCommand("echo Delete : /dev/evms/$hostname-swap | evms");
|
runCommand("echo Delete : /dev/evms/$hostname-swap | evms", \%CONFIG);
|
||||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-swap | evms");
|
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-swap | evms", \%CONFIG);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -583,8 +494,8 @@ sub deleteXenImage
|
|||||||
print "Would remove EVMS disk volume: $CONFIG{'evms'}/$hostname-swap\n";
|
print "Would remove EVMS disk volume: $CONFIG{'evms'}/$hostname-swap\n";
|
||||||
} else {
|
} else {
|
||||||
print "Removing EVMS disk volume\n";
|
print "Removing EVMS disk volume\n";
|
||||||
runCommand("echo Delete : /dev/evms/$hostname-disk | evms");
|
runCommand("echo Delete : /dev/evms/$hostname-disk | evms", \%CONFIG);
|
||||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-disk | evms");
|
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-disk | evms", \%CONFIG);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -597,66 +508,3 @@ sub deleteXenImage
|
|||||||
exit 127;
|
exit 127;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
A utility method to run a system command. We will capture the return
|
|
||||||
value and exit if the command files.
|
|
||||||
|
|
||||||
When running verbosely we will also display any command output.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub runCommand
|
|
||||||
{
|
|
||||||
my ($cmd) = (@_);
|
|
||||||
|
|
||||||
#
|
|
||||||
# Header.
|
|
||||||
#
|
|
||||||
$CONFIG{ 'verbose' } && print "Executing : $cmd\n";
|
|
||||||
|
|
||||||
#
|
|
||||||
# Hide output unless running with --debug.
|
|
||||||
#
|
|
||||||
if ( $CONFIG{ 'verbose' } )
|
|
||||||
{
|
|
||||||
|
|
||||||
#
|
|
||||||
# Copy stderr to stdout, so we can see it.
|
|
||||||
#
|
|
||||||
$cmd .= " 2>&1";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$cmd .= " >/dev/null 2>/dev/null";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Run it.
|
|
||||||
#
|
|
||||||
my $output = `$cmd`;
|
|
||||||
|
|
||||||
if ( $? != 0 )
|
|
||||||
{
|
|
||||||
print "Running command '$cmd' failed.\n";
|
|
||||||
print "Aborting\n";
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# All done.
|
|
||||||
#
|
|
||||||
$CONFIG{ 'verbose' } && print "Output\n";
|
|
||||||
$CONFIG{ 'verbose' } && print "======\n";
|
|
||||||
$CONFIG{ 'verbose' } && print $output . "\n";
|
|
||||||
$CONFIG{ 'verbose' } && print "Finished : $cmd\n";
|
|
||||||
|
|
||||||
return ($output);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -8,6 +8,10 @@ xen-list-images - List all the created and configured Xen images.
|
|||||||
|
|
||||||
xen-list-image [options]
|
xen-list-image [options]
|
||||||
|
|
||||||
|
Filename Options:
|
||||||
|
--extension Specify the file extension to use. An empty extension is equal
|
||||||
|
to any extension.
|
||||||
|
|
||||||
Help Options:
|
Help Options:
|
||||||
--help Show this scripts help information.
|
--help Show this scripts help information.
|
||||||
--manual Read this scripts manual.
|
--manual Read this scripts manual.
|
||||||
@@ -67,7 +71,7 @@ Show the version number and exit.
|
|||||||
|
|
||||||
=head1 LICENSE
|
=head1 LICENSE
|
||||||
|
|
||||||
Copyright (c) 2005-2009 by Steve Kemp, (c) 2010 by The Xen-Tools
|
Copyright (c) 2005-2009 by Steve Kemp, (c) 2010-2013 by The Xen-Tools
|
||||||
Development Team. All rights reserved.
|
Development Team. All rights reserved.
|
||||||
|
|
||||||
This module is free software;
|
This module is free software;
|
||||||
@@ -83,6 +87,7 @@ use English;
|
|||||||
use File::Temp qw/ tempdir /;
|
use File::Temp qw/ tempdir /;
|
||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -94,21 +99,22 @@ use Pod::Usage;
|
|||||||
my %CONFIG;
|
my %CONFIG;
|
||||||
|
|
||||||
#
|
#
|
||||||
# Default prefix
|
# Default values
|
||||||
#
|
#
|
||||||
$CONFIG{ 'prefix' } = "/etc/xen";
|
$CONFIG{ 'prefix' } = "/etc/xen";
|
||||||
|
$CONFIG{ 'extension' } = '.cfg';
|
||||||
|
|
||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Read the global configuration file if it exists.
|
# Read the global configuration file if it exists.
|
||||||
#
|
#
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -144,83 +150,6 @@ exit;
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the configuration file specified.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
# Don't read the file if it doesn't exist.
|
|
||||||
return if ( !-e $file );
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
|
|
||||||
while ( defined( my $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Parse the arguments specified upon the command line.
|
Parse the arguments specified upon the command line.
|
||||||
@@ -238,6 +167,7 @@ sub parseCommandLineArguments
|
|||||||
# Parse options.
|
# Parse options.
|
||||||
#
|
#
|
||||||
GetOptions( "test=s", \$CONFIG{ 'prefix' },
|
GetOptions( "test=s", \$CONFIG{ 'prefix' },
|
||||||
|
"extension:s", \$CONFIG{ 'extension' },
|
||||||
"help", \$HELP,
|
"help", \$HELP,
|
||||||
"manual", \$MANUAL,
|
"manual", \$MANUAL,
|
||||||
"version", \$VERSION );
|
"version", \$VERSION );
|
||||||
@@ -248,13 +178,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.30 $';
|
print "xen-list-images release $RELEASE\n";
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
print "xen-list-images release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -274,9 +198,12 @@ sub findXenInstances
|
|||||||
{
|
{
|
||||||
my @found;
|
my @found;
|
||||||
|
|
||||||
foreach my $file ( sort( glob( $CONFIG{ 'prefix' } . "/*.cfg" ) ) )
|
foreach my $file ( sort( glob( $CONFIG{ 'prefix' } . "/*" . $CONFIG{ 'extension' } ) ) )
|
||||||
{
|
{
|
||||||
push @found, $file if ( -e $file );
|
push @found, $file if (
|
||||||
|
-f $file and
|
||||||
|
$file !~ m(~$|\.dpkg-[a-z]+$|\.sxp$|/xl\.conf$)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (@found);
|
return (@found);
|
||||||
@@ -341,6 +268,7 @@ sub displayInstance
|
|||||||
print "Memory: $mem\n";
|
print "Memory: $mem\n";
|
||||||
print "IP: " . $ip . $mac . "\n" if length($ip);
|
print "IP: " . $ip . $mac . "\n" if length($ip);
|
||||||
print "DHCP" . $mac . "\n" if $dhcp;
|
print "DHCP" . $mac . "\n" if $dhcp;
|
||||||
|
print "Config: $file\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -104,6 +104,7 @@ use Env;
|
|||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
use Text::Template;
|
use Text::Template;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -116,14 +117,19 @@ my %CONFIG;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find xen toolstack command
|
||||||
|
#
|
||||||
|
$CONFIG{ 'xm' } = findXenToolstack();
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Read the global configuration file.
|
# Read the global configuration file.
|
||||||
#
|
#
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -289,84 +295,6 @@ exit 0;
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the configuration file specified.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
# Don't read the file if it doesn't exist.
|
|
||||||
return if ( !-e $file );
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
my $line = "";
|
|
||||||
|
|
||||||
while ( defined( $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Parse the command line arguments this script was given.
|
Parse the command line arguments this script was given.
|
||||||
@@ -482,7 +410,7 @@ EOF
|
|||||||
#
|
#
|
||||||
# Make sure the guest isn't running
|
# Make sure the guest isn't running
|
||||||
#
|
#
|
||||||
if ( xenRunning( $CONFIG{ 'hostname' } ) )
|
if ( xenRunning( $CONFIG{ 'hostname' }, \%CONFIG ) )
|
||||||
{
|
{
|
||||||
print "The guest $CONFIG{'hostname'} appears to be running!\n";
|
print "The guest $CONFIG{'hostname'} appears to be running!\n";
|
||||||
exit 1;
|
exit 1;
|
||||||
@@ -523,31 +451,3 @@ EOF
|
|||||||
$CONFIG{ 'add' } = $1;
|
$CONFIG{ 'add' } = $1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Test to see if the given instance is running.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub xenRunning
|
|
||||||
{
|
|
||||||
my ($hostname) = (@_);
|
|
||||||
|
|
||||||
my $running = 0;
|
|
||||||
|
|
||||||
open( CMD, "xm list $hostname 2>/dev/null |" ) or
|
|
||||||
die "Failed to run 'xm list $hostname'";
|
|
||||||
while (<CMD>)
|
|
||||||
{
|
|
||||||
my $line = $_;
|
|
||||||
$running = 1 if ( $line =~ /\Q$hostname\E/ );
|
|
||||||
}
|
|
||||||
close(CMD);
|
|
||||||
|
|
||||||
return ($running);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -107,6 +107,7 @@ use File::Temp qw/ tempdir /;
|
|||||||
use File::Copy qw/ mv cp /;
|
use File::Copy qw/ mv cp /;
|
||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -120,7 +121,13 @@ my %CONFIG;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find xen toolstack command
|
||||||
|
#
|
||||||
|
$CONFIG{ 'xm' } = findXenToolstack();
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -128,7 +135,7 @@ my $RELEASE = '4.3rc1';
|
|||||||
#
|
#
|
||||||
if ( -e "/etc/xen-tools/xen-tools.conf" )
|
if ( -e "/etc/xen-tools/xen-tools.conf" )
|
||||||
{
|
{
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -168,7 +175,7 @@ E_O_ROOT
|
|||||||
#
|
#
|
||||||
while ( my $name = shift )
|
while ( my $name = shift )
|
||||||
{
|
{
|
||||||
if ( !xenRunning($name) )
|
if ( !xenRunning($name, \%CONFIG) )
|
||||||
{
|
{
|
||||||
updateXenImage($name);
|
updateXenImage($name);
|
||||||
}
|
}
|
||||||
@@ -331,110 +338,6 @@ sub updateXenImage
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Test to see if the given instance is running.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub xenRunning
|
|
||||||
{
|
|
||||||
my ($hostname) = (@_);
|
|
||||||
|
|
||||||
my $running = 0;
|
|
||||||
|
|
||||||
open( CMD, "xm list 2>/dev/null |" ) or
|
|
||||||
die "Failed to run 'xm list $hostname'";
|
|
||||||
while (<CMD>)
|
|
||||||
{
|
|
||||||
my $line = $_;
|
|
||||||
$running = 1 if ( $line =~ /\Q$hostname\E/ );
|
|
||||||
}
|
|
||||||
close(CMD);
|
|
||||||
|
|
||||||
return ($running);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the configuration file specified.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
my $line = "";
|
|
||||||
|
|
||||||
while ( defined( $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Parse the arguments specified upon the command line.
|
Parse the arguments specified upon the command line.
|
||||||
@@ -463,13 +366,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.29 $';
|
print "xen-update-image release $RELEASE\n";
|
||||||
|
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
print "xen-update-image release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -156,7 +156,7 @@ $CONFIG{ 'extension' } = '.cfg';
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -177,7 +177,7 @@ checkArguments();
|
|||||||
#
|
#
|
||||||
if ( $ENV{ 'admins' } )
|
if ( $ENV{ 'admins' } )
|
||||||
{
|
{
|
||||||
setupAdminUsers();
|
setupAdminUsers(\%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -215,7 +215,7 @@ sub parseCommandLineArguments
|
|||||||
#
|
#
|
||||||
GetOptions( "admins=s", \$ENV{ 'admins' },
|
GetOptions( "admins=s", \$ENV{ 'admins' },
|
||||||
"output=s", \$CONFIG{ 'output' },
|
"output=s", \$CONFIG{ 'output' },
|
||||||
"extension=s", \$CONFIG{ 'extension' },
|
"extension:s", \$CONFIG{ 'extension' },
|
||||||
"template=s", \$CONFIG{ 'template' },
|
"template=s", \$CONFIG{ 'template' },
|
||||||
"verbose", \$CONFIG{ 'verbose' },
|
"verbose", \$CONFIG{ 'verbose' },
|
||||||
"help", \$HELP,
|
"help", \$HELP,
|
||||||
@@ -229,13 +229,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.47 $';
|
print "xt-create-xen-config release $RELEASE\n";
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
print "xt-create-xen-config release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -375,7 +369,7 @@ sub createXenConfig
|
|||||||
#
|
#
|
||||||
# The memory size: Convert Gb -> Mb.
|
# The memory size: Convert Gb -> Mb.
|
||||||
#
|
#
|
||||||
if ( $ENV{ 'memory' } =~ /^(\d+)Gb.*$/i )
|
if ( $ENV{ 'memory' } =~ /^(\d+)Gb?.*$/i )
|
||||||
{
|
{
|
||||||
$ENV{ 'memory' } = $1 * 1024;
|
$ENV{ 'memory' } = $1 * 1024;
|
||||||
}
|
}
|
||||||
@@ -383,7 +377,7 @@ sub createXenConfig
|
|||||||
#
|
#
|
||||||
# Remove any trailing Mb.
|
# Remove any trailing Mb.
|
||||||
#
|
#
|
||||||
if ( $ENV{ 'memory' } =~ /^(\d+)Mb.*$/i )
|
if ( $ENV{ 'memory' } =~ /^(\d+)Mb?.*$/i )
|
||||||
{
|
{
|
||||||
$ENV{ 'memory' } = $1;
|
$ENV{ 'memory' } = $1;
|
||||||
}
|
}
|
||||||
@@ -404,13 +398,13 @@ sub createXenConfig
|
|||||||
$ENV{ 'image_suffix' } = '';
|
$ENV{ 'image_suffix' } = '';
|
||||||
importPartitionsFromEnvironment();
|
importPartitionsFromEnvironment();
|
||||||
}
|
}
|
||||||
elsif ( $ENV{ 'image-dev' } )
|
elsif ( $ENV{ 'image_dev' } )
|
||||||
{
|
{
|
||||||
$ENV{ 'image_vbd' } = "phy:$ENV{'image-dev'}";
|
$ENV{ 'image_vbd' } = "phy:$ENV{'image_dev'}";
|
||||||
|
|
||||||
if ( $ENV{ 'swap-dev' } )
|
if ( $ENV{ 'swap_dev' } )
|
||||||
{
|
{
|
||||||
$ENV{ 'swap_vbd' } = "phy:$ENV{'swap-dev'}";
|
$ENV{ 'swap_vbd' } = "phy:$ENV{'swap_dev'}";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -470,80 +464,3 @@ sub createXenConfig
|
|||||||
close(FILE);
|
close(FILE);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
This routine is designed to ensure that any users specified with
|
|
||||||
the --admins flag are setup as administrators of the new instance.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub setupAdminUsers
|
|
||||||
{
|
|
||||||
|
|
||||||
#
|
|
||||||
# If we're not root we can't modify users.
|
|
||||||
#
|
|
||||||
return if ( $EFFECTIVE_USER_ID != 0 );
|
|
||||||
|
|
||||||
#
|
|
||||||
# If we don't have a sudoers file then we'll also ignore this.
|
|
||||||
#
|
|
||||||
return if ( !-e "/etc/sudoers" );
|
|
||||||
|
|
||||||
#
|
|
||||||
# Find the path to the xen-login-shell
|
|
||||||
#
|
|
||||||
my $shell = undef;
|
|
||||||
$shell = "/usr/bin/xen-login-shell" if ( -x "/usr/bin/xen-login-shell" );
|
|
||||||
$shell = "/usr/local/bin/xen-login-shell"
|
|
||||||
if ( -x "/usr/bin/local/xen-login-shell" );
|
|
||||||
|
|
||||||
return if ( !defined($shell) );
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# For each user make sure they exist, and setup the
|
|
||||||
# login shell for them.
|
|
||||||
#
|
|
||||||
foreach my $user ( split( /,/, $ENV{ 'admins' } ) )
|
|
||||||
{
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$user =~ s/^\s+//;
|
|
||||||
$user =~ s/\s+$//;
|
|
||||||
|
|
||||||
# Ignore root
|
|
||||||
next if ( $user =~ /^root$/i );
|
|
||||||
|
|
||||||
# Does the user exist?
|
|
||||||
if ( getpwnam($user) )
|
|
||||||
{
|
|
||||||
|
|
||||||
# Change shell.
|
|
||||||
$CONFIG{ 'verbose' } && print "Changing shell for $user: $shell\n";
|
|
||||||
system( "chsh", "-s", $shell, $user );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
|
|
||||||
# Add a new user.
|
|
||||||
$CONFIG{ 'verbose' } && print "Adding new user: $user\n";
|
|
||||||
system( "useradd", "-s", $shell, $user );
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
|
||||||
# Add the entry to /etc/sudoers.
|
|
||||||
#
|
|
||||||
open( SUDOERS, ">>", "/etc/sudoers" ) or
|
|
||||||
warn "Failed to add user to sudoers file : $user - $!";
|
|
||||||
print SUDOERS
|
|
||||||
"$user ALL = NOPASSWD: /usr/sbin/xm, /usr/bin/xen-create-image\n";
|
|
||||||
close(SUDOERS);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -54,7 +54,7 @@ xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
|||||||
the --location option.
|
the --location option.
|
||||||
|
|
||||||
For the distribution named 'foo' the scripts will be loaded and
|
For the distribution named 'foo' the scripts will be loaded and
|
||||||
executed from '/usr/lib/xen-tools/foo.d'. Each executable will
|
executed from '/usr/share/xen-tools/foo.d'. Each executable will
|
||||||
be loaded and executed in sorted order.
|
be loaded and executed in sorted order.
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
@@ -98,7 +98,7 @@ my %CONFIG;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -159,13 +159,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.33 $';
|
print "xt-customize-image release $RELEASE\n";
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
print "xt-customize-image release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -221,7 +215,7 @@ sub checkArguments
|
|||||||
# If there are no scripts then we clearly cannot
|
# If there are no scripts then we clearly cannot
|
||||||
# customise it!
|
# customise it!
|
||||||
#
|
#
|
||||||
my $dir = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
my $dir = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||||
|
|
||||||
if ( !-d $dir )
|
if ( !-d $dir )
|
||||||
{
|
{
|
||||||
@@ -263,7 +257,7 @@ sub runDistributionHooks
|
|||||||
#
|
#
|
||||||
# Hook directory.
|
# Hook directory.
|
||||||
#
|
#
|
||||||
my $hooks = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d/";
|
my $hooks = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d/";
|
||||||
|
|
||||||
#
|
#
|
||||||
# Installation prefix
|
# Installation prefix
|
||||||
|
|||||||
@@ -55,9 +55,9 @@ full text of the license.
|
|||||||
# Fallback to Debian or Ubuntu in case we can't find anything
|
# Fallback to Debian or Ubuntu in case we can't find anything
|
||||||
my $fallback = 'Debian';
|
my $fallback = 'Debian';
|
||||||
|
|
||||||
# Which mirrors to use if everything else fails (cdn.debian.net uses
|
# Which mirrors to use if everything else fails (http.debian.net
|
||||||
# GeoIP, see http://wiki.debian.org/DebianGeoMirror)
|
# redirects to a working mirror nearby)
|
||||||
my %fallback_mirror = ( Debian => 'http://cdn.debian.net/debian/',
|
my %fallback_mirror = ( Debian => 'http://http.debian.net/debian/',
|
||||||
Ubuntu => 'http://archive.ubuntu.com/ubuntu/' );
|
Ubuntu => 'http://archive.ubuntu.com/ubuntu/' );
|
||||||
|
|
||||||
# Which suite to use if everything else fails. For Debian "stable"
|
# Which suite to use if everything else fails. For Debian "stable"
|
||||||
@@ -81,7 +81,7 @@ use strict;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
# Init
|
# Init
|
||||||
my $mirror = '';
|
my $mirror = '';
|
||||||
|
|||||||
@@ -108,6 +108,7 @@ use Env;
|
|||||||
use File::Copy;
|
use File::Copy;
|
||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
use Pod::Usage;
|
use Pod::Usage;
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -118,7 +119,7 @@ my %CONFIG;
|
|||||||
#
|
#
|
||||||
# Release number.
|
# Release number.
|
||||||
#
|
#
|
||||||
my $RELEASE = '4.3rc1';
|
my $RELEASE = '4.4~dev';
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -156,7 +157,7 @@ my %dispatch = (
|
|||||||
#
|
#
|
||||||
# Read the global configuration file.
|
# Read the global configuration file.
|
||||||
#
|
#
|
||||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -179,7 +180,7 @@ if ( $CONFIG{ 'config' } )
|
|||||||
}
|
}
|
||||||
|
|
||||||
# Read the file, if it exists.
|
# Read the file, if it exists.
|
||||||
readConfigurationFile($path) if ( -e $path );
|
readConfigurationFile($path, \%CONFIG) if ( -e $path );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -280,87 +281,6 @@ else
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
Read the specified configuration file, and update our global configuration
|
|
||||||
hash with the values found in it.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub readConfigurationFile
|
|
||||||
{
|
|
||||||
my ($file) = (@_);
|
|
||||||
|
|
||||||
# Don't read the file if it doesn't exist.
|
|
||||||
return if ( !-e $file );
|
|
||||||
|
|
||||||
|
|
||||||
my $line = "";
|
|
||||||
|
|
||||||
open( FILE, "<", $file ) or die "Cannot read file '$file' - $!";
|
|
||||||
|
|
||||||
while ( defined( $line = <FILE> ) )
|
|
||||||
{
|
|
||||||
chomp $line;
|
|
||||||
if ( $line =~ s/\\$// )
|
|
||||||
{
|
|
||||||
$line .= <FILE>;
|
|
||||||
redo unless eof(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
# Skip lines beginning with comments
|
|
||||||
next if ( $line =~ /^([ \t]*)\#/ );
|
|
||||||
|
|
||||||
# Skip blank lines
|
|
||||||
next if ( length($line) < 1 );
|
|
||||||
|
|
||||||
# Strip trailing comments.
|
|
||||||
if ( $line =~ /(.*)\#(.*)/ )
|
|
||||||
{
|
|
||||||
$line = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Find variable settings
|
|
||||||
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
|
||||||
{
|
|
||||||
my $key = $1;
|
|
||||||
my $val = $2;
|
|
||||||
|
|
||||||
# Strip leading and trailing whitespace.
|
|
||||||
$key =~ s/^\s+//;
|
|
||||||
$key =~ s/\s+$//;
|
|
||||||
$val =~ s/^\s+//;
|
|
||||||
$val =~ s/\s+$//;
|
|
||||||
|
|
||||||
# command expansion?
|
|
||||||
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
|
||||||
{
|
|
||||||
|
|
||||||
# store
|
|
||||||
my $pre = $1;
|
|
||||||
my $cmd = $2;
|
|
||||||
my $post = $3;
|
|
||||||
|
|
||||||
# get output
|
|
||||||
my $output = `$cmd`;
|
|
||||||
chomp($output);
|
|
||||||
|
|
||||||
# build up replacement.
|
|
||||||
$val = $pre . $output . $post;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Store value.
|
|
||||||
$CONFIG{ $key } = $val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
close(FILE);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
Parse the command line arguments this script was given.
|
Parse the command line arguments this script was given.
|
||||||
@@ -411,13 +331,7 @@ sub parseCommandLineArguments
|
|||||||
|
|
||||||
if ($VERSION)
|
if ($VERSION)
|
||||||
{
|
{
|
||||||
my $REVISION = '$Revision: 1.65 $';
|
print "xt-install-image release $RELEASE\n";
|
||||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
|
||||||
{
|
|
||||||
$REVISION = $1;
|
|
||||||
}
|
|
||||||
|
|
||||||
print "xt-install-image release $RELEASE - CVS: $REVISION\n";
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -473,7 +387,7 @@ sub checkArguments
|
|||||||
# If there are no scripts then we clearly cannot
|
# If there are no scripts then we clearly cannot
|
||||||
# customise it!
|
# customise it!
|
||||||
#
|
#
|
||||||
my $dir = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
my $dir = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||||
|
|
||||||
if ( !-d $dir )
|
if ( !-d $dir )
|
||||||
{
|
{
|
||||||
@@ -553,53 +467,6 @@ EOT
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
|
||||||
|
|
||||||
A utility method to run a system command. We will capture the return
|
|
||||||
value and exit if the command fails.
|
|
||||||
|
|
||||||
When running verbosely we will also display any command output.
|
|
||||||
|
|
||||||
=end doc
|
|
||||||
|
|
||||||
=cut
|
|
||||||
|
|
||||||
sub runCommand
|
|
||||||
{
|
|
||||||
my ($cmd) = (@_);
|
|
||||||
|
|
||||||
#
|
|
||||||
# Command start.
|
|
||||||
#
|
|
||||||
$CONFIG{ 'verbose' } && print "Executing : $cmd\n";
|
|
||||||
|
|
||||||
#
|
|
||||||
# Copy stderr to stdout, so we can see it, and make sure we log it.
|
|
||||||
#
|
|
||||||
$cmd .= " 2>&1 | tee --append /var/log/xen-tools/$CONFIG{'hostname'}.log";
|
|
||||||
|
|
||||||
#
|
|
||||||
# Run it.
|
|
||||||
#
|
|
||||||
my $output = `$cmd`;
|
|
||||||
|
|
||||||
if ( $? != 0 )
|
|
||||||
{
|
|
||||||
print "Running command '$cmd' failed.\n";
|
|
||||||
print "Aborting\n";
|
|
||||||
exit 127;
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
|
||||||
# Command finished.
|
|
||||||
#
|
|
||||||
$CONFIG{ 'verbose' } && print "Finished : $cmd\n";
|
|
||||||
|
|
||||||
return ($output);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
=begin doc
|
=begin doc
|
||||||
|
|
||||||
This function will copy all the .deb files from one directory
|
This function will copy all the .deb files from one directory
|
||||||
@@ -685,7 +552,7 @@ sub do_copy
|
|||||||
#
|
#
|
||||||
# Run the copy command.
|
# Run the copy command.
|
||||||
#
|
#
|
||||||
runCommand($cmd);
|
runCommand($cmd, \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -736,7 +603,7 @@ sub do_debootstrap
|
|||||||
}
|
}
|
||||||
$cachedir = $xtcache;
|
$cachedir = $xtcache;
|
||||||
}
|
}
|
||||||
runCommand("mkdir -p $CONFIG{'location'}/var/cache/apt/archives");
|
runCommand("mkdir -p $CONFIG{'location'}/var/cache/apt/archives", \%CONFIG);
|
||||||
copyDebFiles( "$cachedir",
|
copyDebFiles( "$cachedir",
|
||||||
"$CONFIG{'location'}/var/cache/apt/archives" );
|
"$CONFIG{'location'}/var/cache/apt/archives" );
|
||||||
print("Done\n");
|
print("Done\n");
|
||||||
@@ -777,7 +644,7 @@ sub do_debootstrap
|
|||||||
#
|
#
|
||||||
# Run the command.
|
# Run the command.
|
||||||
#
|
#
|
||||||
runCommand($command);
|
runCommand($command, \%CONFIG);
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -848,7 +715,7 @@ sub do_rinse
|
|||||||
$command .= " --verbose";
|
$command .= " --verbose";
|
||||||
}
|
}
|
||||||
|
|
||||||
runCommand($command);
|
runCommand($command, \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -891,7 +758,7 @@ sub do_rpmstrap
|
|||||||
# The command we're going to run.
|
# The command we're going to run.
|
||||||
#
|
#
|
||||||
my $command = "rpmstrap $EXTRA $CONFIG{'dist'} $CONFIG{'location'} $mirror";
|
my $command = "rpmstrap $EXTRA $CONFIG{'dist'} $CONFIG{'location'} $mirror";
|
||||||
runCommand($command);
|
runCommand($command, \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -925,5 +792,5 @@ sub do_tar
|
|||||||
#
|
#
|
||||||
# Run a command to copy an installed system into the new root.
|
# Run a command to copy an installed system into the new root.
|
||||||
#
|
#
|
||||||
runCommand("cd $CONFIG{'location'} && $cmd");
|
runCommand("cd $CONFIG{'location'} && $cmd", \%CONFIG);
|
||||||
}
|
}
|
||||||
|
|||||||
15
debian/NEWS
vendored
15
debian/NEWS
vendored
@@ -1,3 +1,18 @@
|
|||||||
|
xen-tools (4.4~dev-1) UNRELEASED; urgency=low
|
||||||
|
|
||||||
|
* Exported environment variables no more contain dashes ("-"). Dashes in
|
||||||
|
environment variable names are from now on converted to underscores
|
||||||
|
("_") before being exported. May affect some hook or role scripts.
|
||||||
|
|
||||||
|
* /usr/lib/xen-tools/ has been moved to /usr/share/xen-tools/ to
|
||||||
|
properly adhere to FHS. In case you had local scripts added to
|
||||||
|
/usr/lib/xen-tools/, please move them to /usr/share/xen-tools/, too
|
||||||
|
and then remove /usr/lib/xen-tools/ and its left-over subdirectories
|
||||||
|
which all should be empty at that point, i.e. "rmdir -p
|
||||||
|
/usr/lib/xen-tools/*" should do the trick.
|
||||||
|
|
||||||
|
-- Axel Beckert <abe@debian.org> Fri, 05 Apr 2013 20:19:02 +0200
|
||||||
|
|
||||||
xen-tools (4.2~rc1-1) unstable; urgency=low
|
xen-tools (4.2~rc1-1) unstable; urgency=low
|
||||||
|
|
||||||
By default, xen-create-image now generates a random root password and
|
By default, xen-create-image now generates a random root password and
|
||||||
|
|||||||
89
debian/changelog
vendored
89
debian/changelog
vendored
@@ -1,3 +1,92 @@
|
|||||||
|
xen-tools (4.4~dev-1) UNRELEASED; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
- Code deduplication to unify the xen-*-image scripts
|
||||||
|
- Moves /usr/lib/xen-tools/ to /usr/share/xen-tools/
|
||||||
|
- Use http.debian.net as default Debian mirror if no mirror is given
|
||||||
|
and xt-guess-suite-and-mirror is not used.
|
||||||
|
- Fix symbolic link hooks/centos-6/15-setup-arch (Closes: #690299)
|
||||||
|
- Execute END block not on --version/--help/--manual (Closes: #684346)
|
||||||
|
- Move code for --boot feature to END block. Fixes missing SSH
|
||||||
|
fingerprint display if --boot was used. (Closes: #679183)
|
||||||
|
- Use local parameter instead of global variable in unMountImage.
|
||||||
|
- Also recognize "M" and "G" instead of "MB" and "GB" as size unit for
|
||||||
|
--memory. (Closes: #691320) Document the recognized units.
|
||||||
|
- Default DomUs to use the noop scheduler (Closes: #693131)
|
||||||
|
- Overwork TLS disabling on Debian and Ubuntu
|
||||||
|
- xen-list-images now also outputs the file name of the config file.
|
||||||
|
- xen-list-images and xen-delete-image now understand --extension.
|
||||||
|
- Fixes "--extension=" with empty parameter.
|
||||||
|
- Sarge amd64 case handle properly
|
||||||
|
- Remove CVS revisions from --version output
|
||||||
|
- Preliminary support for Debian Jessie and Ubuntu Raring
|
||||||
|
- Preliminary support for xl toolstack
|
||||||
|
- xen-create-image: Consistently use runCommand() instead of system()
|
||||||
|
- Makefile accepts DESTDIR=…
|
||||||
|
- Move examples from debian/examples to examples.
|
||||||
|
- Uses File::Which, added (build-) dependency on libfile-which-perl
|
||||||
|
- Knows about module-init-tools → kmod transition in wheezy/raring.
|
||||||
|
- Adds default mount options for ext4, identical to ext2/ext3.
|
||||||
|
- Ships /etc/initramfs-tools/conf.d/xen-tools for generating Dom0
|
||||||
|
initrds also suitable for DomU usage. Trigger update-initramfs.
|
||||||
|
- By default install linux-image-virtual instead of linux-image-server
|
||||||
|
on Ubuntu Intrepid and newer (Hopefully closes: #640099, LP #839492)
|
||||||
|
- Installs a legacy grub in all pygrub based Debian/Ubuntu DomUs to be
|
||||||
|
able to update the menu.list automatically.
|
||||||
|
- hooks/common.sh: installDebianPackage no more installs recommends.
|
||||||
|
- hooks/common.sh: Rename installCentOS4Package to installRPMPackage.
|
||||||
|
Add installCentOS4Package wrapper for backward compatibility.
|
||||||
|
- Fix filesystem tools installation in 91-install-fs-tools (which was
|
||||||
|
broken since 4.3~rc1-1) by merging 91-install-fs-tools back into
|
||||||
|
90-make-fstab. Also supports RPM-based distributions now.
|
||||||
|
- Fix export of environment variables. Previously they could contain
|
||||||
|
dashes and then were only accessible from within Perl, but not from
|
||||||
|
within Bash.
|
||||||
|
- Uses Test::NoTabs; add according build-dependency.
|
||||||
|
* Add debian/gbp.conf to be able to to build xen-tools with
|
||||||
|
git-buildpackage.
|
||||||
|
* Clean up debian/rules:
|
||||||
|
- Don't mention (generated) upstream changelog explicitly,
|
||||||
|
dh_installchangelogs finds it by itself if it exist. That way
|
||||||
|
building out of a freshly clone git repository does not fail due to
|
||||||
|
a missing upstream changelog.
|
||||||
|
- Use dh_auto_{install,clean}; use "$(MAKE)" instead of "make" where
|
||||||
|
dh_auto_* can't help. No more explicitly call "make manpages", it's
|
||||||
|
a depedency of "make install" in the next line anyway.
|
||||||
|
- Finally switch to a minimal dh style debian/rules.
|
||||||
|
* Bump copyright years in debian/copyright.
|
||||||
|
* Apply wrap-and-sort.
|
||||||
|
|
||||||
|
-- Axel Beckert <abe@debian.org> Thu, 17 Jan 2013 17:09:02 +0100
|
||||||
|
|
||||||
|
xen-tools (4.3.1-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* Remove t/modules.t in upstream's t/Makefile instead of debian/rules'
|
||||||
|
clean target.
|
||||||
|
* Run t/hook-tls.t only if distribution actually has
|
||||||
|
10-disable-tls. Fixes test suite failure on 32 bit architectures.
|
||||||
|
|
||||||
|
-- Axel Beckert <abe@debian.org> Sat, 30 Jun 2012 16:44:50 +0200
|
||||||
|
|
||||||
|
xen-tools (4.3-1) unstable; urgency=low
|
||||||
|
|
||||||
|
* New upstream release
|
||||||
|
- Remove most Mercurial traces
|
||||||
|
* Fixes FTBFS due to testsuite failures (Closes: #676681)
|
||||||
|
- Disable tests of not yet used Xen::Tools. Fixes FTBFS in test suite
|
||||||
|
due to not satisifed Moose dependency in Xen::Tools::Log.
|
||||||
|
- Added build-dependencies on libmoose-perl, git, and
|
||||||
|
libtest-pod-coverage-perl for t/perl-syntax.t, t/gitignore.t, and
|
||||||
|
t/pod-coverage.t.
|
||||||
|
- Skip t/hook-inittab.t if /etc/inittab is not present on the build
|
||||||
|
host. Fixes FTBFS on Ubuntu.
|
||||||
|
* Switch to source format to "3.0 (quilt)"
|
||||||
|
* Don't remove stamp files manually, dh_clean does that already
|
||||||
|
* Remove generated file t/modules.t in clean target to be able to build
|
||||||
|
twice in a row.
|
||||||
|
|
||||||
|
-- Axel Beckert <abe@debian.org> Tue, 26 Jun 2012 22:23:59 +0200
|
||||||
|
|
||||||
xen-tools (4.3~rc1-1) unstable; urgency=low
|
xen-tools (4.3~rc1-1) unstable; urgency=low
|
||||||
|
|
||||||
* New upstream release candidate
|
* New upstream release candidate
|
||||||
|
|||||||
30
debian/control
vendored
30
debian/control
vendored
@@ -2,7 +2,16 @@ Source: xen-tools
|
|||||||
Section: utils
|
Section: utils
|
||||||
Priority: extra
|
Priority: extra
|
||||||
Maintainer: Axel Beckert <abe@debian.org>
|
Maintainer: Axel Beckert <abe@debian.org>
|
||||||
Build-Depends: debhelper (>= 7.0.0), libtest-pod-perl, libtext-template-perl, libfile-slurp-perl, devscripts
|
Build-Depends: debhelper (>= 7.0.0),
|
||||||
|
devscripts,
|
||||||
|
git,
|
||||||
|
libfile-slurp-perl,
|
||||||
|
libfile-which-perl,
|
||||||
|
libmoose-perl,
|
||||||
|
libtest-notabs-perl,
|
||||||
|
libtest-pod-coverage-perl,
|
||||||
|
libtest-pod-perl,
|
||||||
|
libtext-template-perl
|
||||||
Standards-Version: 3.9.3
|
Standards-Version: 3.9.3
|
||||||
Homepage: http://xen-tools.org/software/xen-tools
|
Homepage: http://xen-tools.org/software/xen-tools
|
||||||
Vcs-Browser: http://gitorious.org/xen-tools/xen-tools
|
Vcs-Browser: http://gitorious.org/xen-tools/xen-tools
|
||||||
@@ -10,9 +19,22 @@ Vcs-Git: git://gitorious.org/xen-tools/xen-tools.git
|
|||||||
|
|
||||||
Package: xen-tools
|
Package: xen-tools
|
||||||
Architecture: all
|
Architecture: all
|
||||||
Depends: debootstrap | cdebootstrap, perl-modules, libtext-template-perl, libconfig-inifiles-perl, libfile-slurp-perl, ${misc:Depends}, openssh-client
|
Depends: debootstrap | cdebootstrap,
|
||||||
Recommends: xen-hypervisor-amd64 | xen-hypervisor-i386 | xen-hypervisor-i386-pae, rinse (>= 1.9.1-1), libexpect-perl, xen-utils
|
libconfig-inifiles-perl,
|
||||||
Suggests: reiserfsprogs, xfsprogs, cfengine2, btrfs-tools
|
libfile-slurp-perl,
|
||||||
|
libfile-which-perl,
|
||||||
|
libtext-template-perl,
|
||||||
|
openssh-client,
|
||||||
|
perl-modules,
|
||||||
|
${misc:Depends}
|
||||||
|
Recommends: libexpect-perl,
|
||||||
|
rinse (>= 1.9.1-1),
|
||||||
|
xen-hypervisor-amd64 | xen-hypervisor-i386 | xen-hypervisor-i386-pae,
|
||||||
|
xen-utils
|
||||||
|
Suggests: btrfs-tools,
|
||||||
|
cfengine2,
|
||||||
|
reiserfsprogs,
|
||||||
|
xfsprogs
|
||||||
Description: Tools to manage Xen virtual servers
|
Description: Tools to manage Xen virtual servers
|
||||||
This package contains tools to manage Debian based Xen virtual servers.
|
This package contains tools to manage Debian based Xen virtual servers.
|
||||||
.
|
.
|
||||||
|
|||||||
2
debian/copyright
vendored
2
debian/copyright
vendored
@@ -4,7 +4,7 @@ Tue, 20 Dec 2005 02:21:05 +0200.
|
|||||||
It was downloaded from http://xen-tools.org/software/xen-tools/
|
It was downloaded from http://xen-tools.org/software/xen-tools/
|
||||||
|
|
||||||
Copyright 2005-2009: Steve Kemp <steve@steve.org.uk>
|
Copyright 2005-2009: Steve Kemp <steve@steve.org.uk>
|
||||||
Copyright 2010-2012: The Xen-Tools Development Team, currently consisting of:
|
Copyright 2010-2013: The Xen-Tools Development Team, currently consisting of:
|
||||||
Axel Beckert <abe@deuxchevaux.org>,
|
Axel Beckert <abe@deuxchevaux.org>,
|
||||||
Dmitry Nedospasov <dmitry@nedos.net>, and
|
Dmitry Nedospasov <dmitry@nedos.net>, and
|
||||||
Stéphane Jourdois <sjourdois@gmail.com>
|
Stéphane Jourdois <sjourdois@gmail.com>
|
||||||
|
|||||||
2
debian/dirs
vendored
2
debian/dirs
vendored
@@ -1,4 +1,4 @@
|
|||||||
/etc/xen-tools
|
/etc/xen-tools
|
||||||
/etc/xen-tools/role.d
|
/etc/xen-tools/role.d
|
||||||
/etc/xen-tools/skel
|
/etc/xen-tools/skel
|
||||||
/usr/lib/xen-tools
|
/usr/share/xen-tools
|
||||||
12
debian/docs
vendored
12
debian/docs
vendored
@@ -1,7 +1,7 @@
|
|||||||
AUTHORS
|
AUTHORS
|
||||||
README
|
README.markdown
|
||||||
SUPPORT
|
SUPPORT.markdown
|
||||||
BUGS
|
BUGS.markdown
|
||||||
TODO
|
TODO.markdown
|
||||||
KNOWN_BUGS
|
KNOWN_BUGS.markdown
|
||||||
NEWS
|
NEWS.markdown
|
||||||
|
|||||||
1
debian/examples
vendored
Normal file
1
debian/examples
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
examples/*
|
||||||
3
debian/gbp.conf
vendored
Normal file
3
debian/gbp.conf
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
upstream-tag=release-%(version)s
|
||||||
|
debian-tag=debian-%(version)s
|
||||||
55
debian/rules
vendored
55
debian/rules
vendored
@@ -2,56 +2,7 @@
|
|||||||
# Uncomment this to turn on verbose mode.
|
# Uncomment this to turn on verbose mode.
|
||||||
#export DH_VERBOSE=1
|
#export DH_VERBOSE=1
|
||||||
|
|
||||||
|
%:
|
||||||
|
dh $@
|
||||||
|
|
||||||
configure: configure-stamp
|
override_dh_auto_build:
|
||||||
configure-stamp:
|
|
||||||
dh_testdir
|
|
||||||
touch configure-stamp
|
|
||||||
|
|
||||||
|
|
||||||
build: build-arch build-indep
|
|
||||||
build-arch: build-stamp
|
|
||||||
build-indep: build-stamp
|
|
||||||
build-stamp: configure-stamp
|
|
||||||
dh_testdir
|
|
||||||
touch build-stamp
|
|
||||||
|
|
||||||
clean:
|
|
||||||
dh_testdir
|
|
||||||
dh_testroot
|
|
||||||
make clean
|
|
||||||
rm -f build-stamp configure-stamp
|
|
||||||
dh_clean
|
|
||||||
|
|
||||||
install: build
|
|
||||||
dh_testdir
|
|
||||||
dh_testroot
|
|
||||||
dh_prep
|
|
||||||
|
|
||||||
dh_auto_test
|
|
||||||
make manpages
|
|
||||||
make install prefix=`pwd`/debian/xen-tools
|
|
||||||
|
|
||||||
dh_installdirs
|
|
||||||
|
|
||||||
# Build architecture-independent files here.
|
|
||||||
binary-indep: build install
|
|
||||||
# We have nothing to do by default.
|
|
||||||
|
|
||||||
# Build architecture-dependent files here.
|
|
||||||
binary-indep: build install
|
|
||||||
dh_testdir
|
|
||||||
dh_testroot
|
|
||||||
dh_install
|
|
||||||
dh_installexamples debian/examples/setup-kernel-initrd debian/examples/update-modules
|
|
||||||
dh_installchangelogs ChangeLog
|
|
||||||
dh_installdocs
|
|
||||||
dh_compress
|
|
||||||
dh_fixperms
|
|
||||||
dh_installdeb
|
|
||||||
dh_gencontrol
|
|
||||||
dh_md5sums
|
|
||||||
dh_builddeb
|
|
||||||
|
|
||||||
binary: binary-indep binary-arch
|
|
||||||
.PHONY: build clean binary-indep binary-arch binary install configure
|
|
||||||
|
|||||||
2
debian/source/format
vendored
2
debian/source/format
vendored
@@ -1 +1 @@
|
|||||||
1.0
|
3.0 (quilt)
|
||||||
|
|||||||
1
debian/triggers
vendored
Normal file
1
debian/triggers
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
activate update-initramfs
|
||||||
@@ -266,6 +266,7 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
|||||||
# mirror_lenny = http://archive.debian.org/debian
|
# mirror_lenny = http://archive.debian.org/debian
|
||||||
# mirror_squeeze = http://cdn.debian.net/debian
|
# mirror_squeeze = http://cdn.debian.net/debian
|
||||||
# mirror_wheezy = http://cdn.debian.net/debian
|
# mirror_wheezy = http://cdn.debian.net/debian
|
||||||
|
# mirror_jessie = http://cdn.debian.net/debian
|
||||||
# mirror_sid = http://cdn.debian.net/debian
|
# mirror_sid = http://cdn.debian.net/debian
|
||||||
# mirror_dapper = http://old-releases.ubuntu.com/ubuntu
|
# mirror_dapper = http://old-releases.ubuntu.com/ubuntu
|
||||||
# mirror_edgy = http://old-releases.ubuntu.com/ubuntu
|
# mirror_edgy = http://old-releases.ubuntu.com/ubuntu
|
||||||
@@ -277,10 +278,11 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
|||||||
# mirror_karmic = http://old-releases.ubuntu.com/ubuntu
|
# mirror_karmic = http://old-releases.ubuntu.com/ubuntu
|
||||||
# mirror_lucid = http://archive.ubuntu.com/ubuntu
|
# mirror_lucid = http://archive.ubuntu.com/ubuntu
|
||||||
# mirror_maverick = http://old-releases.ubuntu.com/ubuntu
|
# mirror_maverick = http://old-releases.ubuntu.com/ubuntu
|
||||||
# mirror_natty = http://archive.ubuntu.com/ubuntu
|
# mirror_natty = http://old-releases.ubuntu.com/ubuntu
|
||||||
# mirror_oneiric = http://archive.ubuntu.com/ubuntu
|
# mirror_oneiric = http://archive.ubuntu.com/ubuntu
|
||||||
# mirror_precise = http://archive.ubuntu.com/ubuntu
|
# mirror_precise = http://archive.ubuntu.com/ubuntu
|
||||||
# mirror_quantal = http://archive.ubuntu.com/ubuntu
|
# mirror_quantal = http://archive.ubuntu.com/ubuntu
|
||||||
|
# mirror_raring = http://archive.ubuntu.com/ubuntu
|
||||||
|
|
||||||
# If this is defined it will be used by debootstrap, and configured as the
|
# If this is defined it will be used by debootstrap, and configured as the
|
||||||
# proxy for the guest
|
# proxy for the guest
|
||||||
@@ -290,6 +292,7 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
|||||||
#
|
#
|
||||||
# Filesystem options for the different filesystems we support.
|
# Filesystem options for the different filesystems we support.
|
||||||
#
|
#
|
||||||
|
ext4_options = noatime,nodiratime,errors=remount-ro
|
||||||
ext3_options = noatime,nodiratime,errors=remount-ro
|
ext3_options = noatime,nodiratime,errors=remount-ro
|
||||||
ext2_options = noatime,nodiratime,errors=remount-ro
|
ext2_options = noatime,nodiratime,errors=remount-ro
|
||||||
xfs_options = defaults
|
xfs_options = defaults
|
||||||
|
|||||||
@@ -8,7 +8,8 @@
|
|||||||
#
|
#
|
||||||
{ if ( ( $kernel ) && ( !defined($pygrub)) )
|
{ if ( ( $kernel ) && ( !defined($pygrub)) )
|
||||||
{
|
{
|
||||||
$OUT.= "kernel = '$kernel'";
|
$OUT .= "kernel = '$kernel'\n";
|
||||||
|
$OUT .= "extra = 'elevator=noop'";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
{ if ( ( $initrd ) && ( !defined($pygrub)) )
|
{ if ( ( $initrd ) && ( !defined($pygrub)) )
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ hooks/
|
|||||||
* The installation will have a running installation of OpenSSH
|
* The installation will have a running installation of OpenSSH
|
||||||
|
|
||||||
The subdirectories in this hooks/ directory will be installed
|
The subdirectories in this hooks/ directory will be installed
|
||||||
to the directory /usr/lib/xen-tools/
|
to the directory /usr/share/xen-tools/
|
||||||
|
|
||||||
Steve
|
Steve
|
||||||
--
|
--
|
||||||
|
|||||||
@@ -8,8 +8,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -66,7 +66,7 @@ cat > ${prefix}/boot/grub/menu.lst << EOF
|
|||||||
default=0
|
default=0
|
||||||
timeout=5
|
timeout=5
|
||||||
title CentOS ($KERNELVERSION)
|
title CentOS ($KERNELVERSION)
|
||||||
kernel /boot/vmlinuz-$KERNELVERSION xen_pv_hvm=enable
|
kernel /boot/vmlinuz-$KERNELVERSION xen_pv_hvm=enable elevator=noop
|
||||||
initrd /boot/initrd-$KERNELVERSION.img
|
initrd /boot/initrd-$KERNELVERSION.img
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
../common/15-disable-hwclock
|
../common/15-setup-arch
|
||||||
@@ -8,8 +8,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -66,7 +66,7 @@ cat > ${prefix}/boot/grub/menu.lst << EOF
|
|||||||
default=0
|
default=0
|
||||||
timeout=5
|
timeout=5
|
||||||
title CentOS ($KERNELVERSION)
|
title CentOS ($KERNELVERSION)
|
||||||
kernel /boot/vmlinuz-$KERNELVERSION
|
kernel /boot/vmlinuz-$KERNELVERSION elevator=noop
|
||||||
initrd /boot/initramfs-$KERNELVERSION.img
|
initrd /boot/initramfs-$KERNELVERSION.img
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|||||||
163
hooks/common.sh
163
hooks/common.sh
@@ -60,7 +60,7 @@ assert ()
|
|||||||
# We take special care so that daemons shouldn't start after installation
|
# We take special care so that daemons shouldn't start after installation
|
||||||
# which they might otherwise do.
|
# which they might otherwise do.
|
||||||
#
|
#
|
||||||
# NOTE: Function not renamed with trailing "s" for compatability reasons.
|
# NOTE: Function not renamed with trailing "s" for compatibility reasons.
|
||||||
#
|
#
|
||||||
installDebianPackage ()
|
installDebianPackage ()
|
||||||
{
|
{
|
||||||
@@ -98,7 +98,7 @@ installDebianPackage ()
|
|||||||
#
|
#
|
||||||
# Install the packages
|
# Install the packages
|
||||||
#
|
#
|
||||||
DEBIAN_FRONTEND=noninteractive chroot ${prefix} /usr/bin/apt-get --yes --force-yes install "$@"
|
DEBIAN_FRONTEND=noninteractive chroot ${prefix} /usr/bin/apt-get --yes --force-yes --no-install-recommends install "$@"
|
||||||
|
|
||||||
#
|
#
|
||||||
# Remove the policy-rc.d script.
|
# Remove the policy-rc.d script.
|
||||||
@@ -113,6 +113,143 @@ installDebianPackage ()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generate a Debian-/Ubuntu-compliant menu.lst for legacy GRUB
|
||||||
|
#
|
||||||
|
generateDebianGrubMenuLst ()
|
||||||
|
{
|
||||||
|
prefix="$1"
|
||||||
|
DOMU_ISSUE="$2"
|
||||||
|
DOMU_KERNEL="$3"
|
||||||
|
DOMU_RAMDISK="$4"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Log our options
|
||||||
|
#
|
||||||
|
logMessage "Generating a legacy GRUB menu.lst into prefix ${prefix}"
|
||||||
|
|
||||||
|
#
|
||||||
|
# We require at least 3 parameters
|
||||||
|
#
|
||||||
|
assert "$LINENO" "${prefix}"
|
||||||
|
assert "$LINENO" "${DOMU_ISSUE}"
|
||||||
|
assert "$LINENO" "${DOMU_KERNEL}"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Prefix must be a directory, kernel a file
|
||||||
|
#
|
||||||
|
assert "$LINENO" -d ${prefix}
|
||||||
|
assert "$LINENO" -f "${prefix}/boot/${DOMU_KERNEL}"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generate a menu.lst for pygrub
|
||||||
|
#
|
||||||
|
|
||||||
|
mkdir -p ${prefix}/boot/grub
|
||||||
|
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
||||||
|
default 0
|
||||||
|
timeout 2
|
||||||
|
|
||||||
|
### BEGIN AUTOMAGIC KERNELS LIST
|
||||||
|
## lines between the AUTOMAGIC KERNELS LIST markers will be modified
|
||||||
|
## by the debian update-grub script except for the default options below
|
||||||
|
|
||||||
|
## DO NOT UNCOMMENT THEM, Just edit them to your needs
|
||||||
|
|
||||||
|
## ## Start Default Options ##
|
||||||
|
## default kernel options
|
||||||
|
## default kernel options for automagic boot options
|
||||||
|
## If you want special options for specific kernels use kopt_x_y_z
|
||||||
|
## where x.y.z is kernel version. Minor versions can be omitted.
|
||||||
|
## e.g. kopt=root=/dev/hda1 ro
|
||||||
|
## kopt_2_6_8=root=/dev/hdc1 ro
|
||||||
|
## kopt_2_6_8_2_686=root=/dev/hdc2 ro
|
||||||
|
# kopt=root=/dev/xvda2 ro elevator=noop
|
||||||
|
|
||||||
|
## default grub root device
|
||||||
|
## e.g. groot=(hd0,0)
|
||||||
|
# groot=(hd0,0)
|
||||||
|
|
||||||
|
## should update-grub create alternative automagic boot options
|
||||||
|
## e.g. alternative=true
|
||||||
|
## alternative=false
|
||||||
|
# alternative=true
|
||||||
|
|
||||||
|
## should update-grub lock alternative automagic boot options
|
||||||
|
## e.g. lockalternative=true
|
||||||
|
## lockalternative=false
|
||||||
|
# lockalternative=false
|
||||||
|
|
||||||
|
## additional options to use with the default boot option, but not with the
|
||||||
|
## alternatives
|
||||||
|
## e.g. defoptions=vga=791 resume=/dev/hda5
|
||||||
|
# defoptions=
|
||||||
|
|
||||||
|
## should update-grub lock old automagic boot options
|
||||||
|
## e.g. lockold=false
|
||||||
|
## lockold=true
|
||||||
|
# lockold=false
|
||||||
|
|
||||||
|
## altoption boot targets option
|
||||||
|
## multiple altoptions lines are allowed
|
||||||
|
## e.g. altoptions=(extra menu suffix) extra boot options
|
||||||
|
## altoptions=(single-user) single
|
||||||
|
# altoptions=(single-user mode) single
|
||||||
|
|
||||||
|
## controls how many kernels should be put into the menu.lst
|
||||||
|
## only counts the first occurence of a kernel, not the
|
||||||
|
## alternative kernel options
|
||||||
|
## e.g. howmany=all
|
||||||
|
## howmany=7
|
||||||
|
# howmany=all
|
||||||
|
|
||||||
|
## should update-grub create memtest86 boot option
|
||||||
|
## e.g. memtest86=true
|
||||||
|
## memtest86=false
|
||||||
|
# memtest86=false
|
||||||
|
|
||||||
|
## should update-grub adjust the value of the default booted system
|
||||||
|
## can be true or false
|
||||||
|
# updatedefaultentry=false
|
||||||
|
|
||||||
|
## should update-grub add savedefault to the default options
|
||||||
|
## can be true or false
|
||||||
|
# savedefault=false
|
||||||
|
|
||||||
|
## ## End Default Options ##
|
||||||
|
|
||||||
|
### END DEBIAN AUTOMAGIC KERNELS LIST
|
||||||
|
|
||||||
|
# Entries statically generated bu xen-tools upon installation. Maybe
|
||||||
|
# removed manually if the entries above (generated by update-grub)
|
||||||
|
# seem to work fine.
|
||||||
|
|
||||||
|
title $DOMU_ISSUE
|
||||||
|
root (hd0,0)
|
||||||
|
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro elevator=noop
|
||||||
|
initrd /boot/$DOMU_RAMDISK
|
||||||
|
|
||||||
|
title $DOMU_ISSUE (Single-User)
|
||||||
|
root (hd0,0)
|
||||||
|
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro single elevator=noop
|
||||||
|
initrd /boot/$DOMU_RAMDISK
|
||||||
|
|
||||||
|
title $DOMU_ISSUE (Default Kernel)
|
||||||
|
root (hd0,0)
|
||||||
|
kernel /vmlinuz root=/dev/xvda2 ro elevator=noop
|
||||||
|
initrd /initrd.img
|
||||||
|
|
||||||
|
title $DOMU_ISSUE (Default Kernel, Single-User)
|
||||||
|
root (hd0,0)
|
||||||
|
kernel /vmlinuz root=/dev/xvda2 ro single elevator=noop
|
||||||
|
initrd /initrd.img
|
||||||
|
|
||||||
|
E_O_MENU
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Disable the start-stop-daemon
|
# Disable the start-stop-daemon
|
||||||
@@ -191,9 +328,9 @@ removeDebianPackage ()
|
|||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Install a CentOS4 package via yum
|
# Install a RPM package via yum
|
||||||
#
|
#
|
||||||
installCentOS4Package ()
|
installRPMPackage ()
|
||||||
{
|
{
|
||||||
prefix=$1
|
prefix=$1
|
||||||
package=$2
|
package=$2
|
||||||
@@ -201,7 +338,7 @@ installCentOS4Package ()
|
|||||||
#
|
#
|
||||||
# Log our options
|
# Log our options
|
||||||
#
|
#
|
||||||
logMessage "Installing CentOS4 ${package} to prefix ${prefix}"
|
logMessage "Installing RPM ${package} to prefix ${prefix}"
|
||||||
|
|
||||||
#
|
#
|
||||||
# We require a package + prefix
|
# We require a package + prefix
|
||||||
@@ -220,6 +357,15 @@ installCentOS4Package ()
|
|||||||
chroot ${prefix} /usr/bin/yum -y install ${package}
|
chroot ${prefix} /usr/bin/yum -y install ${package}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Backwards Compatibility Function
|
||||||
|
installCentOS4Package () ( installRPMPackage "$@" )
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Functions to test if we're on a redhatesk or debianesk system
|
||||||
|
#
|
||||||
|
isDeb() ( [ -x $1/usr/bin/apt-get -a -x $1/usr/bin/dpkg ] )
|
||||||
|
isYum() ( [ -x $1/usr/bin/yum ] )
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -230,11 +376,11 @@ installPackage ()
|
|||||||
prefix=$1
|
prefix=$1
|
||||||
package=$2
|
package=$2
|
||||||
|
|
||||||
if [ -x ${prefix}/usr/bin/apt-get ] ; then
|
if isDeb ; then
|
||||||
installDebianPackage "$@"
|
installDebianPackage "$@"
|
||||||
|
|
||||||
elif [ -x ${prefix}/usr/bin/yum ] ; then
|
elif isYum ; then
|
||||||
installCentOS4Package "$@"
|
installRPMPackage "$@"
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage "Unable to install package ${package}; no package manager found"
|
logMessage "Unable to install package ${package}; no package manager found"
|
||||||
@@ -261,4 +407,3 @@ installGentooPackage ()
|
|||||||
logMessage "NOTE: Not doing anything - this is a stub - FIXME"
|
logMessage "NOTE: Not doing anything - this is a stub - FIXME"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -6,8 +6,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -70,18 +70,14 @@ chroot ${prefix} /usr/bin/apt-get update
|
|||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Now fixup TLS on non-64bit systems after dapper.
|
# Now fixup TLS on non-64bit systems after dapper. For dapper this is
|
||||||
|
# already fixed in 10-disable-tls.
|
||||||
#
|
#
|
||||||
if [ "$dist" != 'dapper' ]; then
|
if [ "$arch" = 'i386' -a "$dist" != 'dapper' ]; then
|
||||||
if [ "`uname -m`" = "x86_64" ]; then
|
|
||||||
|
|
||||||
logMessage "Ignoring TLS since we're a 64 bit host."
|
logMessage "Installing libc6-xen"
|
||||||
|
installDebianPackage ${prefix} libc6-xen
|
||||||
|
|
||||||
else
|
|
||||||
|
|
||||||
logMessage "Installing libc6-xen"
|
|
||||||
installDebianPackage ${prefix} libc6-xen
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -12,8 +12,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -11,8 +11,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -11,8 +11,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -38,9 +38,9 @@ mkdir -p ${prefix}/etc/ssh
|
|||||||
#
|
#
|
||||||
if [ ! -f ${prefix}/etc/ssh/ssh_host_rsa_key ]; then
|
if [ ! -f ${prefix}/etc/ssh/ssh_host_rsa_key ]; then
|
||||||
if ssh-keygen -t rsa -N "" -f ${prefix}/etc/ssh/ssh_host_rsa_key -C "root@${hostname}"; then
|
if ssh-keygen -t rsa -N "" -f ${prefix}/etc/ssh/ssh_host_rsa_key -C "root@${hostname}"; then
|
||||||
logMessage "successfully generetaged Host RSA"
|
logMessage "successfully generated RSA host key"
|
||||||
else
|
else
|
||||||
logMessage "failed to generate Host RSA Key"
|
logMessage "failed to generate RSA host key"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -49,9 +49,9 @@ fi
|
|||||||
#
|
#
|
||||||
if [ ! -f ${prefix}/etc/ssh/ssh_host_dsa_key ]; then
|
if [ ! -f ${prefix}/etc/ssh/ssh_host_dsa_key ]; then
|
||||||
if ssh-keygen -t dsa -N "" -f ${prefix}/etc/ssh/ssh_host_dsa_key -C "root@${hostname}"; then
|
if ssh-keygen -t dsa -N "" -f ${prefix}/etc/ssh/ssh_host_dsa_key -C "root@${hostname}"; then
|
||||||
logMessage "successfully generetaged Host DSA"
|
logMessage "successfully generated DSA host key"
|
||||||
else
|
else
|
||||||
logMessage "failed to generate Host DSA Key"
|
logMessage "failed to generate DSA host key"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -19,8 +19,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -73,11 +73,6 @@ else
|
|||||||
cp -au /lib/modules/$(uname -r) ${prefix}/lib/modules
|
cp -au /lib/modules/$(uname -r) ${prefix}/lib/modules
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#
|
|
||||||
# Install the module-init-tools package.
|
|
||||||
#
|
|
||||||
installDebianPackage ${prefix} module-init-tools
|
|
||||||
|
|
||||||
fi # if pygrub
|
fi # if pygrub
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -19,8 +19,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
44
hooks/common/81-install-modules-init-tools
Executable file
44
hooks/common/81-install-modules-init-tools
Executable file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Ensure that either modules-init-tools or kmod is setup.
|
||||||
|
#
|
||||||
|
# This is required in most setups. But even if it isn't required it
|
||||||
|
# can't really do anything bad; just waste a bit of space.
|
||||||
|
#
|
||||||
|
|
||||||
|
prefix=$1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Source our common functions
|
||||||
|
#
|
||||||
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
|
. /usr/share/xen-tools/common.sh
|
||||||
|
else
|
||||||
|
. ./hooks/common.sh
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Log our start
|
||||||
|
#
|
||||||
|
logMessage Script $0 starting
|
||||||
|
|
||||||
|
#
|
||||||
|
# Install either kmod or module-init-tools package.
|
||||||
|
#
|
||||||
|
if chroot ${prefix} /usr/bin/apt-cache show module-init-tools >/dev/null 2>/dev/null; then
|
||||||
|
if chroot ${prefix} /usr/bin/apt-cache show module-init-tools | fgrep -qi transitional; then
|
||||||
|
installDebianPackage ${prefix} kmod
|
||||||
|
else
|
||||||
|
installDebianPackage ${prefix} module-init-tools
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
installDebianPackage ${prefix} kmod
|
||||||
|
fi
|
||||||
|
|
||||||
|
#
|
||||||
|
# Log our finish
|
||||||
|
#
|
||||||
|
logMessage Script $0 finished
|
||||||
52
hooks/common/82-install-grub-legacy
Executable file
52
hooks/common/82-install-grub-legacy
Executable file
@@ -0,0 +1,52 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Ensure that either modules-init-tools or kmod is setup.
|
||||||
|
#
|
||||||
|
# This is most likely required if you're using a custom kernel
|
||||||
|
# for your Xen system. But even if it isn't required it can't
|
||||||
|
# really do anything bad; just waste a bit of space.
|
||||||
|
|
||||||
|
|
||||||
|
prefix=$1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Source our common functions
|
||||||
|
#
|
||||||
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
|
. /usr/share/xen-tools/common.sh
|
||||||
|
else
|
||||||
|
. ./hooks/common.sh
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Log our start
|
||||||
|
#
|
||||||
|
logMessage Script $0 starting
|
||||||
|
|
||||||
|
if [ ${pygrub} ]; then
|
||||||
|
|
||||||
|
#
|
||||||
|
# Install the grub 0.9x package ("grub-legacy" on Debian, "grub" on Ubuntu)
|
||||||
|
#
|
||||||
|
if chroot ${prefix} /usr/bin/apt-cache show grub-legacy 2>/dev/null | egrep -qi 'GRand Unified Bootloader.*Legacy'; then
|
||||||
|
installDebianPackage ${prefix} grub-legacy
|
||||||
|
else
|
||||||
|
installDebianPackage ${prefix} grub
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -e ${prefix}/boot/grub/default ]; then
|
||||||
|
echo default > ${prefix}/boot/grub/default
|
||||||
|
fi
|
||||||
|
chroot ${prefix} /usr/sbin/update-grub
|
||||||
|
|
||||||
|
else
|
||||||
|
logMessage "pygrub not set, skipping grub-legacy installation"
|
||||||
|
fi # if pygrub
|
||||||
|
|
||||||
|
#
|
||||||
|
# Log our finish
|
||||||
|
#
|
||||||
|
logMessage Script $0 finished
|
||||||
@@ -17,8 +17,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -100,6 +100,34 @@ for part in `seq 1 ${NUMPARTITIONS}`; do
|
|||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
|
logMessage Checking for filesystem tools to install
|
||||||
|
|
||||||
|
#
|
||||||
|
# Install any required packages for the given root filesystem
|
||||||
|
#
|
||||||
|
if [ "$has_xfs" -eq 1 ]; then
|
||||||
|
installPackage ${prefix} xfsprogs
|
||||||
|
fi
|
||||||
|
if [ "$has_reiserfs" -eq 1 ]; then
|
||||||
|
if isAPT; then
|
||||||
|
installDebianPackage reiserfsprogs
|
||||||
|
elif isYum; then
|
||||||
|
installRPMPackage reiserfs-utils
|
||||||
|
else
|
||||||
|
logMessage "Unable to install reiserfs tools; no package manager recognized"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [ "$has_btrfs" -eq 1 ]; then
|
||||||
|
if isAPT; then
|
||||||
|
installDebianPackage btrfs-tools
|
||||||
|
elif isYum; then
|
||||||
|
installRPMPackage btrfs-progs
|
||||||
|
else
|
||||||
|
logMessage "Unable to install btrfs tools; no package manager recognized"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Log our finish
|
# Log our finish
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -1,45 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# Some root filesystems will require the installation of new packages
|
|
||||||
#
|
|
||||||
# Steve
|
|
||||||
# --
|
|
||||||
# http://www.steve.org.uk/
|
|
||||||
|
|
||||||
|
|
||||||
prefix=$1
|
|
||||||
|
|
||||||
#
|
|
||||||
# Source our common functions
|
|
||||||
#
|
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
|
||||||
. /usr/lib/xen-tools/common.sh
|
|
||||||
else
|
|
||||||
. ./hooks/common.sh
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Log our start
|
|
||||||
#
|
|
||||||
logMessage Script $0 starting
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Install any required packages for the given root filesystem
|
|
||||||
#
|
|
||||||
if [ $has_xfs -eq 1 ]; then
|
|
||||||
installDebianPackage ${prefix} xfsprogs
|
|
||||||
fi
|
|
||||||
if [ $has_reiserfs -eq 1 ]; then
|
|
||||||
installDebianPackage ${prefix} reiserfsprogs
|
|
||||||
fi
|
|
||||||
if [ $has_btrfs -eq 1 ]; then
|
|
||||||
installDebianPackage ${prefix} btrfs-tools
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Log our finish
|
|
||||||
#
|
|
||||||
logMessage Script $0 finished
|
|
||||||
@@ -13,8 +13,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -12,8 +12,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
1
hooks/dapper/81-install-modules-init-tools
Symbolic link
1
hooks/dapper/81-install-modules-init-tools
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/81-install-modules-init-tools
|
||||||
@@ -1 +0,0 @@
|
|||||||
../common/91-install-fs-tools
|
|
||||||
@@ -14,8 +14,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -90,30 +90,20 @@ fi
|
|||||||
#
|
#
|
||||||
chroot ${prefix} /usr/bin/apt-get update
|
chroot ${prefix} /usr/bin/apt-get update
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# For sid or etch systems we install libc6-xen
|
# For all systems after Sarge we install libc6-xen on i386
|
||||||
#
|
#
|
||||||
# For sarge we don't have that option, so we disable TLS.
|
# For Sarge we don't have that option, so we disable TLS the hard way.
|
||||||
#
|
#
|
||||||
if [ "`uname -m`" = "x86_64" ]; then
|
if [ "${arch}" = "i386" ]; then
|
||||||
|
if [ "${dist}" = 'sarge' ]; then
|
||||||
logMessage "Ignoring TLS since we're a 64 bit host."
|
logMessage "Disabling TLS"
|
||||||
|
mv ${prefix}/lib/tls ${prefix}/lib/tls.disabled
|
||||||
else
|
mkdir ${prefix}/lib/tls
|
||||||
|
else
|
||||||
case "${dist}" in
|
logMessage "Installing xen-aware libc6"
|
||||||
*)
|
installDebianPackage ${prefix} libc6-xen
|
||||||
logMessage "Installing xen-aware libc6"
|
fi
|
||||||
|
|
||||||
installDebianPackage ${prefix} libc6-xen
|
|
||||||
;;
|
|
||||||
sarge)
|
|
||||||
logMessage "Disabling TLS"
|
|
||||||
mv ${prefix}/lib/tls ${prefix}/lib/tls.disabled
|
|
||||||
mkdir ${prefix}/lib/tls
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
|
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -103,28 +103,8 @@ fi
|
|||||||
# Generate a menu.lst for pygrub
|
# Generate a menu.lst for pygrub
|
||||||
#
|
#
|
||||||
|
|
||||||
mkdir -p ${prefix}/boot/grub
|
generateDebianGrubMenuLst "${prefix}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
|
||||||
default 0
|
|
||||||
timeout 2
|
|
||||||
|
|
||||||
title $DOMU_ISSUE
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
title $DOMU_ISSUE (Single-User)
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro single
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
E_O_MENU
|
|
||||||
|
|
||||||
#
|
|
||||||
# Install the module-init-tools package.
|
|
||||||
#
|
|
||||||
|
|
||||||
installDebianPackage ${prefix} module-init-tools
|
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage pygrub not set, skipping kernel install
|
logMessage pygrub not set, skipping kernel install
|
||||||
|
|||||||
1
hooks/debian/81-install-modules-init-tools
Symbolic link
1
hooks/debian/81-install-modules-init-tools
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/81-install-modules-init-tools
|
||||||
1
hooks/debian/82-install-grub-legacy
Symbolic link
1
hooks/debian/82-install-grub-legacy
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/82-install-grub-legacy
|
||||||
@@ -1 +0,0 @@
|
|||||||
../common/91-install-fs-tools
|
|
||||||
@@ -12,8 +12,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
|
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -27,7 +27,7 @@ fi
|
|||||||
|
|
||||||
logMessage Script $0 starting
|
logMessage Script $0 starting
|
||||||
|
|
||||||
if [ ${pygrub} ]; then
|
if [ "${pygrub}" ]; then
|
||||||
|
|
||||||
#
|
#
|
||||||
# Attempt to install a xen kernel, if that fails, then install a normal one
|
# Attempt to install a xen kernel, if that fails, then install a normal one
|
||||||
@@ -78,32 +78,12 @@ fi
|
|||||||
# Generate a menu.lst for pygrub
|
# Generate a menu.lst for pygrub
|
||||||
#
|
#
|
||||||
|
|
||||||
mkdir -p ${prefix}/boot/grub
|
generateDebianGrubMenuLst "${prefix}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
|
||||||
default 0
|
|
||||||
timeout 2
|
|
||||||
|
|
||||||
title $DOMU_ISSUE
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
title $DOMU_ISSUE (Single-User)
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro single
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
E_O_MENU
|
|
||||||
|
|
||||||
#
|
|
||||||
# Install the module-init-tools package.
|
|
||||||
#
|
|
||||||
|
|
||||||
installDebianPackage ${prefix} module-init-tools
|
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage pygrub not set, skipping kernel install
|
logMessage pygrub not set, skipping kernel install
|
||||||
fi
|
fi # if pygrub
|
||||||
|
|
||||||
#
|
#
|
||||||
# Log our finish
|
# Log our finish
|
||||||
|
|||||||
1
hooks/edgy/81-install-modules-init-tools
Symbolic link
1
hooks/edgy/81-install-modules-init-tools
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/81-install-modules-init-tools
|
||||||
1
hooks/edgy/82-install-grub-legacy
Symbolic link
1
hooks/edgy/82-install-grub-legacy
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/82-install-grub-legacy
|
||||||
@@ -1 +0,0 @@
|
|||||||
../common/91-install-fs-tools
|
|
||||||
@@ -12,8 +12,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -12,8 +12,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -16,8 +16,8 @@ prefix=$1
|
|||||||
#
|
#
|
||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ prefix=$1
|
|||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
|
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
@@ -27,13 +27,13 @@ fi
|
|||||||
|
|
||||||
logMessage Script $0 starting
|
logMessage Script $0 starting
|
||||||
|
|
||||||
if [ ${pygrub} ]; then
|
if [ "${pygrub}" ]; then
|
||||||
|
|
||||||
#
|
#
|
||||||
# Attempt to install a xen kernel, if that fails, then install a normal one
|
# Attempt to install a xen kernel, if that fails, then install a normal one
|
||||||
#
|
#
|
||||||
|
|
||||||
KERNEL_PKG="linux-image-server"
|
KERNEL_PKG="linux-image-virtual"
|
||||||
|
|
||||||
logMessage Attempting to install the $KERNEL_PKG kernel image
|
logMessage Attempting to install the $KERNEL_PKG kernel image
|
||||||
logMessage WARNING: This kernel may not have pvops
|
logMessage WARNING: This kernel may not have pvops
|
||||||
@@ -68,32 +68,11 @@ fi
|
|||||||
# Generate a menu.lst for pygrub
|
# Generate a menu.lst for pygrub
|
||||||
#
|
#
|
||||||
|
|
||||||
mkdir -p ${prefix}/boot/grub
|
generateDebianGrubMenuLst "${prefix}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
|
||||||
default 0
|
|
||||||
timeout 2
|
|
||||||
|
|
||||||
title $DOMU_ISSUE
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
title $DOMU_ISSUE (Single-User)
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro single
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
E_O_MENU
|
|
||||||
|
|
||||||
#
|
|
||||||
# Install the module-init-tools package.
|
|
||||||
#
|
|
||||||
|
|
||||||
installDebianPackage ${prefix} module-init-tools
|
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage pygrub not set, skipping kernel install
|
logMessage pygrub not set, skipping kernel install
|
||||||
fi
|
fi # if pygrub
|
||||||
|
|
||||||
#
|
#
|
||||||
# Log our finish
|
# Log our finish
|
||||||
|
|||||||
1
hooks/intrepid/81-install-modules-init-tools
Symbolic link
1
hooks/intrepid/81-install-modules-init-tools
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/81-install-modules-init-tools
|
||||||
1
hooks/intrepid/82-install-grub-legacy
Symbolic link
1
hooks/intrepid/82-install-grub-legacy
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/82-install-grub-legacy
|
||||||
@@ -1 +0,0 @@
|
|||||||
../common/91-install-fs-tools
|
|
||||||
@@ -15,25 +15,25 @@ prefix=$1
|
|||||||
# Source our common functions
|
# Source our common functions
|
||||||
#
|
#
|
||||||
|
|
||||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||||
. /usr/lib/xen-tools/common.sh
|
. /usr/share/xen-tools/common.sh
|
||||||
else
|
else
|
||||||
. ./hooks/common.sh
|
. ./hooks/common.sh
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${pygrub}" ]; then
|
|
||||||
#
|
#
|
||||||
# Log our start
|
# Log our start
|
||||||
#
|
#
|
||||||
|
|
||||||
logMessage Script $0 starting
|
logMessage Script $0 starting
|
||||||
|
|
||||||
|
if [ "${pygrub}" ]; then
|
||||||
|
|
||||||
#
|
#
|
||||||
# The type of kernel that we will be installing
|
# The type of kernel that we will be installing
|
||||||
#
|
#
|
||||||
# linux_kernel_type="desktop"
|
# linux_kernel_type="desktop"
|
||||||
#
|
#
|
||||||
linux_kernel_type="server"
|
linux_kernel_type="virtual"
|
||||||
|
|
||||||
linux_kernel_package="linux-image-${linux_kernel_type}"
|
linux_kernel_package="linux-image-${linux_kernel_type}"
|
||||||
|
|
||||||
@@ -54,33 +54,17 @@ DOMU_KERNEL=$(basename $(ls -1 ${prefix}/boot/vmlinuz* | tail -n 1))
|
|||||||
DOMU_RAMDISK=$(basename $(ls -1 ${prefix}/boot/initrd*|tail -n 1))
|
DOMU_RAMDISK=$(basename $(ls -1 ${prefix}/boot/initrd*|tail -n 1))
|
||||||
DOMU_ISSUE=$(head -n 1 ${prefix}/etc/issue | awk -F '\' '{ print $1 }' | sed 's/[ \t]*$//')
|
DOMU_ISSUE=$(head -n 1 ${prefix}/etc/issue | awk -F '\' '{ print $1 }' | sed 's/[ \t]*$//')
|
||||||
|
|
||||||
mkdir -p ${prefix}/boot/grub
|
#
|
||||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
# Generate a menu.lst for pygrub
|
||||||
default 0
|
#
|
||||||
timeout 2
|
|
||||||
|
|
||||||
title $DOMU_ISSUE
|
generateDebianGrubMenuLst "${prefix}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
title $DOMU_ISSUE (Single-User)
|
|
||||||
root (hd0,0)
|
|
||||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro single
|
|
||||||
initrd /boot/$DOMU_RAMDISK
|
|
||||||
|
|
||||||
E_O_MENU
|
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage "Package '${linux_kernel_package}' is not available"
|
logMessage "Package '${linux_kernel_package}' is not available"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#
|
|
||||||
# Install the module-init-tools package.
|
|
||||||
#
|
|
||||||
|
|
||||||
installDebianPackage ${prefix} module-init-tools
|
|
||||||
|
|
||||||
else
|
else
|
||||||
logMessage pygrub not set, skipping kernel install
|
logMessage pygrub not set, skipping kernel install
|
||||||
fi # if pygrub
|
fi # if pygrub
|
||||||
|
|||||||
1
hooks/karmic/81-install-modules-init-tools
Symbolic link
1
hooks/karmic/81-install-modules-init-tools
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/81-install-modules-init-tools
|
||||||
1
hooks/karmic/82-install-grub-legacy
Symbolic link
1
hooks/karmic/82-install-grub-legacy
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../common/82-install-grub-legacy
|
||||||
@@ -1 +0,0 @@
|
|||||||
../common/91-install-fs-tools
|
|
||||||
441
lib/Xen/Tools/Common.pm
Normal file
441
lib/Xen/Tools/Common.pm
Normal file
@@ -0,0 +1,441 @@
|
|||||||
|
# -*- perl -*
|
||||||
|
|
||||||
|
package Xen::Tools::Common;
|
||||||
|
|
||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
Xen::Tools::Common - Common funtions used in xen-tools' Perl scripts
|
||||||
|
|
||||||
|
=head1 SYNOPSIS
|
||||||
|
|
||||||
|
use Xen::Tools::Common;
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
use warnings;
|
||||||
|
use strict;
|
||||||
|
|
||||||
|
use Exporter 'import';
|
||||||
|
use vars qw(@EXPORT_OK @EXPORT);
|
||||||
|
|
||||||
|
use English;
|
||||||
|
|
||||||
|
@EXPORT = qw(readConfigurationFile xenRunning runCommand setupAdminUsers
|
||||||
|
findXenToolstack findBinary
|
||||||
|
logprint_with_config logonly_with_config fail_with_config);
|
||||||
|
|
||||||
|
=head1 FUNCTIONS
|
||||||
|
|
||||||
|
=head2 readConfigurationFile
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Read the specified configuration file, and update our global configuration
|
||||||
|
hash with the values found in it.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub readConfigurationFile ($$)
|
||||||
|
{
|
||||||
|
my ($file, $CONFIG) = (@_);
|
||||||
|
|
||||||
|
# Don't read the file if it doesn't exist.
|
||||||
|
return if ( !-e $file );
|
||||||
|
|
||||||
|
|
||||||
|
my $line = "";
|
||||||
|
|
||||||
|
open( FILE, "<", $file ) or
|
||||||
|
fail_with_config("Cannot read file '$file' - $!", $CONFIG);
|
||||||
|
|
||||||
|
while ( defined( $line = <FILE> ) )
|
||||||
|
{
|
||||||
|
chomp $line;
|
||||||
|
if ( $line =~ s/\\$// )
|
||||||
|
{
|
||||||
|
$line .= <FILE>;
|
||||||
|
redo unless eof(FILE);
|
||||||
|
}
|
||||||
|
|
||||||
|
# Skip lines beginning with comments
|
||||||
|
next if ( $line =~ /^([ \t]*)\#/ );
|
||||||
|
|
||||||
|
# Skip blank lines
|
||||||
|
next if ( length($line) < 1 );
|
||||||
|
|
||||||
|
# Strip trailing comments.
|
||||||
|
if ( $line =~ /(.*)\#(.*)/ )
|
||||||
|
{
|
||||||
|
$line = $1;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Find variable settings
|
||||||
|
if ( $line =~ /([^=]+)=([^\n]+)/ )
|
||||||
|
{
|
||||||
|
my $key = $1;
|
||||||
|
my $val = $2;
|
||||||
|
|
||||||
|
# Strip leading and trailing whitespace.
|
||||||
|
$key =~ s/^\s+//;
|
||||||
|
$key =~ s/\s+$//;
|
||||||
|
$val =~ s/^\s+//;
|
||||||
|
$val =~ s/\s+$//;
|
||||||
|
|
||||||
|
# command expansion?
|
||||||
|
if ( $val =~ /(.*)`([^`]+)`(.*)/ )
|
||||||
|
{
|
||||||
|
|
||||||
|
# store
|
||||||
|
my $pre = $1;
|
||||||
|
my $cmd = $2;
|
||||||
|
my $post = $3;
|
||||||
|
|
||||||
|
# get output
|
||||||
|
my $output = `$cmd`;
|
||||||
|
chomp($output);
|
||||||
|
|
||||||
|
# build up replacement.
|
||||||
|
$val = $pre . $output . $post;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Store value.
|
||||||
|
$CONFIG->{ $key } = $val;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
close(FILE);
|
||||||
|
}
|
||||||
|
|
||||||
|
=head2 xenRunning
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Test to see if the given instance is running.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub xenRunning ($$)
|
||||||
|
{
|
||||||
|
my ($hostname, $CONFIG) = (@_);
|
||||||
|
|
||||||
|
my $running = 0;
|
||||||
|
|
||||||
|
die "Couldn't determine Xen toolstack" unless $CONFIG->{'xm'};
|
||||||
|
|
||||||
|
open( CMD, $CONFIG->{'xm'}." list $hostname 2>/dev/null |" ) or
|
||||||
|
fail_with_config("Failed to run '".$CONFIG->{'xm'}." list $hostname'", $CONFIG);
|
||||||
|
while (<CMD>)
|
||||||
|
{
|
||||||
|
my $line = $_;
|
||||||
|
$running = 1 if ( $line =~ /\Q$hostname\E/ );
|
||||||
|
}
|
||||||
|
close(CMD);
|
||||||
|
|
||||||
|
return ($running);
|
||||||
|
}
|
||||||
|
|
||||||
|
=head2 findBinary
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Find the location of the specified binary on the curent user's PATH.
|
||||||
|
|
||||||
|
Return undef if the named binary isn't found.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub findBinary
|
||||||
|
{
|
||||||
|
my ($bin) = (@_);
|
||||||
|
|
||||||
|
# strip any path which might be present.
|
||||||
|
$bin = $2 if ( $bin =~ /(.*)[\/\\](.*)/ );
|
||||||
|
|
||||||
|
foreach my $entry ( split( /:/, $ENV{ 'PATH' } ) )
|
||||||
|
{
|
||||||
|
|
||||||
|
# guess of location.
|
||||||
|
my $guess = $entry . "/" . $bin;
|
||||||
|
|
||||||
|
# return it if it exists and is executable
|
||||||
|
return $guess if ( -e $guess && -x $guess );
|
||||||
|
}
|
||||||
|
|
||||||
|
return undef;
|
||||||
|
}
|
||||||
|
|
||||||
|
=head2 findXenToolstack
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Find the right Xen toolstack. On Debian and derivatives there's a
|
||||||
|
script which tells you about the current toolstack.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub findXenToolstack
|
||||||
|
{
|
||||||
|
my $helper = '/usr/lib/xen-common/bin/xen-toolstack';
|
||||||
|
|
||||||
|
if (-x $helper) {
|
||||||
|
my $toolstack = `$helper`;
|
||||||
|
chomp($toolstack);
|
||||||
|
return $toolstack if $toolstack;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $xm = findBinary('xm');
|
||||||
|
if ($xm and system("$xm list >/dev/null 2>/dev/null") == 0) {
|
||||||
|
return $xm;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $xl = findBinary('xl');
|
||||||
|
if ($xl and system("$xl list >/dev/null 2>/dev/null") == 0) {
|
||||||
|
return $xl;
|
||||||
|
}
|
||||||
|
|
||||||
|
return undef;
|
||||||
|
}
|
||||||
|
|
||||||
|
=head2 runCommand
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
A utility method to run a system command. We will capture the return
|
||||||
|
value and exit if the command files.
|
||||||
|
|
||||||
|
When running verbosely we will also display any command output once
|
||||||
|
it has finished.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub runCommand ($$;$)
|
||||||
|
{
|
||||||
|
my ($cmd, $CONFIG, $fail_ok) = (@_);
|
||||||
|
|
||||||
|
#
|
||||||
|
# Set a local if we don't have one.
|
||||||
|
#
|
||||||
|
$ENV{ 'LC_ALL' } = "C" unless ( $ENV{ 'LC_ALL' } );
|
||||||
|
|
||||||
|
#
|
||||||
|
# Header.
|
||||||
|
#
|
||||||
|
if ($CONFIG->{ 'verbose' }) {
|
||||||
|
logprint_with_config("Executing : $cmd\n", $CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copy stderr to stdout, so we can see it, and make sure we log it.
|
||||||
|
#
|
||||||
|
$cmd .= " 2>&1";
|
||||||
|
|
||||||
|
#
|
||||||
|
# Run it.
|
||||||
|
#
|
||||||
|
my $rcopen = open(CMD, '-|', $cmd);
|
||||||
|
if (!defined($rcopen)) {
|
||||||
|
logprint_with_config("Starting command '$cmd' failed: $!\n", $CONFIG);
|
||||||
|
unless ($fail_ok) {
|
||||||
|
logprint_with_config("Aborting\n", $CONFIG);
|
||||||
|
print "See /var/log/xen-tools/".$CONFIG->{'hostname'}.".log for details\n";
|
||||||
|
$CONFIG->{'FAIL'} = 1;
|
||||||
|
exit 127;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while (my $line = <CMD>) {
|
||||||
|
if ($CONFIG->{ 'verbose' }) {
|
||||||
|
logprint_with_config($line, $CONFIG);
|
||||||
|
} else {
|
||||||
|
logonly_with_config($line, $CONFIG);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
my $rcclose = close(CMD);
|
||||||
|
|
||||||
|
if ($CONFIG->{ 'verbose' }) {
|
||||||
|
logprint_with_config("Finished : $cmd\n", $CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$rcclose)
|
||||||
|
{
|
||||||
|
logprint_with_config("Running command '$cmd' failed with exit code $?.\n", $CONFIG);
|
||||||
|
logprint_with_config("Aborting\n", $CONFIG);
|
||||||
|
print "See /var/log/xen-tools/".$CONFIG->{'hostname'}.".log for details\n";
|
||||||
|
unless ($fail_ok) {
|
||||||
|
$CONFIG->{'FAIL'} = 1;
|
||||||
|
exit 127;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
=head2 setupAdminUsers (xen-shell helper)
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
This routine is designed to ensure that any users specified with
|
||||||
|
the --admins flag are setup as administrators of the new instance.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub setupAdminUsers ($)
|
||||||
|
{
|
||||||
|
my $CONFIG = (@_);
|
||||||
|
|
||||||
|
#
|
||||||
|
# If we're not root we can't modify users.
|
||||||
|
#
|
||||||
|
return if ( $EFFECTIVE_USER_ID != 0 );
|
||||||
|
|
||||||
|
#
|
||||||
|
# If we don't have a sudoers file then we'll also ignore this.
|
||||||
|
#
|
||||||
|
return if ( !-e "/etc/sudoers" );
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find the path to the xen-login-shell
|
||||||
|
#
|
||||||
|
my $shell = undef;
|
||||||
|
$shell = "/usr/bin/xen-login-shell" if ( -x "/usr/bin/xen-login-shell" );
|
||||||
|
$shell = "/usr/local/bin/xen-login-shell"
|
||||||
|
if ( -x "/usr/bin/local/xen-login-shell" );
|
||||||
|
|
||||||
|
return if ( !defined($shell) );
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# For each user make sure they exist, and setup the
|
||||||
|
# login shell for them.
|
||||||
|
#
|
||||||
|
foreach my $user ( split( /,/, $ENV{ 'admins' } ) )
|
||||||
|
{
|
||||||
|
|
||||||
|
# Strip leading and trailing whitespace.
|
||||||
|
$user =~ s/^\s+//;
|
||||||
|
$user =~ s/\s+$//;
|
||||||
|
|
||||||
|
# Ignore root
|
||||||
|
next if ( $user =~ /^root$/i );
|
||||||
|
|
||||||
|
# Does the user exist?
|
||||||
|
if ( getpwnam($user) )
|
||||||
|
{
|
||||||
|
|
||||||
|
# Change shell.
|
||||||
|
if ($CONFIG->{ 'verbose' }) {
|
||||||
|
logprint_with_config("Changing shell for $user: $shell\n", $CONFIG);
|
||||||
|
}
|
||||||
|
system( "chsh", "-s", $shell, $user );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
# Add a new user.
|
||||||
|
if ($CONFIG->{ 'verbose' }) {
|
||||||
|
logprint_with_config("Adding new user: $user\n", $CONFIG);
|
||||||
|
}
|
||||||
|
system( "useradd", "-s", $shell, $user );
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Add the entry to /etc/sudoers.
|
||||||
|
#
|
||||||
|
open( SUDOERS, ">>", "/etc/sudoers" ) or
|
||||||
|
warn "Failed to add user to sudoers file : $user - $!";
|
||||||
|
print SUDOERS
|
||||||
|
"$user ALL = NOPASSWD: /usr/sbin/xm, /usr/sbin/xl, /usr/bin/xen-create-image\n";
|
||||||
|
close(SUDOERS);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
=head2 fail_with_config
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Properly set $CONFIG{FAIL} on die
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub fail_with_config ($$)
|
||||||
|
{
|
||||||
|
my ($text, $CONFIG) = (@_);
|
||||||
|
|
||||||
|
logprint_with_config($text, $CONFIG);
|
||||||
|
$CONFIG->{'FAIL'} = 1;
|
||||||
|
exit 127;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
=head2 logonly_with_config
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Print the given string to the logfile.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub logonly_with_config ($$)
|
||||||
|
{
|
||||||
|
my ($text, $CONFIG) = (@_);
|
||||||
|
|
||||||
|
if ( $CONFIG->{ 'hostname' } )
|
||||||
|
{
|
||||||
|
open( LOGFILE, '>>', '/var/log/xen-tools/'.$CONFIG->{'hostname'}.'.log' ) or
|
||||||
|
return;
|
||||||
|
print LOGFILE $text;
|
||||||
|
close(LOGFILE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
=head2 logprint_with_config
|
||||||
|
|
||||||
|
=begin doc
|
||||||
|
|
||||||
|
Print the given string both to our screen, and to the logfile.
|
||||||
|
|
||||||
|
=end doc
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub logprint_with_config ($$)
|
||||||
|
{
|
||||||
|
my ($text, $CONFIG) = (@_);
|
||||||
|
|
||||||
|
print $text;
|
||||||
|
logonly_with_config($text, $CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
=head1 AUTHORS
|
||||||
|
|
||||||
|
Steve Kemp, http://www.steve.org.uk/
|
||||||
|
Axel Beckert, http://noone.org/abe/
|
||||||
|
Dmitry Nedospasov, http://nedos.net/
|
||||||
|
Stéphane Jourdois
|
||||||
|
|
||||||
|
Merged from several scripts by Axel Beckert.
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
return 1;
|
||||||
@@ -9,7 +9,6 @@ misc/
|
|||||||
|
|
||||||
xen-tools - Bash completion code for our commands.
|
xen-tools - Bash completion code for our commands.
|
||||||
xen-tools.spec - File to build an RPM of the xen-tools pacakge.
|
xen-tools.spec - File to build an RPM of the xen-tools pacakge.
|
||||||
xm - Bash completion code for the Xen 'xm' command.
|
|
||||||
|
|
||||||
Steve
|
Steve
|
||||||
--
|
--
|
||||||
|
|||||||
@@ -65,8 +65,8 @@ _xen_create_image()
|
|||||||
# Available distributions, by which we mean distributions which
|
# Available distributions, by which we mean distributions which
|
||||||
# we have hook scripts available.
|
# we have hook scripts available.
|
||||||
#
|
#
|
||||||
for i in `/bin/ls -1 /usr/lib/xen-tools/ ` ; do
|
for i in `/bin/ls -1 /usr/share/xen-tools/ ` ; do
|
||||||
if [ -d /usr/lib/xen-tools/${i} ]; then
|
if [ -d /usr/share/xen-tools/${i} ]; then
|
||||||
dists="${dists} ${i/.d/}"
|
dists="${dists} ${i/.d/}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user