Compare commits
163 Commits
release-4.
...
prefix-vs-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
cc2a6d4e41 | ||
|
|
5ac0f15c32 | ||
|
|
dcb9284636 | ||
|
|
07622d8ed0 | ||
|
|
081c0370d4 | ||
|
|
ea209f085b | ||
|
|
a70b79f63f | ||
|
|
c482220b99 | ||
|
|
dcd0bf09f1 | ||
|
|
92a825b87b | ||
|
|
6871954f6e | ||
|
|
e9d8bd0896 | ||
|
|
9369fd2a03 | ||
|
|
04dd81ec07 | ||
|
|
d39255dc5e | ||
|
|
5a48067d9e | ||
|
|
6fc51d20be | ||
|
|
16dbe870f2 | ||
|
|
cb3227d61b | ||
|
|
a89aa86511 | ||
|
|
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 | ||
|
|
f58a9faa6a | ||
|
|
b1476676fe | ||
|
|
a23f31077a | ||
|
|
34ccb63f64 | ||
|
|
ed91f1fc43 | ||
|
|
65d76b6aa4 | ||
|
|
0f71f545df | ||
|
|
2de01d8cbc | ||
|
|
1d45cd33ab | ||
|
|
eabb327786 | ||
|
|
8835b9134b | ||
|
|
fec2114caf | ||
|
|
24cd27b737 |
3
.gitignore
vendored
3
.gitignore
vendored
@@ -28,3 +28,6 @@
|
||||
|
||||
# backups created by "make update-version"
|
||||
*.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) 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>,
|
||||
Dmitry Nedospasov <dmitry@nedos.net>, and
|
||||
Stéphane Jourdois <sjourdois@gmail.com>
|
||||
|
||||
126
Makefile
126
Makefile
@@ -14,7 +14,7 @@
|
||||
#
|
||||
TMP ?= /tmp
|
||||
DIST_PREFIX = ${TMP}
|
||||
VERSION = 4.3.1
|
||||
VERSION = 4.4~dev
|
||||
DEBVERSION = $(shell echo $(VERSION)|sed 's/\(rc\|pre\|beta\|alpha\)/~\1/')
|
||||
BASE = xen-tools
|
||||
VCS = git
|
||||
@@ -22,7 +22,8 @@ VCS = git
|
||||
#
|
||||
# Installation prefix, useful for the Debian package.
|
||||
#
|
||||
prefix=
|
||||
DESTDIR=
|
||||
prefix=${DESTDIR}
|
||||
|
||||
|
||||
nop:
|
||||
@@ -94,7 +95,7 @@ fixup-perms:
|
||||
chmod 644 etc/xen-tools.conf
|
||||
chmod 644 etc/xm.tmpl
|
||||
chmod 644 etc/xm-nfs.tmpl
|
||||
chmod 644 misc/xen-tools misc/README
|
||||
chmod 644 misc/*
|
||||
|
||||
#
|
||||
# Install files to /etc/
|
||||
@@ -109,8 +110,10 @@ install-etc:
|
||||
cp etc/xm.tmpl ${prefix}/etc/xen-tools/
|
||||
cp etc/xm-nfs.tmpl ${prefix}/etc/xen-tools/
|
||||
cp partitions/*-* ${prefix}/etc/xen-tools/partitions.d/
|
||||
-mkdir -p ${prefix}/etc/bash_completion.d
|
||||
cp misc/xen-tools ${prefix}/etc/bash_completion.d/
|
||||
-mkdir -p ${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
|
||||
|
||||
|
||||
#
|
||||
@@ -144,60 +147,62 @@ install-bin:
|
||||
#
|
||||
install-hooks:
|
||||
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
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-4.d/
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-5.d/
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/centos-6.d/
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/fedora-core-6.d/
|
||||
cp -R hooks/centos-4/*-* ${prefix}/usr/lib/xen-tools/centos-4.d
|
||||
cp -R hooks/centos-5/*-* ${prefix}/usr/lib/xen-tools/centos-5.d
|
||||
cp -R hooks/centos-6/*-* ${prefix}/usr/lib/xen-tools/centos-6.d
|
||||
cp -R hooks/fedora-core-6/*-* ${prefix}/usr/lib/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/lib/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/lib/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/lib/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/lib/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/lib/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/lib/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
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/debian.d/
|
||||
cp -R hooks/debian/*-* ${prefix}/usr/lib/xen-tools/debian.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d sarge.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d etch.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d lenny.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d squeeze.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d wheezy.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d sid.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d testing.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s debian.d stable.d
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/gentoo.d/
|
||||
cp -R hooks/gentoo/*-* ${prefix}/usr/lib/xen-tools/gentoo.d
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/dapper.d/
|
||||
cp -R hooks/dapper/*-* ${prefix}/usr/lib/xen-tools/dapper.d/
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/edgy.d/
|
||||
cp -R hooks/edgy/*-* ${prefix}/usr/lib/xen-tools/edgy.d/
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d feisty.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d gutsy.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s edgy.d hardy.d
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/intrepid.d/
|
||||
cp -R hooks/intrepid/*-* ${prefix}/usr/lib/xen-tools/intrepid.d/
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s intrepid.d jaunty.d
|
||||
mkdir -p ${prefix}/usr/lib/xen-tools/karmic.d/
|
||||
cp -R hooks/karmic/*-* ${prefix}/usr/lib/xen-tools/karmic.d/
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d lucid.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d maverick.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d natty.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d oneiric.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d precise.d
|
||||
-cd ${prefix}/usr/lib/xen-tools/ && ln -s karmic.d quantal.d
|
||||
cp hooks/common.sh ${prefix}/usr/lib/xen-tools
|
||||
cp -r hooks/common ${prefix}/usr/lib/xen-tools
|
||||
for i in ${prefix}/usr/share/xen-tools/*.d; do if [ -L "$$i" ]; then rm -vf "$$i"; fi; done
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/centos-4.d/
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/centos-5.d/
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/centos-6.d/
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/fedora-core-6.d/
|
||||
cp -R hooks/centos-4/*-* ${prefix}/usr/share/xen-tools/centos-4.d
|
||||
cp -R hooks/centos-5/*-* ${prefix}/usr/share/xen-tools/centos-5.d
|
||||
cp -R hooks/centos-6/*-* ${prefix}/usr/share/xen-tools/centos-6.d
|
||||
cp -R hooks/fedora-core-6/*-* ${prefix}/usr/share/xen-tools/fedora-core-6.d
|
||||
-cd ${prefix}/usr/share/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-5.d
|
||||
-cd ${prefix}/usr/share/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-8.d
|
||||
-cd ${prefix}/usr/share/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-10.d
|
||||
-cd ${prefix}/usr/share/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-12.d
|
||||
-cd ${prefix}/usr/share/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-14.d
|
||||
-cd ${prefix}/usr/share/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-16.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s fedora-core-6.d fedora-core-17.d
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/debian.d/
|
||||
cp -R hooks/debian/*-* ${prefix}/usr/share/xen-tools/debian.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d sarge.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d etch.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d lenny.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d squeeze.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d wheezy.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d jessie.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d sid.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d testing.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s debian.d stable.d
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/gentoo.d/
|
||||
cp -R hooks/gentoo/*-* ${prefix}/usr/share/xen-tools/gentoo.d
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/dapper.d/
|
||||
cp -R hooks/dapper/*-* ${prefix}/usr/share/xen-tools/dapper.d/
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/edgy.d/
|
||||
cp -R hooks/edgy/*-* ${prefix}/usr/share/xen-tools/edgy.d/
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d feisty.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d gutsy.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s edgy.d hardy.d
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/intrepid.d/
|
||||
cp -R hooks/intrepid/*-* ${prefix}/usr/share/xen-tools/intrepid.d/
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s intrepid.d jaunty.d
|
||||
mkdir -p ${prefix}/usr/share/xen-tools/karmic.d/
|
||||
cp -R hooks/karmic/*-* ${prefix}/usr/share/xen-tools/karmic.d/
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d lucid.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d maverick.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d natty.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d oneiric.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d precise.d
|
||||
-cd ${prefix}/usr/share/xen-tools/ && ln -s karmic.d quantal.d
|
||||
-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
|
||||
|
||||
|
||||
#
|
||||
@@ -205,7 +210,6 @@ install-hooks:
|
||||
#
|
||||
install-libraries:
|
||||
-mkdir -p ${prefix}/usr/share/perl5/Xen/Tools
|
||||
cp ./lib/Xen/*.pm ${prefix}/usr/share/perl5/Xen
|
||||
cp ./lib/Xen/Tools/*.pm ${prefix}/usr/share/perl5/Xen/Tools
|
||||
|
||||
#
|
||||
@@ -298,7 +302,9 @@ uninstall:
|
||||
-rm -rf ${prefix}/etc/xen-tools/skel
|
||||
-rmdir ${prefix}/etc/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/share/xen-tools
|
||||
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-list-images.8.gz
|
||||
|
||||
@@ -1,5 +1,11 @@
|
||||
xen-tools 4.3rc2 (released TODO)
|
||||
=======================================
|
||||
xen-tools 4.3.1 (released 30-Jun-2012)
|
||||
======================================
|
||||
|
||||
Bugfix Release only
|
||||
|
||||
|
||||
xen-tools 4.3 (released 26-Jun-2012)
|
||||
====================================
|
||||
|
||||
Bug Fixes
|
||||
---------
|
||||
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.
|
||||
247
TODO.markdown
Normal file
247
TODO.markdown
Normal file
@@ -0,0 +1,247 @@
|
||||
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.
|
||||
|
||||
* Add test for `--size` constraints (upper- and lowercase letters,
|
||||
with and without `B`, etc.)
|
||||
|
||||
* Needs a `--dry-run` or `--check-constraints` option in
|
||||
`xen-create-image` first. Which probably both would be a good
|
||||
idea.
|
||||
|
||||
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
|
||||
|
||||
* MAC addresses should no more depend on the distribution.
|
||||
|
||||
* Let the admin switch between MAC addresses based on XenSource's OUI,
|
||||
its organisation's own OUI or locally administrated MAC addresses.
|
||||
See also http://wiki.xen.org/wiki/Xen_Networking#MAC_addresses
|
||||
File diff suppressed because it is too large
Load Diff
@@ -36,8 +36,6 @@ xen-create-nfs - Create a Xen configuration file for an NFS-root guest.
|
||||
--nfs_server Specify the NFS server to mount the root partition from.
|
||||
--nfs_root Specify the path, upon the NFS server, to mount.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 OPTIONS
|
||||
|
||||
@@ -55,11 +53,8 @@ Read the manual for this script.
|
||||
=item B<--version>
|
||||
Show the version number and exit.
|
||||
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
@@ -71,8 +66,6 @@ Show the version number and exit.
|
||||
support more than the minimal number of options to completement the
|
||||
existing xen-create-image script, however it is hopefully useful.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 REFERENCE
|
||||
|
||||
@@ -81,16 +74,12 @@ Show the version number and exit.
|
||||
|
||||
http://www.debian-administration.org/articles/505
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
Steve Kemp, http://www.steve.org.uk/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -102,7 +91,6 @@ you can redistribute it and/or modify it under
|
||||
the same terms as Perl itself.
|
||||
The LICENSE file contains the full text of the license.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
@@ -112,7 +100,7 @@ use Env;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use Text::Template;
|
||||
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
#
|
||||
@@ -131,7 +119,7 @@ $CONFIG{ 'template' } = '/etc/xen-tools/xm-nfs.tmpl';
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
# store version number away.
|
||||
@@ -141,7 +129,7 @@ $CONFIG{ 'xen_tools_version' } = $RELEASE;
|
||||
#
|
||||
# Read the global configuration file.
|
||||
#
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||
|
||||
|
||||
#
|
||||
@@ -170,7 +158,7 @@ if ( -e "/etc/xen/$CONFIG{'hostname'}.cfg" )
|
||||
#
|
||||
if ( $CONFIG{ 'admins' } )
|
||||
{
|
||||
setupAdminUsers();
|
||||
setupAdminUsers(\%CONFIG);
|
||||
}
|
||||
|
||||
#
|
||||
@@ -186,88 +174,6 @@ createNewConfigurationFile();
|
||||
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
|
||||
|
||||
Parse the command line arguments this script was given.
|
||||
@@ -324,13 +230,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.13 $';
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
logprint("xen-create-nfs release $RELEASE - CVS: $REVISION\n");
|
||||
logprint("xen-create-nfs release $RELEASE\n");
|
||||
exit;
|
||||
}
|
||||
}
|
||||
@@ -409,82 +309,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
|
||||
|
||||
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
|
||||
|
||||
Filename Options:
|
||||
--extension Specify the file extension to use. An empty extension is equal
|
||||
to any extension.
|
||||
|
||||
Help Options:
|
||||
--help Show help information.
|
||||
--manual Read the manual for this script.
|
||||
@@ -23,9 +27,8 @@ xen-delete-image - Delete previously created Xen instances.
|
||||
--hostname Specify the image name to delete.
|
||||
|
||||
Testing options:
|
||||
--test Don't complain if we're not invoked by root.
|
||||
|
||||
=cut
|
||||
--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
|
||||
|
||||
|
||||
=head1 OPTIONS
|
||||
@@ -56,11 +59,8 @@ Do not complain, or exit, if the script is not executed by the root user.
|
||||
=item B<--version>
|
||||
Show the version number and exit.
|
||||
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
@@ -74,8 +74,6 @@ Show the version number and exit.
|
||||
but will fail to remove anything which the user does not have permission
|
||||
to delete.)
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 LOOPBACK EXAMPLE
|
||||
|
||||
@@ -91,8 +89,6 @@ Show the version number and exit.
|
||||
(The matching Xen configuration files beneath /etc/xen will also be
|
||||
removed.)
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 LVM EXAMPLE
|
||||
|
||||
@@ -109,8 +105,6 @@ Show the version number and exit.
|
||||
|
||||
The Xen configuration files will also be removed from beneath /etc/xen.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 EVMS EXAMPLE
|
||||
|
||||
@@ -127,8 +121,6 @@ Show the version number and exit.
|
||||
|
||||
The Xen configuration files will also be removed.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
@@ -136,12 +128,10 @@ Show the version number and exit.
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=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.
|
||||
|
||||
This module is free software;
|
||||
@@ -149,7 +139,6 @@ you can redistribute it and/or modify it under
|
||||
the same terms as Perl itself.
|
||||
The LICENSE file contains the full text of the license.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
@@ -158,6 +147,7 @@ use English;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use File::Path;
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
#
|
||||
@@ -171,16 +161,26 @@ my %CONFIG;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
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.
|
||||
#
|
||||
if ( -e "/etc/xen-tools/xen-tools.conf" )
|
||||
{
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||
}
|
||||
|
||||
|
||||
@@ -216,27 +216,21 @@ E_O_ROOT
|
||||
|
||||
#
|
||||
# Loop over the supplied arguments, and attempt to delete each
|
||||
# image.
|
||||
# image. Check both, bare parameters as well as --hostname options.
|
||||
#
|
||||
while ( my $name = shift )
|
||||
{
|
||||
if ( !xenRunning($name) )
|
||||
{
|
||||
deleteXenImage($name);
|
||||
}
|
||||
else
|
||||
{
|
||||
print "Skipping xen guest '$name' - it appears to be running.\n";
|
||||
}
|
||||
|
||||
my @hosts = ();
|
||||
if (exists($CONFIG{ 'hostname' }) and defined($CONFIG{ 'hostname' })) {
|
||||
my $hostname_option = $CONFIG{ 'hostname' };
|
||||
@hosts = 'ARRAY' eq ref($hostname_option) ?
|
||||
@$hostname_option : $hostname_option;
|
||||
}
|
||||
|
||||
#
|
||||
# Also delete any which were specified using the --hostname flag
|
||||
#
|
||||
my $hosts = $CONFIG{ 'hostname' };
|
||||
foreach my $name (@$hosts)
|
||||
foreach my $name (@ARGV, @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);
|
||||
}
|
||||
@@ -253,81 +247,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
|
||||
|
||||
@@ -350,9 +269,11 @@ sub parseCommandLineArguments
|
||||
"dry-run", \$CONFIG{ 'dry-run' },
|
||||
"lvm=s", \$CONFIG{ 'lvm' },
|
||||
"evms=s", \$CONFIG{ 'evms' },
|
||||
"extension:s", \$CONFIG{ 'extension' },
|
||||
"hostname=s@", \$CONFIG{ 'hostname' },
|
||||
"test", \$CONFIG{ 'test' },
|
||||
"verbose", \$CONFIG{ 'verbose' },
|
||||
"no-xen-ok", \$CONFIG{ 'no_xen_ok' },
|
||||
"help", \$HELP,
|
||||
"manual", \$MANUAL,
|
||||
"version", \$VERSION
|
||||
@@ -364,14 +285,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.41 $';
|
||||
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
print "xen-delete-image release $RELEASE - CVS: $REVISION\n";
|
||||
print "xen-delete-image release $RELEASE\n";
|
||||
exit;
|
||||
|
||||
}
|
||||
@@ -424,33 +338,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
|
||||
|
||||
Delete the named image, and the corresponding configuration file
|
||||
@@ -472,17 +359,17 @@ sub deleteXenImage
|
||||
#
|
||||
# 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.
|
||||
#
|
||||
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' } );
|
||||
}
|
||||
|
||||
#
|
||||
@@ -505,7 +392,8 @@ sub deleteXenImage
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
my %PER_HOST_CONFIG = %CONFIG;
|
||||
$PER_HOST_CONFIG{ 'hostname' } = $hostname;
|
||||
if ( defined( $CONFIG{ 'dir' } ) )
|
||||
{
|
||||
my $prefix = $CONFIG{ 'dir' } . "/domains/";
|
||||
@@ -539,7 +427,7 @@ sub deleteXenImage
|
||||
print "Would remove LVM swap volume /dev/$CONFIG{'lvm'}/$hostname-swap\n";
|
||||
} else {
|
||||
print "Removing swap volume\n";
|
||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-swap --force");
|
||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-swap --force", \%PER_HOST_CONFIG);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -549,7 +437,7 @@ sub deleteXenImage
|
||||
print "Would remove LVM disk volume /dev/$CONFIG{'lvm'}/$hostname-disk\n";
|
||||
} else {
|
||||
print "Removing LVM disk volume\n";
|
||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-disk --force");
|
||||
runCommand("lvremove /dev/$CONFIG{'lvm'}/$hostname-disk --force", \%PER_HOST_CONFIG);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -571,8 +459,8 @@ sub deleteXenImage
|
||||
print "Would remove EVMS swap volume: $CONFIG{'evms'}/$hostname-swap\n";
|
||||
} else {
|
||||
print "Removing EVMS swap volume\n";
|
||||
runCommand("echo Delete : /dev/evms/$hostname-swap | evms");
|
||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-swap | evms");
|
||||
runCommand("echo Delete : /dev/evms/$hostname-swap | evms", \%PER_HOST_CONFIG);
|
||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-swap | evms", \%PER_HOST_CONFIG);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -583,8 +471,8 @@ sub deleteXenImage
|
||||
print "Would remove EVMS disk volume: $CONFIG{'evms'}/$hostname-swap\n";
|
||||
} else {
|
||||
print "Removing EVMS disk volume\n";
|
||||
runCommand("echo Delete : /dev/evms/$hostname-disk | evms");
|
||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-disk | evms");
|
||||
runCommand("echo Delete : /dev/evms/$hostname-disk | evms", \%PER_HOST_CONFIG);
|
||||
runCommand("echo Delete : $CONFIG{'evms'}/$hostname-disk | evms", \%PER_HOST_CONFIG);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -597,66 +485,3 @@ sub deleteXenImage
|
||||
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]
|
||||
|
||||
Filename Options:
|
||||
--extension Specify the file extension to use. An empty extension is equal
|
||||
to any extension.
|
||||
|
||||
Help Options:
|
||||
--help Show this scripts help information.
|
||||
--manual Read this scripts manual.
|
||||
@@ -16,6 +20,7 @@ xen-list-images - List all the created and configured Xen images.
|
||||
Testing options:
|
||||
--test Specify an alternate Xen configuration directory.
|
||||
|
||||
|
||||
=head1 OPTIONS
|
||||
|
||||
=over 8
|
||||
@@ -48,26 +53,22 @@ Show the version number and exit.
|
||||
and then either the IP address configured, or "DHCP" to denote
|
||||
a dynamic host.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 TODO
|
||||
|
||||
It should be possible to determine the disk(s) used by the images,
|
||||
and then display their sizes.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
Steve Kemp, http://www.steve.org.uk/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
=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.
|
||||
|
||||
This module is free software;
|
||||
@@ -83,6 +84,7 @@ use English;
|
||||
use File::Temp qw/ tempdir /;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
#
|
||||
@@ -94,21 +96,22 @@ use Pod::Usage;
|
||||
my %CONFIG;
|
||||
|
||||
#
|
||||
# Default prefix
|
||||
# Default values
|
||||
#
|
||||
$CONFIG{ 'prefix' } = "/etc/xen";
|
||||
$CONFIG{ 'extension' } = '.cfg';
|
||||
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
|
||||
#
|
||||
# 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 +147,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
|
||||
|
||||
Parse the arguments specified upon the command line.
|
||||
@@ -238,6 +164,7 @@ sub parseCommandLineArguments
|
||||
# Parse options.
|
||||
#
|
||||
GetOptions( "test=s", \$CONFIG{ 'prefix' },
|
||||
"extension:s", \$CONFIG{ 'extension' },
|
||||
"help", \$HELP,
|
||||
"manual", \$MANUAL,
|
||||
"version", \$VERSION );
|
||||
@@ -248,13 +175,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.30 $';
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
print "xen-list-images release $RELEASE - CVS: $REVISION\n";
|
||||
print "xen-list-images release $RELEASE\n";
|
||||
exit;
|
||||
}
|
||||
}
|
||||
@@ -274,9 +195,12 @@ sub findXenInstances
|
||||
{
|
||||
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);
|
||||
@@ -341,6 +265,7 @@ sub displayInstance
|
||||
print "Memory: $mem\n";
|
||||
print "IP: " . $ip . $mac . "\n" if length($ip);
|
||||
print "DHCP" . $mac . "\n" if $dhcp;
|
||||
print "Config: $file\n";
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -20,8 +20,6 @@ xen-resize-guest - Resize a loopback or LVM based xen guest.
|
||||
--force Force the resize to happen without a last-chance delay.
|
||||
--hostname Specify the hostname of the guest to resize.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 OPTIONS
|
||||
|
||||
@@ -53,8 +51,6 @@ Show the version number and exit.
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
@@ -74,15 +70,12 @@ Show the version number and exit.
|
||||
More than once I've heard of users making mistakes and breaking their
|
||||
filesystems; hence this tool.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
Steve Kemp, http://www.steve.org.uk/
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -94,7 +87,6 @@ you can redistribute it and/or modify it under
|
||||
the same terms as Perl itself.
|
||||
The LICENSE file contains the full text of the license.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
@@ -104,6 +96,7 @@ use Env;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use Text::Template;
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
|
||||
@@ -116,14 +109,19 @@ my %CONFIG;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
#
|
||||
# Find xen toolstack command
|
||||
#
|
||||
$CONFIG{ 'xm' } = findXenToolstack();
|
||||
|
||||
|
||||
#
|
||||
# Read the global configuration file.
|
||||
#
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||
|
||||
|
||||
#
|
||||
@@ -289,84 +287,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
|
||||
|
||||
Parse the command line arguments this script was given.
|
||||
@@ -482,7 +402,7 @@ EOF
|
||||
#
|
||||
# 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";
|
||||
exit 1;
|
||||
@@ -523,31 +443,3 @@ EOF
|
||||
$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);
|
||||
}
|
||||
|
||||
@@ -18,9 +18,6 @@ xen-update-image - Update the software installed upon offline Xen images.
|
||||
--lvm Specify the LVM volume group which contains the image(s).
|
||||
--evms Specify the EVMS container which contains the image(s).
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
|
||||
=head1 OPTIONS
|
||||
|
||||
@@ -46,8 +43,6 @@ Show the version number and exit.
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
@@ -65,8 +60,6 @@ Show the version number and exit.
|
||||
corruption otherwise it will allow you to update your image without
|
||||
booting it.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 EXAMPLES
|
||||
|
||||
@@ -77,8 +70,6 @@ Show the version number and exit.
|
||||
|
||||
xen-update-images --dir=/home/xen test.my.flat x11.my.flat
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
@@ -86,7 +77,6 @@ Show the version number and exit.
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -107,6 +97,7 @@ use File::Temp qw/ tempdir /;
|
||||
use File::Copy qw/ mv cp /;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
#
|
||||
@@ -120,7 +111,13 @@ my %CONFIG;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
#
|
||||
# Find xen toolstack command
|
||||
#
|
||||
$CONFIG{ 'xm' } = findXenToolstack();
|
||||
|
||||
|
||||
#
|
||||
@@ -128,7 +125,7 @@ my $RELEASE = '4.3.1';
|
||||
#
|
||||
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 +165,7 @@ E_O_ROOT
|
||||
#
|
||||
while ( my $name = shift )
|
||||
{
|
||||
if ( !xenRunning($name) )
|
||||
if ( !xenRunning($name, \%CONFIG) )
|
||||
{
|
||||
updateXenImage($name);
|
||||
}
|
||||
@@ -331,110 +328,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
|
||||
|
||||
Parse the arguments specified upon the command line.
|
||||
@@ -463,13 +356,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.29 $';
|
||||
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
print "xen-update-image release $RELEASE - CVS: $REVISION\n";
|
||||
print "xen-update-image release $RELEASE\n";
|
||||
exit;
|
||||
|
||||
}
|
||||
|
||||
@@ -4,8 +4,6 @@
|
||||
|
||||
xt-create-config - Create a Xen configuration file for a new guest
|
||||
|
||||
=cut
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
xt-create-config [options]
|
||||
@@ -39,7 +37,6 @@ xt-create-config - Create a Xen configuration file for a new guest
|
||||
All other options from xen-create-image, such as the new IP address(es)
|
||||
to give to the new instance, will be passed as environmental variables.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 ABOUT
|
||||
|
||||
@@ -53,8 +50,6 @@ xt-create-config - Create a Xen configuration file for a new guest
|
||||
|
||||
By default the script will use /etc/xen-tools/xm.tmpl as its input.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 INVOCATION
|
||||
|
||||
@@ -75,9 +70,6 @@ xt-create-config - Create a Xen configuration file for a new guest
|
||||
=for example end
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 ARGUMENT PASSING
|
||||
|
||||
This script will be invoked with a full copy of the arguments from
|
||||
@@ -102,7 +94,6 @@ xt-create-config - Create a Xen configuration file for a new guest
|
||||
for the "Text::Template" perl module. (If you have the perldoc
|
||||
package installed you can read this with "perldoc Text::Template".)
|
||||
|
||||
=cut
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
@@ -110,7 +101,6 @@ xt-create-config - Create a Xen configuration file for a new guest
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -156,7 +146,7 @@ $CONFIG{ 'extension' } = '.cfg';
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
|
||||
@@ -177,7 +167,7 @@ checkArguments();
|
||||
#
|
||||
if ( $ENV{ 'admins' } )
|
||||
{
|
||||
setupAdminUsers();
|
||||
setupAdminUsers(\%CONFIG);
|
||||
}
|
||||
|
||||
|
||||
@@ -215,7 +205,7 @@ sub parseCommandLineArguments
|
||||
#
|
||||
GetOptions( "admins=s", \$ENV{ 'admins' },
|
||||
"output=s", \$CONFIG{ 'output' },
|
||||
"extension=s", \$CONFIG{ 'extension' },
|
||||
"extension:s", \$CONFIG{ 'extension' },
|
||||
"template=s", \$CONFIG{ 'template' },
|
||||
"verbose", \$CONFIG{ 'verbose' },
|
||||
"help", \$HELP,
|
||||
@@ -229,13 +219,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.47 $';
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
print "xt-create-xen-config release $RELEASE - CVS: $REVISION\n";
|
||||
print "xt-create-xen-config release $RELEASE\n";
|
||||
exit;
|
||||
}
|
||||
}
|
||||
@@ -375,7 +359,7 @@ sub createXenConfig
|
||||
#
|
||||
# The memory size: Convert Gb -> Mb.
|
||||
#
|
||||
if ( $ENV{ 'memory' } =~ /^(\d+)Gb.*$/i )
|
||||
if ( $ENV{ 'memory' } =~ /^(\d+)Gb?.*$/i )
|
||||
{
|
||||
$ENV{ 'memory' } = $1 * 1024;
|
||||
}
|
||||
@@ -383,7 +367,7 @@ sub createXenConfig
|
||||
#
|
||||
# Remove any trailing Mb.
|
||||
#
|
||||
if ( $ENV{ 'memory' } =~ /^(\d+)Mb.*$/i )
|
||||
if ( $ENV{ 'memory' } =~ /^(\d+)Mb?.*$/i )
|
||||
{
|
||||
$ENV{ 'memory' } = $1;
|
||||
}
|
||||
@@ -404,13 +388,13 @@ sub createXenConfig
|
||||
$ENV{ 'image_suffix' } = '';
|
||||
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
|
||||
{
|
||||
@@ -470,80 +454,3 @@ sub createXenConfig
|
||||
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);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,8 +4,6 @@
|
||||
|
||||
xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
||||
|
||||
=cut
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
xt-customize-image [options]
|
||||
@@ -25,7 +23,6 @@ xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
||||
All other options from xen-create-image, such as the new IP address(es)
|
||||
to give to the new instance, will be passed as environmental variables.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 NOTES
|
||||
|
||||
@@ -41,8 +38,6 @@ xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
||||
--location - The temporary installation root of the new install
|
||||
--dist - The distribution which has been installed.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 HOOK SCRIPTS
|
||||
|
||||
@@ -54,11 +49,9 @@ xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
||||
the --location option.
|
||||
|
||||
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.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
@@ -66,8 +59,6 @@ xt-customize-image - Customize a freshly installed copy of GNU/Linux
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -98,7 +89,7 @@ my %CONFIG;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
|
||||
@@ -159,13 +150,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.33 $';
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
print "xt-customize-image release $RELEASE - CVS: $REVISION\n";
|
||||
print "xt-customize-image release $RELEASE\n";
|
||||
exit;
|
||||
}
|
||||
}
|
||||
@@ -221,7 +206,7 @@ sub checkArguments
|
||||
# If there are no scripts then we clearly cannot
|
||||
# customise it!
|
||||
#
|
||||
my $dir = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||
my $dir = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||
|
||||
if ( !-d $dir )
|
||||
{
|
||||
@@ -263,7 +248,7 @@ sub runDistributionHooks
|
||||
#
|
||||
# Hook directory.
|
||||
#
|
||||
my $hooks = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d/";
|
||||
my $hooks = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d/";
|
||||
|
||||
#
|
||||
# Installation prefix
|
||||
|
||||
@@ -5,8 +5,6 @@
|
||||
xt-guess-suite-and-mirror - Tries to guess the most suitable suite and
|
||||
mirror for DomUs on Debian and Ubuntu Dom0s.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
--suite Show suite
|
||||
@@ -20,7 +18,6 @@ mirror for DomUs on Debian and Ubuntu Dom0s.
|
||||
--manual Show the manual for this script.
|
||||
--version Show the version number and exit.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
@@ -28,14 +25,12 @@ xt-guess-suite-and-mirror tries to find the mirror and suite the Xen
|
||||
Dom0 is currently using and returns them in a way suitable for
|
||||
xen-create-image(1) or the backticks feature in xen-tools.conf.
|
||||
|
||||
=cut
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
Axel Beckert, http://noone.org/abe/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -55,9 +50,9 @@ full text of the license.
|
||||
# Fallback to Debian or Ubuntu in case we can't find anything
|
||||
my $fallback = 'Debian';
|
||||
|
||||
# Which mirrors to use if everything else fails (cdn.debian.net uses
|
||||
# GeoIP, see http://wiki.debian.org/DebianGeoMirror)
|
||||
my %fallback_mirror = ( Debian => 'http://cdn.debian.net/debian/',
|
||||
# Which mirrors to use if everything else fails (http.debian.net
|
||||
# redirects to a working mirror nearby)
|
||||
my %fallback_mirror = ( Debian => 'http://http.debian.net/debian/',
|
||||
Ubuntu => 'http://archive.ubuntu.com/ubuntu/' );
|
||||
|
||||
# Which suite to use if everything else fails. For Debian "stable"
|
||||
@@ -81,7 +76,7 @@ use strict;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
# Init
|
||||
my $mirror = '';
|
||||
|
||||
@@ -4,8 +4,6 @@
|
||||
|
||||
xt-install-image - Install a fresh copy of GNU/Linux into a directory
|
||||
|
||||
=cut
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
xt-install-image [options]
|
||||
@@ -39,8 +37,6 @@ xt-install-image - Install a fresh copy of GNU/Linux into a directory
|
||||
All other options from xen-create-image will be passed as environmental
|
||||
variables.
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 NOTES
|
||||
|
||||
@@ -50,8 +46,6 @@ xt-install-image - Install a fresh copy of GNU/Linux into a directory
|
||||
configuration, etc.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
=head1 INSTALLATION METHODS
|
||||
|
||||
There are several available methods of installation, depending upon the
|
||||
@@ -78,8 +72,6 @@ Untar a .tar file into the new installation location. This tarfile is assumed t
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
=head1 AUTHORS
|
||||
|
||||
@@ -88,7 +80,6 @@ Untar a .tar file into the new installation location. This tarfile is assumed t
|
||||
Dmitry Nedospasov, http://nedos.net/
|
||||
Stéphane Jourdois
|
||||
|
||||
=cut
|
||||
|
||||
=head1 LICENSE
|
||||
|
||||
@@ -108,6 +99,7 @@ use Env;
|
||||
use File::Copy;
|
||||
use Getopt::Long;
|
||||
use Pod::Usage;
|
||||
use Xen::Tools::Common;
|
||||
|
||||
|
||||
#
|
||||
@@ -118,7 +110,7 @@ my %CONFIG;
|
||||
#
|
||||
# Release number.
|
||||
#
|
||||
my $RELEASE = '4.3.1';
|
||||
my $RELEASE = '4.4~dev';
|
||||
|
||||
|
||||
#
|
||||
@@ -132,13 +124,19 @@ my $RELEASE = '4.3.1';
|
||||
# needDirectory Defined if we need an install-source directory specified.
|
||||
#
|
||||
#
|
||||
my $debootstrap_cmd;
|
||||
my %dispatch = (
|
||||
"copy" => { sub => \&do_copy,
|
||||
needBinary => "/bin/cp",
|
||||
needDirectory => 1,
|
||||
},
|
||||
"debootstrap" => { sub => \&do_debootstrap,
|
||||
needBinary => "/usr/sbin/debootstrap",
|
||||
needBinary => ["/usr/sbin/debootstrap", "/usr/bin/cdebootstrap", "/usr/bin/cdebootstrap-static"],
|
||||
var => \$debootstrap_cmd,
|
||||
},
|
||||
"cdebootstrap" => { sub => \&do_debootstrap,
|
||||
needBinary => ["/usr/sbin/cdebootstrap", "/usr/bin/cdebootstrap-static"],
|
||||
var => \$debootstrap_cmd,
|
||||
},
|
||||
"rinse" => { sub => \&do_rinse,
|
||||
needBinary => "/usr/sbin/rinse",
|
||||
@@ -156,7 +154,7 @@ my %dispatch = (
|
||||
#
|
||||
# Read the global configuration file.
|
||||
#
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf");
|
||||
readConfigurationFile("/etc/xen-tools/xen-tools.conf", \%CONFIG);
|
||||
|
||||
|
||||
#
|
||||
@@ -179,7 +177,7 @@ if ( $CONFIG{ 'config' } )
|
||||
}
|
||||
|
||||
# Read the file, if it exists.
|
||||
readConfigurationFile($path) if ( -e $path );
|
||||
readConfigurationFile($path, \%CONFIG) if ( -e $path );
|
||||
}
|
||||
|
||||
|
||||
@@ -209,13 +207,35 @@ if ( defined( $CONFIG{ 'install-method' } ) &&
|
||||
#
|
||||
|
||||
# Do we need to test for a binary.
|
||||
if ( ( $installer->{ 'needBinary' } ) &&
|
||||
( !-x $installer->{ 'needBinary' } ) )
|
||||
{
|
||||
print
|
||||
"The following required binary for the installation was not found\n";
|
||||
print "\t" . $installer->{ 'needBinary' } . "\n";
|
||||
exit 1;
|
||||
if ( $installer->{ 'needBinary' } ) {
|
||||
if ( 'ARRAY' eq ref $installer->{ 'needBinary' } ) {
|
||||
unless (ref $installer->{ 'var' }) {
|
||||
die "Assertion: If dispatch->->needBinary is an array ref, dispatch->->var must exist";
|
||||
}
|
||||
|
||||
foreach my $binary (@{$installer->{ 'needBinary' }}) {
|
||||
if (-x $binary) {
|
||||
${$installer->{ 'var' }} = $binary;
|
||||
last;
|
||||
}
|
||||
}
|
||||
|
||||
unless ( ${$installer->{ 'var' }} ) {
|
||||
print
|
||||
"One of the following binaries are required for the installation, but none was found\n";
|
||||
print "\t" . join(', ', @{$installer->{ 'needBinary' }}) . "\n";
|
||||
exit 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if ( !-x $installer->{ 'needBinary' } ) {
|
||||
print
|
||||
"The following required binary for the installation was not found\n";
|
||||
print "\t" . $installer->{ 'needBinary' } . "\n";
|
||||
exit 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
# Do we need a directory specified as the installation source?
|
||||
@@ -280,87 +300,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
|
||||
|
||||
Parse the command line arguments this script was given.
|
||||
@@ -411,13 +350,7 @@ sub parseCommandLineArguments
|
||||
|
||||
if ($VERSION)
|
||||
{
|
||||
my $REVISION = '$Revision: 1.65 $';
|
||||
if ( $REVISION =~ /1.([0-9.]+) / )
|
||||
{
|
||||
$REVISION = $1;
|
||||
}
|
||||
|
||||
print "xt-install-image release $RELEASE - CVS: $REVISION\n";
|
||||
print "xt-install-image release $RELEASE\n";
|
||||
exit;
|
||||
}
|
||||
}
|
||||
@@ -473,7 +406,7 @@ sub checkArguments
|
||||
# If there are no scripts then we clearly cannot
|
||||
# customise it!
|
||||
#
|
||||
my $dir = "/usr/lib/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||
my $dir = "/usr/share/xen-tools/" . $CONFIG{ 'dist' } . ".d";
|
||||
|
||||
if ( !-d $dir )
|
||||
{
|
||||
@@ -553,53 +486,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
|
||||
|
||||
This function will copy all the .deb files from one directory
|
||||
@@ -685,7 +571,7 @@ sub do_copy
|
||||
#
|
||||
# Run the copy command.
|
||||
#
|
||||
runCommand($cmd);
|
||||
runCommand($cmd, \%CONFIG);
|
||||
}
|
||||
|
||||
|
||||
@@ -705,21 +591,9 @@ sub do_debootstrap
|
||||
# The command is a little configurable - mostly to allow you
|
||||
# to use cdebootstrap.
|
||||
#
|
||||
my $cmd = $CONFIG{ 'debootstrap-cmd' };
|
||||
my $cmd = $CONFIG{ 'debootstrap-cmd' } || $debootstrap_cmd;
|
||||
print "Using $cmd as debootstrap command\n";
|
||||
my $cachedir = $CONFIG{ 'cachedir' };
|
||||
if ( !$cmd )
|
||||
{
|
||||
if (-x '/usr/sbin/debootstrap') {
|
||||
$cmd = '/usr/sbin/debootstrap';
|
||||
} elsif (-x '/usr/sbin/cdebootstrap') {
|
||||
$cmd = '/usr/sbin/cdebootstrap';
|
||||
} else {
|
||||
print STDERR "Found neither debootstrap nor cdebootstrap and no --debootstrap-cmd given\n";
|
||||
exit 1;
|
||||
}
|
||||
print "Using $cmd as debootstrap command\n";
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Cache from host -> new installation if we've got caching
|
||||
@@ -736,7 +610,7 @@ sub do_debootstrap
|
||||
}
|
||||
$cachedir = $xtcache;
|
||||
}
|
||||
runCommand("mkdir -p $CONFIG{'location'}/var/cache/apt/archives");
|
||||
runCommand("mkdir -p $CONFIG{'location'}/var/cache/apt/archives", \%CONFIG);
|
||||
copyDebFiles( "$cachedir",
|
||||
"$CONFIG{'location'}/var/cache/apt/archives" );
|
||||
print("Done\n");
|
||||
@@ -777,7 +651,7 @@ sub do_debootstrap
|
||||
#
|
||||
# Run the command.
|
||||
#
|
||||
runCommand($command);
|
||||
runCommand($command, \%CONFIG);
|
||||
|
||||
|
||||
#
|
||||
@@ -848,7 +722,7 @@ sub do_rinse
|
||||
$command .= " --verbose";
|
||||
}
|
||||
|
||||
runCommand($command);
|
||||
runCommand($command, \%CONFIG);
|
||||
}
|
||||
|
||||
|
||||
@@ -891,7 +765,7 @@ sub do_rpmstrap
|
||||
# The command we're going to run.
|
||||
#
|
||||
my $command = "rpmstrap $EXTRA $CONFIG{'dist'} $CONFIG{'location'} $mirror";
|
||||
runCommand($command);
|
||||
runCommand($command, \%CONFIG);
|
||||
}
|
||||
|
||||
|
||||
@@ -925,5 +799,5 @@ sub do_tar
|
||||
#
|
||||
# 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
|
||||
|
||||
By default, xen-create-image now generates a random root password and
|
||||
|
||||
69
debian/changelog
vendored
69
debian/changelog
vendored
@@ -1,3 +1,72 @@
|
||||
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)
|
||||
- Correctly handle aborts in END block. (Closes: #704882)
|
||||
- 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()
|
||||
- xt-install-image: Don't bail out if only cdebootstrap is installed
|
||||
but not debootstrap (Thanks Elmar Heeb!)
|
||||
- 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.
|
||||
- Fixes export of environment variables. Previously they could contain
|
||||
dashes and then were only accessible from within Perl, but not from
|
||||
within Bash.
|
||||
- Fixes creation of "ARRAY(0x…).log" named log files.
|
||||
- Makes some options (like --pygrub) negatable.
|
||||
- Uses Test::NoTabs; add according build-dependency.
|
||||
- Removes unused Perl modules Xen::Tools and Xen::Tools::Log from
|
||||
source code. Also removes the according tests from the test suite.
|
||||
→ Remove no more needed build-dependency on Moose.
|
||||
* 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'
|
||||
|
||||
29
debian/control
vendored
29
debian/control
vendored
@@ -2,7 +2,15 @@ Source: xen-tools
|
||||
Section: utils
|
||||
Priority: extra
|
||||
Maintainer: Axel Beckert <abe@debian.org>
|
||||
Build-Depends: debhelper (>= 7.0.0), libtest-pod-perl, libtext-template-perl, libfile-slurp-perl, devscripts, libmoose-perl, libtest-pod-coverage-perl, git
|
||||
Build-Depends: debhelper (>= 7.0.0),
|
||||
devscripts,
|
||||
git,
|
||||
libfile-slurp-perl,
|
||||
libfile-which-perl,
|
||||
libtest-notabs-perl,
|
||||
libtest-pod-coverage-perl,
|
||||
libtest-pod-perl,
|
||||
libtext-template-perl
|
||||
Standards-Version: 3.9.3
|
||||
Homepage: http://xen-tools.org/software/xen-tools
|
||||
Vcs-Browser: http://gitorious.org/xen-tools/xen-tools
|
||||
@@ -10,9 +18,22 @@ Vcs-Git: git://gitorious.org/xen-tools/xen-tools.git
|
||||
|
||||
Package: xen-tools
|
||||
Architecture: all
|
||||
Depends: debootstrap | cdebootstrap, perl-modules, libtext-template-perl, libconfig-inifiles-perl, libfile-slurp-perl, ${misc:Depends}, openssh-client
|
||||
Recommends: xen-hypervisor-amd64 | xen-hypervisor-i386 | xen-hypervisor-i386-pae, rinse (>= 1.9.1-1), libexpect-perl, xen-utils
|
||||
Suggests: reiserfsprogs, xfsprogs, cfengine2, btrfs-tools
|
||||
Depends: debootstrap | cdebootstrap,
|
||||
libconfig-inifiles-perl,
|
||||
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
|
||||
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/
|
||||
|
||||
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>,
|
||||
Dmitry Nedospasov <dmitry@nedos.net>, and
|
||||
Stéphane Jourdois <sjourdois@gmail.com>
|
||||
|
||||
2
debian/dirs
vendored
2
debian/dirs
vendored
@@ -1,4 +1,4 @@
|
||||
/etc/xen-tools
|
||||
/etc/xen-tools/role.d
|
||||
/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
|
||||
README
|
||||
SUPPORT
|
||||
BUGS
|
||||
TODO
|
||||
KNOWN_BUGS
|
||||
NEWS
|
||||
README.markdown
|
||||
SUPPORT.markdown
|
||||
BUGS.markdown
|
||||
TODO.markdown
|
||||
KNOWN_BUGS.markdown
|
||||
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
|
||||
54
debian/rules
vendored
54
debian/rules
vendored
@@ -2,55 +2,7 @@
|
||||
# Uncomment this to turn on verbose mode.
|
||||
#export DH_VERBOSE=1
|
||||
|
||||
%:
|
||||
dh $@
|
||||
|
||||
configure: configure-stamp
|
||||
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
|
||||
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
|
||||
override_dh_auto_build:
|
||||
|
||||
1
debian/triggers
vendored
Normal file
1
debian/triggers
vendored
Normal file
@@ -0,0 +1 @@
|
||||
activate update-initramfs
|
||||
@@ -125,13 +125,14 @@ install-method = debootstrap
|
||||
# Disk and Sizing options.
|
||||
##
|
||||
#
|
||||
size = 4Gb # Disk image size.
|
||||
memory = 128Mb # Memory size
|
||||
swap = 128Mb # Swap size
|
||||
# noswap = 1 # Don't use swap at all for the new system.
|
||||
fs = ext3 # use the EXT3 filesystem for the disk image.
|
||||
dist = `xt-guess-suite-and-mirror --suite` # Default distribution to install.
|
||||
image = sparse # Specify sparse vs. full disk images.
|
||||
size = 4G # Root disk, suffix (G, M, k) required
|
||||
memory = 128M # Suffix (G, M, k) required
|
||||
swap = 128M # Suffix (G, M, k) required
|
||||
# noswap = 1 # Don't use swap at all for new systems.
|
||||
fs = ext3 # Default file system for any disk
|
||||
dist = `xt-guess-suite-and-mirror --suite`
|
||||
# Default distribution is determined by Dom0's distribution
|
||||
image = sparse # Specify sparse vs. full disk images (file based images only)
|
||||
|
||||
#
|
||||
# See the README for currently supported and tested distributions. You can
|
||||
@@ -235,6 +236,13 @@ image = sparse # Specify sparse vs. full disk images.
|
||||
kernel = /boot/vmlinuz-`uname -r`
|
||||
initrd = /boot/initrd.img-`uname -r`
|
||||
|
||||
#
|
||||
# Uncomment the following line if you wish to use pygrub by default
|
||||
# for all distributions.
|
||||
#
|
||||
# pygrub = 1
|
||||
#
|
||||
|
||||
#
|
||||
# The architecture to use when using debootstrap, rinse, or rpmstrap.
|
||||
#
|
||||
@@ -266,6 +274,7 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
||||
# mirror_lenny = http://archive.debian.org/debian
|
||||
# mirror_squeeze = 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_dapper = http://old-releases.ubuntu.com/ubuntu
|
||||
# mirror_edgy = http://old-releases.ubuntu.com/ubuntu
|
||||
@@ -277,10 +286,11 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
||||
# mirror_karmic = http://old-releases.ubuntu.com/ubuntu
|
||||
# mirror_lucid = http://archive.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_precise = 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
|
||||
# proxy for the guest
|
||||
@@ -290,6 +300,7 @@ mirror = `xt-guess-suite-and-mirror --mirror`
|
||||
#
|
||||
# Filesystem options for the different filesystems we support.
|
||||
#
|
||||
ext4_options = noatime,nodiratime,errors=remount-ro
|
||||
ext3_options = noatime,nodiratime,errors=remount-ro
|
||||
ext2_options = noatime,nodiratime,errors=remount-ro
|
||||
xfs_options = defaults
|
||||
|
||||
@@ -8,7 +8,8 @@
|
||||
#
|
||||
{ if ( ( $kernel ) && ( !defined($pygrub)) )
|
||||
{
|
||||
$OUT.= "kernel = '$kernel'";
|
||||
$OUT .= "kernel = '$kernel'\n";
|
||||
$OUT .= "extra = 'elevator=noop'";
|
||||
}
|
||||
}
|
||||
{ if ( ( $initrd ) && ( !defined($pygrub)) )
|
||||
|
||||
@@ -19,7 +19,7 @@ hooks/
|
||||
* The installation will have a running installation of OpenSSH
|
||||
|
||||
The subdirectories in this hooks/ directory will be installed
|
||||
to the directory /usr/lib/xen-tools/
|
||||
to the directory /usr/share/xen-tools/
|
||||
|
||||
Steve
|
||||
--
|
||||
|
||||
@@ -3,13 +3,13 @@
|
||||
# This script sets up the kernel and fstab for CentOS 5.
|
||||
#
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -21,16 +21,16 @@ fi
|
||||
logMessage Script $0 starting
|
||||
|
||||
# Make the console work
|
||||
sed -i "/Cancelled/ {G;s/$/co:2345:respawn:\/sbin\/mingetty console/;}" ${prefix}/etc/inittab
|
||||
sed -i "s/^1:2345/#1:2345/" ${prefix}/etc/inittab
|
||||
sed -i "/Cancelled/ {G;s/$/co:2345:respawn:\/sbin\/mingetty console/;}" ${TARGET}/etc/inittab
|
||||
sed -i "s/^1:2345/#1:2345/" ${TARGET}/etc/inittab
|
||||
|
||||
# MAKEDEV is needed at this point
|
||||
chroot ${prefix} ln -s /sbin/MAKEDEV /dev/MAKEDEV
|
||||
chroot ${prefix} /sbin/MAKEDEV sda sdb sdc sdd
|
||||
chroot ${TARGET} ln -s /sbin/MAKEDEV /dev/MAKEDEV
|
||||
chroot ${TARGET} /sbin/MAKEDEV sda sdb sdc sdd
|
||||
|
||||
# Create fstab
|
||||
logMessage Create /etc/fstab
|
||||
cat > ${prefix}/etc/fstab << EOF
|
||||
cat > ${TARGET}/etc/fstab << EOF
|
||||
# /etc/fstab: static file system information.
|
||||
#
|
||||
# <file system> <mount point> <type> <options> <dump> <pass>
|
||||
@@ -39,26 +39,26 @@ none /dev/pts devpts mode=0620 0 0
|
||||
EOF
|
||||
|
||||
for i in `seq 1 $NUMPARTITIONS`; do
|
||||
echo -n "/dev/xvde$i " >> ${prefix}/etc/fstab
|
||||
echo -n "/dev/xvde$i " >> ${TARGET}/etc/fstab
|
||||
eval part=\$PARTITION$i
|
||||
if [ ! -z "`echo $part | grep swap`" ]; then
|
||||
echo "none swap ws 0 0" >> ${prefix}/etc/fstab
|
||||
echo "none swap ws 0 0" >> ${TARGET}/etc/fstab
|
||||
else
|
||||
echo $part | awk -F: '{print $4,$3,$5,0,1}' >> ${prefix}/etc/fstab
|
||||
echo $part | awk -F: '{print $4,$3,$5,0,1}' >> ${TARGET}/etc/fstab
|
||||
fi
|
||||
done
|
||||
|
||||
# Install the kernel, grub and perl
|
||||
chroot ${prefix} yum clean expire-cache
|
||||
chroot ${prefix} yum -y install kernel-xen grub.x86_64 perl.x86_64
|
||||
chroot ${TARGET} yum clean expire-cache
|
||||
chroot ${TARGET} yum -y install kernel-xen grub.x86_64 perl.x86_64
|
||||
|
||||
KERNELVERSION=`ls ${prefix}/boot/vmlinuz-* | sed "s#$prefix/boot/vmlinuz-##"`
|
||||
KERNELVERSION=`ls ${TARGET}/boot/vmlinuz-* | sed "s#${TARGET}/boot/vmlinuz-##"`
|
||||
logMessage "Kernel $KERNELVERSION found"
|
||||
|
||||
# Create grub's menu.list
|
||||
logMessage "Creating /boot/grub/menu.lst"
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
cat > ${prefix}/boot/grub/menu.lst << EOF
|
||||
mkdir -p ${TARGET}/boot/grub
|
||||
cat > ${TARGET}/boot/grub/menu.lst << EOF
|
||||
# WARNING : Don't forget to update this when you upgrade kernel !
|
||||
# You can also exclude kernel-xen from updates by putting
|
||||
# exclude=kernel-xen in in [main] in yum.conf
|
||||
@@ -66,7 +66,7 @@ cat > ${prefix}/boot/grub/menu.lst << EOF
|
||||
default=0
|
||||
timeout=5
|
||||
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
|
||||
EOF
|
||||
|
||||
|
||||
@@ -1 +1 @@
|
||||
../common/15-disable-hwclock
|
||||
../common/15-setup-arch
|
||||
@@ -3,13 +3,13 @@
|
||||
# This script sets up the kernel and fstab for CentOS 5.
|
||||
#
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -21,16 +21,16 @@ fi
|
||||
logMessage Script $0 starting
|
||||
|
||||
# Make the console work
|
||||
sed -i "/Cancelled/ {G;s/$/co:2345:respawn:\/sbin\/mingetty console/;}" ${prefix}/etc/inittab
|
||||
sed -i "s/^1:2345/#1:2345/" ${prefix}/etc/inittab
|
||||
sed -i "/Cancelled/ {G;s/$/co:2345:respawn:\/sbin\/mingetty console/;}" ${TARGET}/etc/inittab
|
||||
sed -i "s/^1:2345/#1:2345/" ${TARGET}/etc/inittab
|
||||
|
||||
# MAKEDEV is needed at this point
|
||||
chroot ${prefix} ln -s /sbin/MAKEDEV /dev/MAKEDEV
|
||||
chroot ${prefix} /sbin/MAKEDEV sda sdb sdc sdd
|
||||
chroot ${TARGET} ln -s /sbin/MAKEDEV /dev/MAKEDEV
|
||||
chroot ${TARGET} /sbin/MAKEDEV sda sdb sdc sdd
|
||||
|
||||
# Create fstab
|
||||
logMessage Create /etc/fstab
|
||||
cat > ${prefix}/etc/fstab << EOF
|
||||
cat > ${TARGET}/etc/fstab << EOF
|
||||
# /etc/fstab: static file system information.
|
||||
#
|
||||
# <file system> <mount point> <type> <options> <dump> <pass>
|
||||
@@ -39,26 +39,26 @@ none /dev/pts devpts mode=0620 0 0
|
||||
EOF
|
||||
|
||||
for i in `seq 1 $NUMPARTITIONS`; do
|
||||
echo -n "/dev/sda$i " >> ${prefix}/etc/fstab
|
||||
echo -n "/dev/sda$i " >> ${TARGET}/etc/fstab
|
||||
eval part=\$PARTITION$i
|
||||
if [ ! -z "`echo $part | grep swap`" ]; then
|
||||
echo "none swap ws 0 0" >> ${prefix}/etc/fstab
|
||||
echo "none swap ws 0 0" >> ${TARGET}/etc/fstab
|
||||
else
|
||||
echo $part | awk -F: '{print $4,$3,$5,0,1}' >> ${prefix}/etc/fstab
|
||||
echo $part | awk -F: '{print $4,$3,$5,0,1}' >> ${TARGET}/etc/fstab
|
||||
fi
|
||||
done
|
||||
|
||||
# Install the kernel, grub and perl
|
||||
chroot ${prefix} yum clean expire-cache
|
||||
chroot ${prefix} yum -y install kernel-xen grub.x86_64 perl.x86_64
|
||||
chroot ${TARGET} yum clean expire-cache
|
||||
chroot ${TARGET} yum -y install kernel-xen grub.x86_64 perl.x86_64
|
||||
|
||||
KERNELVERSION=`ls ${prefix}/boot/vmlinuz-* | sed "s#$prefix/boot/vmlinuz-##"`
|
||||
KERNELVERSION=`ls ${TARGET}/boot/vmlinuz-* | sed "s#${TARGET}/boot/vmlinuz-##"`
|
||||
logMessage "Kernel $KERNELVERSION found"
|
||||
|
||||
# Create grub's menu.list
|
||||
logMessage "Creating /boot/grub/menu.lst"
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
cat > ${prefix}/boot/grub/menu.lst << EOF
|
||||
mkdir -p ${TARGET}/boot/grub
|
||||
cat > ${TARGET}/boot/grub/menu.lst << EOF
|
||||
# WARNING : Don't forget to update this when you upgrade kernel !
|
||||
# You can also exclude kernel-xen from updates by putting
|
||||
# exclude=kernel-xen in in [main] in yum.conf
|
||||
@@ -66,15 +66,15 @@ cat > ${prefix}/boot/grub/menu.lst << EOF
|
||||
default=0
|
||||
timeout=5
|
||||
title CentOS ($KERNELVERSION)
|
||||
kernel /boot/vmlinuz-$KERNELVERSION
|
||||
kernel /boot/vmlinuz-$KERNELVERSION elevator=noop
|
||||
initrd /boot/initramfs-$KERNELVERSION.img
|
||||
EOF
|
||||
|
||||
# Some use lvm but mkinitrd will generate a wrong initrd when these are present.
|
||||
rm -f ${prefix}/etc/lvm/backup/* ${prefix}/etc/lvm/archive/*
|
||||
rm -f ${TARGET}/etc/lvm/backup/* ${TARGET}/etc/lvm/archive/*
|
||||
|
||||
# Generate a correct initrd.
|
||||
chroot ${prefix} mkinitrd --with=xenblk --with=xennet --preload=xenblk --preload=xennet\
|
||||
chroot ${TARGET} mkinitrd --with=xenblk --with=xennet --preload=xenblk --preload=xennet\
|
||||
-f /boot/initramfs-$KERNELVERSION.img $KERNELVERSION
|
||||
|
||||
#
|
||||
|
||||
229
hooks/common.sh
229
hooks/common.sh
@@ -60,55 +60,192 @@ assert ()
|
||||
# We take special care so that daemons shouldn't start after installation
|
||||
# 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 ()
|
||||
{
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
shift
|
||||
|
||||
#
|
||||
# Log our options
|
||||
#
|
||||
logMessage "Installing Debian packages $@ to prefix ${prefix}"
|
||||
logMessage "Installing Debian packages $@ to target ${TARGET}"
|
||||
|
||||
#
|
||||
# We require a package + prefix
|
||||
# We require a package + target
|
||||
#
|
||||
assert "$LINENO" "${prefix}"
|
||||
assert "$LINENO" "${TARGET}"
|
||||
|
||||
#
|
||||
# Prefix must be a directory.
|
||||
# Target must be a directory.
|
||||
#
|
||||
assert "$LINENO" -d ${prefix}
|
||||
assert "$LINENO" -d ${TARGET}
|
||||
|
||||
#
|
||||
# Use policy-rc to stop any daemons from starting.
|
||||
#
|
||||
printf '#!/bin/sh\nexit 101\n' > ${prefix}/usr/sbin/policy-rc.d
|
||||
chmod +x ${prefix}/usr/sbin/policy-rc.d
|
||||
printf '#!/bin/sh\nexit 101\n' > ${TARGET}/usr/sbin/policy-rc.d
|
||||
chmod +x ${TARGET}/usr/sbin/policy-rc.d
|
||||
|
||||
#
|
||||
# Disable the start-stop-daemon - this shouldn't be necessary
|
||||
# with the policy-rc.d addition above, however leaving it in
|
||||
# place won't hurt ..
|
||||
#
|
||||
disableStartStopDaemon ${prefix}
|
||||
disableStartStopDaemon ${TARGET}
|
||||
|
||||
#
|
||||
# Install the packages
|
||||
#
|
||||
DEBIAN_FRONTEND=noninteractive chroot ${prefix} /usr/bin/apt-get --yes --force-yes install "$@"
|
||||
DEBIAN_FRONTEND=noninteractive chroot ${TARGET} /usr/bin/apt-get --yes --force-yes --no-install-recommends install "$@"
|
||||
|
||||
#
|
||||
# Remove the policy-rc.d script.
|
||||
#
|
||||
rm -f ${prefix}/usr/sbin/policy-rc.d
|
||||
rm -f ${TARGET}/usr/sbin/policy-rc.d
|
||||
|
||||
#
|
||||
# Re-enable the start-stop-daemon
|
||||
#
|
||||
enableStartStopDaemon ${prefix}
|
||||
enableStartStopDaemon ${TARGET}
|
||||
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Generate a Debian-/Ubuntu-compliant menu.lst for legacy GRUB
|
||||
#
|
||||
generateDebianGrubMenuLst ()
|
||||
{
|
||||
TARGET="$1"
|
||||
DOMU_ISSUE="$2"
|
||||
DOMU_KERNEL="$3"
|
||||
DOMU_RAMDISK="$4"
|
||||
|
||||
#
|
||||
# Log our options
|
||||
#
|
||||
logMessage "Generating a legacy GRUB menu.lst into target ${TARGET}"
|
||||
|
||||
#
|
||||
# We require at least 3 parameters
|
||||
#
|
||||
assert "$LINENO" "${TARGET}"
|
||||
assert "$LINENO" "${DOMU_ISSUE}"
|
||||
assert "$LINENO" "${DOMU_KERNEL}"
|
||||
|
||||
#
|
||||
# Target must be a directory, kernel a file
|
||||
#
|
||||
assert "$LINENO" -d ${TARGET}
|
||||
assert "$LINENO" -f "${TARGET}/boot/${DOMU_KERNEL}"
|
||||
|
||||
#
|
||||
# Generate a menu.lst for pygrub
|
||||
#
|
||||
|
||||
mkdir -p ${TARGET}/boot/grub
|
||||
cat << E_O_MENU > ${TARGET}/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
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -119,10 +256,10 @@ installDebianPackage ()
|
||||
#
|
||||
disableStartStopDaemon ()
|
||||
{
|
||||
local prefix="$1"
|
||||
assert "$LINENO" "${prefix}"
|
||||
local TARGET="$1"
|
||||
assert "$LINENO" "${TARGET}"
|
||||
for starter in start-stop-daemon initctl; do
|
||||
local daemonfile="${prefix}/sbin/${starter}"
|
||||
local daemonfile="${TARGET}/sbin/${starter}"
|
||||
|
||||
mv "${daemonfile}" "${daemonfile}.REAL"
|
||||
echo '#!/bin/sh' > "${daemonfile}"
|
||||
@@ -140,10 +277,10 @@ disableStartStopDaemon ()
|
||||
#
|
||||
enableStartStopDaemon ()
|
||||
{
|
||||
local prefix=$1
|
||||
assert "$LINENO" "${prefix}"
|
||||
local TARGET=$1
|
||||
assert "$LINENO" "${TARGET}"
|
||||
for starter in start-stop-daemon initctl; do
|
||||
local daemonfile="${prefix}/sbin/${starter}"
|
||||
local daemonfile="${TARGET}/sbin/${starter}"
|
||||
|
||||
#
|
||||
# If the disabled file is present then enable it.
|
||||
@@ -164,62 +301,71 @@ enableStartStopDaemon ()
|
||||
#
|
||||
removeDebianPackage ()
|
||||
{
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
shift
|
||||
|
||||
#
|
||||
# Log our options
|
||||
#
|
||||
logMessage "Purging Debian package ${package} from prefix ${prefix}"
|
||||
logMessage "Purging Debian package ${package} from target ${TARGET}"
|
||||
|
||||
#
|
||||
# We require a prefix
|
||||
# We require a target
|
||||
#
|
||||
assert "$LINENO" "${prefix}"
|
||||
assert "$LINENO" "${TARGET}"
|
||||
|
||||
#
|
||||
# Prefix must be a directory.
|
||||
# Target must be a directory.
|
||||
#
|
||||
assert "$LINENO" -d ${prefix}
|
||||
assert "$LINENO" -d ${TARGET}
|
||||
|
||||
#
|
||||
# Purge the packages we've been given.
|
||||
#
|
||||
chroot ${prefix} /usr/bin/apt-get remove --yes --purge "$@"
|
||||
chroot ${TARGET} /usr/bin/apt-get remove --yes --purge "$@"
|
||||
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Install a CentOS4 package via yum
|
||||
# Install a RPM package via yum
|
||||
#
|
||||
installCentOS4Package ()
|
||||
installRPMPackage ()
|
||||
{
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
package=$2
|
||||
|
||||
#
|
||||
# Log our options
|
||||
#
|
||||
logMessage "Installing CentOS4 ${package} to prefix ${prefix}"
|
||||
logMessage "Installing RPM ${package} to target ${TARGET}"
|
||||
|
||||
#
|
||||
# We require a package + prefix
|
||||
# We require a package + target
|
||||
#
|
||||
assert "$LINENO" "${package}"
|
||||
assert "$LINENO" "${prefix}"
|
||||
assert "$LINENO" "${TARGET}"
|
||||
|
||||
#
|
||||
# Prefix must be a directory.
|
||||
# Target must be a directory.
|
||||
#
|
||||
assert "$LINENO" -d ${prefix}
|
||||
assert "$LINENO" -d ${TARGET}
|
||||
|
||||
#
|
||||
# Install the package
|
||||
#
|
||||
chroot ${prefix} /usr/bin/yum -y install ${package}
|
||||
chroot ${TARGET} /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 ] )
|
||||
|
||||
|
||||
#
|
||||
@@ -227,14 +373,14 @@ installCentOS4Package ()
|
||||
#
|
||||
installPackage ()
|
||||
{
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
package=$2
|
||||
|
||||
if [ -x ${prefix}/usr/bin/apt-get ] ; then
|
||||
if isDeb ; then
|
||||
installDebianPackage "$@"
|
||||
|
||||
elif [ -x ${prefix}/usr/bin/yum ] ; then
|
||||
installCentOS4Package "$@"
|
||||
elif isYum ; then
|
||||
installRPMPackage "$@"
|
||||
|
||||
else
|
||||
logMessage "Unable to install package ${package}; no package manager found"
|
||||
@@ -250,15 +396,14 @@ installPackage ()
|
||||
#
|
||||
installGentooPackage ()
|
||||
{
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
package=$2
|
||||
|
||||
#
|
||||
# Log our options
|
||||
#
|
||||
logMessage "Installing Gentoo package ${package} to prefix ${prefix}"
|
||||
logMessage "Installing Gentoo package ${package} to target ${TARGET}"
|
||||
|
||||
logMessage "NOTE: Not doing anything - this is a stub - FIXME"
|
||||
|
||||
}
|
||||
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -30,20 +30,20 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Make sure we have a directory.
|
||||
#
|
||||
if [ ! -d "${prefix}/usr/sbin" ]; then
|
||||
if [ ! -d "${TARGET}/usr/sbin" ]; then
|
||||
|
||||
mkdir -p "${prefix}/usr/sbin"
|
||||
mkdir -p "${TARGET}/usr/sbin"
|
||||
|
||||
logMessage "created missing directory: ${prefix}/usr/sbin"
|
||||
logMessage "created missing directory: ${TARGET}/usr/sbin"
|
||||
fi
|
||||
|
||||
|
||||
#
|
||||
# Add the script.
|
||||
#
|
||||
echo '#!/bin/sh' > ${prefix}/usr/sbin/policy-rc.d
|
||||
echo 'exit 101' >> ${prefix}/usr/sbin/policy-rc.d
|
||||
chmod 755 ${prefix}/usr/sbin/policy-rc.d
|
||||
echo '#!/bin/sh' > ${TARGET}/usr/sbin/policy-rc.d
|
||||
echo 'exit 101' >> ${TARGET}/usr/sbin/policy-rc.d
|
||||
chmod 755 ${TARGET}/usr/sbin/policy-rc.d
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,9 +29,9 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Enable the shadow passwords if the command is found.
|
||||
#
|
||||
if [ -x ${prefix}/sbin/shadowconfig ]; then
|
||||
if [ -x ${TARGET}/sbin/shadowconfig ]; then
|
||||
|
||||
chroot ${prefix} /sbin/shadowconfig on
|
||||
chroot ${TARGET} /sbin/shadowconfig on
|
||||
else
|
||||
|
||||
logMessage "/sbin/shadowconfig not found. skipping."
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -37,8 +37,8 @@ if [ "`uname -m`" = "x86_64" ]; then
|
||||
else
|
||||
|
||||
logMessage "Disabling TLS"
|
||||
mv ${prefix}/lib/tls ${prefix}/lib/tls.disabled
|
||||
mkdir ${prefix}/lib/tls
|
||||
mv ${TARGET}/lib/tls ${TARGET}/lib/tls.disabled
|
||||
mkdir ${TARGET}/lib/tls
|
||||
fi
|
||||
|
||||
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,7 +29,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Disable the startup scripts from all runlevels.
|
||||
#
|
||||
chroot ${prefix} /usr/sbin/update-rc.d -f hwclock.sh remove
|
||||
chroot ${TARGET} /usr/sbin/update-rc.d -f hwclock.sh remove
|
||||
|
||||
#
|
||||
# Log our finish
|
||||
|
||||
@@ -6,8 +6,8 @@ prefix=$1
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
#
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -33,17 +33,17 @@ logMessage Script $0 starting
|
||||
# the setting to the proxy guess file.
|
||||
#
|
||||
if [ ${apt_proxy} ]; then
|
||||
echo "Acquire::http::Proxy \"${apt_proxy}\";" > ${prefix}/etc/apt/apt.conf.d/01proxy
|
||||
echo "Acquire::http::Proxy \"${apt_proxy}\";" > ${TARGET}/etc/apt/apt.conf.d/01proxy
|
||||
else
|
||||
logMessage The use of a proxy detected.
|
||||
apt-config dump | grep -i Acquire::HTTP::Proxy > ${prefix}/etc/apt/apt.conf.d/01proxy
|
||||
apt-config dump | grep -i Acquire::HTTP::Proxy > ${TARGET}/etc/apt/apt.conf.d/01proxy
|
||||
fi
|
||||
|
||||
|
||||
#
|
||||
# Setup the sources.list file for new installations of Ubuntu GNU/Linux.
|
||||
#
|
||||
cat <<E_O_APT > ${prefix}/etc/apt/sources.list
|
||||
cat <<E_O_APT > ${TARGET}/etc/apt/sources.list
|
||||
#
|
||||
# /etc/apt/sources.list
|
||||
#
|
||||
@@ -66,22 +66,18 @@ E_O_APT
|
||||
#
|
||||
# Now that the sources have been setup make sure the system is up to date.
|
||||
#
|
||||
chroot ${prefix} /usr/bin/apt-get update
|
||||
chroot ${TARGET} /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 [ "`uname -m`" = "x86_64" ]; then
|
||||
if [ "$arch" = 'i386' -a "$dist" != 'dapper' ]; then
|
||||
|
||||
logMessage "Ignoring TLS since we're a 64 bit host."
|
||||
logMessage "Installing libc6-xen"
|
||||
installDebianPackage ${TARGET} libc6-xen
|
||||
|
||||
else
|
||||
|
||||
logMessage "Installing libc6-xen"
|
||||
installDebianPackage ${prefix} libc6-xen
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,12 +29,12 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Update yum
|
||||
#
|
||||
if [ ! -d ${prefix}/proc ]; then
|
||||
mkdir -p ${prefix}/proc
|
||||
if [ ! -d ${TARGET}/proc ]; then
|
||||
mkdir -p ${TARGET}/proc
|
||||
fi
|
||||
mount -o bind /proc ${prefix}/proc
|
||||
chroot ${prefix} /usr/bin/yum update
|
||||
umount ${prefix}/proc
|
||||
mount -o bind /proc ${TARGET}/proc
|
||||
chroot ${TARGET} /usr/bin/yum update
|
||||
umount ${TARGET}/proc
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -31,7 +31,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# NOTE: Failure to support your favourite language is *not* a bug.
|
||||
#
|
||||
installDebianPackage ${prefix} language-pack-en
|
||||
installDebianPackage ${TARGET} language-pack-en
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -6,14 +6,14 @@
|
||||
#
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -30,20 +30,20 @@ logMessage Script $0 starting
|
||||
#
|
||||
|
||||
# Upstart on Ubuntu newer than 8.04
|
||||
rm -f ${prefix}/etc/init/tty[!1].conf
|
||||
[ -f ${prefix}/etc/init/tty1.conf ] && {
|
||||
sed -i -e s/tty1/hvc0/ ${prefix}/etc/init/tty1.conf
|
||||
mv ${prefix}/etc/init/tty1.conf ${prefix}/etc/init/hvc0.conf
|
||||
rm -f ${TARGET}/etc/init/tty[!1].conf
|
||||
[ -f ${TARGET}/etc/init/tty1.conf ] && {
|
||||
sed -i -e s/tty1/hvc0/ ${TARGET}/etc/init/tty1.conf
|
||||
mv ${TARGET}/etc/init/tty1.conf ${TARGET}/etc/init/hvc0.conf
|
||||
}
|
||||
# Upstart on Ubuntu 8.04 or older
|
||||
rm -f ${prefix}/etc/event.d/tty[!1]
|
||||
[ -f ${prefix}/etc/event.d/tty1 ] && {
|
||||
sed -i -e s/tty1/hvc0/ ${prefix}/etc/event.d/tty1
|
||||
mv ${prefix}/etc/event.d/tty1 ${prefix}/etc/event.d/hvc0
|
||||
rm -f ${TARGET}/etc/event.d/tty[!1]
|
||||
[ -f ${TARGET}/etc/event.d/tty1 ] && {
|
||||
sed -i -e s/tty1/hvc0/ ${TARGET}/etc/event.d/tty1
|
||||
mv ${TARGET}/etc/event.d/tty1 ${TARGET}/etc/event.d/hvc0
|
||||
}
|
||||
|
||||
# Inittab
|
||||
[ -f ${prefix}/etc/inittab ] && sed -i -e 's/^\([2-6].*:respawn*\)/#\1/' -e 's/^T/#\t/' -e 's/tty1$/hvc0/' ${prefix}/etc/inittab
|
||||
[ -f ${TARGET}/etc/inittab ] && sed -i -e 's/^\([2-6].*:respawn*\)/#\1/' -e 's/^T/#\t/' -e 's/tty1$/hvc0/' ${TARGET}/etc/inittab
|
||||
|
||||
|
||||
#
|
||||
@@ -59,21 +59,21 @@ if [ ! -z "${serial_device}" ]; then
|
||||
# replace existing device.
|
||||
|
||||
# Upstart on Ubuntu newer than 8.04
|
||||
[ -f ${prefix}/etc/init/hvc0.conf ] && {
|
||||
mv ${prefix}/etc/init/hvc0.conf ${prefix}/etc/init/${serial_device}.conf
|
||||
sed -i -e s/hvc0/${serial_device}/ ${prefix}/etc/init/${serial_device}.conf
|
||||
[ -f ${TARGET}/etc/init/hvc0.conf ] && {
|
||||
mv ${TARGET}/etc/init/hvc0.conf ${TARGET}/etc/init/${serial_device}.conf
|
||||
sed -i -e s/hvc0/${serial_device}/ ${TARGET}/etc/init/${serial_device}.conf
|
||||
}
|
||||
# Upstart on Ubuntu 8.04 or older
|
||||
[ -f ${prefix}/etc/event.d/hvc0 ] && {
|
||||
mv ${prefix}/etc/event.d/hvc0 ${prefix}/etc/event.d/${serial_device}
|
||||
sed -i -e s/hvc0/${serial_device}/ ${prefix}/etc/event.d/${serial_device}
|
||||
[ -f ${TARGET}/etc/event.d/hvc0 ] && {
|
||||
mv ${TARGET}/etc/event.d/hvc0 ${TARGET}/etc/event.d/${serial_device}
|
||||
sed -i -e s/hvc0/${serial_device}/ ${TARGET}/etc/event.d/${serial_device}
|
||||
}
|
||||
|
||||
# Inittab
|
||||
[ -f ${prefix}/etc/inittab ] && sed -i -e s/hvc0/${serial_device}/ ${prefix}/etc/inittab
|
||||
[ -f ${TARGET}/etc/inittab ] && sed -i -e s/hvc0/${serial_device}/ ${TARGET}/etc/inittab
|
||||
|
||||
# make sure that it is allowed to login.
|
||||
echo $serial_device >> ${prefix}/etc/securetty
|
||||
echo $serial_device >> ${TARGET}/etc/securetty
|
||||
fi
|
||||
|
||||
|
||||
|
||||
@@ -8,13 +8,13 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,7 +29,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Make sure we have an /etc/network directory.
|
||||
#
|
||||
mkdir -p ${prefix}/etc/network
|
||||
mkdir -p ${TARGET}/etc/network
|
||||
|
||||
|
||||
#
|
||||
@@ -40,7 +40,7 @@ setupDynamicNetworking ()
|
||||
#
|
||||
# The host is using DHCP.
|
||||
#
|
||||
cat <<E_O_DHCP > ${prefix}/etc/network/interfaces
|
||||
cat <<E_O_DHCP > ${TARGET}/etc/network/interfaces
|
||||
# This file describes the network interfaces available on your system
|
||||
# and how to activate them. For more information, see interfaces(5).
|
||||
|
||||
@@ -88,7 +88,7 @@ setupStaticNetworking ()
|
||||
#
|
||||
# We have a static IP address
|
||||
#
|
||||
cat <<E_O_STATIC >${prefix}/etc/network/interfaces
|
||||
cat <<E_O_STATIC >${TARGET}/etc/network/interfaces
|
||||
# This file describes the network interfaces available on your system
|
||||
# and how to activate them. For more information, see interfaces(5).
|
||||
|
||||
@@ -122,7 +122,7 @@ E_O_STATIC
|
||||
|
||||
logMessage Adding etho:${interface}
|
||||
|
||||
cat <<E_O_STATIC >>${prefix}/etc/network/interfaces
|
||||
cat <<E_O_STATIC >>${TARGET}/etc/network/interfaces
|
||||
auto eth0:${interface}
|
||||
iface eth0:${interface} inet static
|
||||
address ${value}
|
||||
@@ -139,12 +139,12 @@ E_O_STATIC
|
||||
# will be restored after hooks are run.
|
||||
#
|
||||
if [ '' != "$nameserver" ]; then
|
||||
rm -f ${prefix}/etc/resolv.conf.old
|
||||
rm -f ${TARGET}/etc/resolv.conf.old
|
||||
for ns in $nameserver; do
|
||||
echo "nameserver $ns" >>${prefix}/etc/resolv.conf.old
|
||||
echo "nameserver $ns" >>${TARGET}/etc/resolv.conf.old
|
||||
done
|
||||
else
|
||||
cp /etc/resolv.conf ${prefix}/etc/resolv.conf.old
|
||||
cp /etc/resolv.conf ${TARGET}/etc/resolv.conf.old
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,7 +29,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Make sure we have an /etc/sysconfig/network-scripts directory.
|
||||
#
|
||||
mkdir -p ${prefix}/etc/sysconfig/network-scripts/
|
||||
mkdir -p ${TARGET}/etc/sysconfig/network-scripts/
|
||||
|
||||
|
||||
#
|
||||
@@ -40,7 +40,7 @@ if [ -z "${dhcp}" ]; then
|
||||
#
|
||||
# Setup the initial interface
|
||||
#
|
||||
cat <<E_O_STATIC >${prefix}/etc/sysconfig/network-scripts/ifcfg-eth0
|
||||
cat <<E_O_STATIC >${TARGET}/etc/sysconfig/network-scripts/ifcfg-eth0
|
||||
DEVICE=eth0
|
||||
ONBOOT=yes
|
||||
BOOTPROTO=static
|
||||
@@ -62,7 +62,7 @@ E_O_STATIC
|
||||
|
||||
logMessage Adding etho:${interface}
|
||||
|
||||
cat <<E_O_STATIC >${prefix}/etc/sysconfig/network-scripts/ifcfg-eth0:${interface}
|
||||
cat <<E_O_STATIC >${TARGET}/etc/sysconfig/network-scripts/ifcfg-eth0:${interface}
|
||||
DEVICE=eth0:${interface}
|
||||
ONBOOT=yes
|
||||
BOOTPROTO=static
|
||||
@@ -79,27 +79,27 @@ E_O_STATIC
|
||||
# will be restored after hooks are run.
|
||||
#
|
||||
if [ '' != "$nameserver" ]; then
|
||||
rm -f ${prefix}/etc/resolv.conf.old
|
||||
rm -f ${TARGET}/etc/resolv.conf.old
|
||||
for ns in $nameserver; do
|
||||
echo "nameserver $ns" >>${prefix}/etc/resolv.conf.old
|
||||
echo "nameserver $ns" >>${TARGET}/etc/resolv.conf.old
|
||||
done
|
||||
else
|
||||
cp /etc/resolv.conf ${prefix}/etc/resolv.conf.old
|
||||
cp /etc/resolv.conf ${TARGET}/etc/resolv.conf.old
|
||||
fi
|
||||
else
|
||||
cat <<E_O_DHCP >${prefix}/etc/sysconfig/network-scripts/ifcfg-eth0
|
||||
cat <<E_O_DHCP >${TARGET}/etc/sysconfig/network-scripts/ifcfg-eth0
|
||||
DEVICE=eth0
|
||||
BOOTPROTO=dhcp
|
||||
ONBOOT=yes
|
||||
E_O_DHCP
|
||||
chroot ${prefix} /usr/bin/yum -y install dhclient
|
||||
chroot ${TARGET} /usr/bin/yum -y install dhclient
|
||||
fi
|
||||
|
||||
|
||||
#
|
||||
# Don't forget to setup the default route.
|
||||
#
|
||||
cat <<EOF >${prefix}/etc/sysconfig/network
|
||||
cat <<EOF >${TARGET}/etc/sysconfig/network
|
||||
NETWORKING=yes
|
||||
GATEWAY=${gateway}
|
||||
HOSTNAME=${hostname}
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -43,8 +43,8 @@ umask 022
|
||||
#
|
||||
# Setup the mailname + hostname files.
|
||||
#
|
||||
echo $GUEST_HOSTNAME > ${prefix}/etc/hostname
|
||||
echo $GUEST_FQDN > ${prefix}/etc/mailname
|
||||
echo $GUEST_HOSTNAME > ${TARGET}/etc/hostname
|
||||
echo $GUEST_FQDN > ${TARGET}/etc/mailname
|
||||
|
||||
|
||||
#
|
||||
@@ -55,7 +55,7 @@ if [ -z "${copyhosts}" ]; then
|
||||
#
|
||||
# Copy localhost
|
||||
#
|
||||
cat > ${prefix}/etc/hosts <<EOF
|
||||
cat > ${TARGET}/etc/hosts <<EOF
|
||||
127.0.0.1 localhost
|
||||
EOF
|
||||
#
|
||||
@@ -65,21 +65,21 @@ EOF
|
||||
#
|
||||
# If dhcp is diabled, FQDN should resolve to our IP
|
||||
#
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
${ip1} $GUEST_FQDN $GUEST_HOSTNAME
|
||||
EOF
|
||||
else
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
127.0.1.1 $GUEST_FQDN $GUEST_HOSTNAME
|
||||
EOF
|
||||
fi
|
||||
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
|
||||
# The following lines are desirable for IPv6 capable hosts
|
||||
::1 ip6-localhost ip6-loopback
|
||||
fe00::0 ip6-localnet
|
||||
ff00::0 ip6-mcastprefix
|
||||
ff00::0 ip6-mcastTARGET
|
||||
ff02::1 ip6-allnodes
|
||||
ff02::2 ip6-allrouters
|
||||
ff02::3 ip6-allhosts
|
||||
@@ -88,23 +88,23 @@ EOF
|
||||
|
||||
else
|
||||
# Non-IPv6 stuff.
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${prefix}/etc/hosts
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${TARGET}/etc/hosts
|
||||
|
||||
# New entry.
|
||||
if [ -z "${dhcp}" ]; then
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
${ip1} $GUEST_FQDN $GUEST_HOSTNAME
|
||||
|
||||
EOF
|
||||
else
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
127.0.1.1 $GUEST_FQDN $GUEST_HOSTNAME
|
||||
|
||||
EOF
|
||||
fi
|
||||
|
||||
# IPv6 stuff.
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${prefix}/etc/hosts
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${TARGET}/etc/hosts
|
||||
fi
|
||||
|
||||
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -37,8 +37,8 @@ umask 022
|
||||
#
|
||||
# Setup the mailname + hostname files.
|
||||
#
|
||||
echo ${hostname} | sed 's/^\([^\.]*\)\..*/\1/' > ${prefix}/etc/hostname
|
||||
echo ${hostname} > ${prefix}/etc/mailname
|
||||
echo ${hostname} | sed 's/^\([^\.]*\)\..*/\1/' > ${TARGET}/etc/hostname
|
||||
echo ${hostname} > ${TARGET}/etc/mailname
|
||||
|
||||
|
||||
#
|
||||
@@ -48,21 +48,21 @@ echo ${hostname} > ${prefix}/etc/mailname
|
||||
if [ -z "${dhcp}" ]; then
|
||||
|
||||
# Non-IPv6 stuff.
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${prefix}/etc/hosts
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${TARGET}/etc/hosts
|
||||
|
||||
# New entry.
|
||||
echo "${ip1} ${hostname}" >> ${prefix}/etc/hosts
|
||||
echo " " >> ${prefix}/etc/hosts
|
||||
echo "${ip1} ${hostname}" >> ${TARGET}/etc/hosts
|
||||
echo " " >> ${TARGET}/etc/hosts
|
||||
|
||||
# IPv6 stuff.
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${prefix}/etc/hosts
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${TARGET}/etc/hosts
|
||||
|
||||
else
|
||||
|
||||
#
|
||||
# Stub /etc/hosts for DHCP clients.
|
||||
#
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
127.0.0.1 localhost
|
||||
|
||||
# The following lines are desirable for IPv6 capable hosts
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -32,8 +32,8 @@ logMessage Script $0 starting
|
||||
MAKEDEV=''
|
||||
MAKEDEV_PATHS="/sbin/MAKEDEV /dev/MAKEDEV"
|
||||
for MAKEDEV_PATH in ${MAKEDEV_PATHS}; do
|
||||
if [ -x "${prefix}${MAKEDEV_PATH}" ]; then
|
||||
MAKEDEV="${prefix}${MAKEDEV_PATH}"
|
||||
if [ -x "${TARGET}${MAKEDEV_PATH}" ]; then
|
||||
MAKEDEV="${TARGET}${MAKEDEV_PATH}"
|
||||
break
|
||||
fi
|
||||
done
|
||||
@@ -44,11 +44,11 @@ if [ -n "${MAKEDEV}" ]; then
|
||||
# Early termination if we have a couple of common devices present
|
||||
# should speed up installs which use --copy/--tar
|
||||
#
|
||||
if ( test `ls -1 ${prefix}/dev | wc -l` -gt 10 ); then
|
||||
if ( test `ls -1 ${TARGET}/dev | wc -l` -gt 10 ); then
|
||||
#
|
||||
# We still need to make sure the basic devices are present
|
||||
#
|
||||
cd ${prefix}/dev
|
||||
cd ${TARGET}/dev
|
||||
${MAKEDEV} std
|
||||
${MAKEDEV} hda
|
||||
${MAKEDEV} sda
|
||||
@@ -62,7 +62,7 @@ fi
|
||||
#
|
||||
# Make the device nodes.
|
||||
#
|
||||
cd ${prefix}/dev
|
||||
cd ${TARGET}/dev
|
||||
${MAKEDEV} generic
|
||||
${MAKEDEV} std
|
||||
|
||||
|
||||
@@ -5,14 +5,14 @@
|
||||
#
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -27,8 +27,8 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Copy "required" files from our host.
|
||||
#
|
||||
cp /etc/timezone ${prefix}/etc
|
||||
cp /etc/localtime ${prefix}/etc
|
||||
cp /etc/timezone ${TARGET}/etc
|
||||
cp /etc/localtime ${TARGET}/etc
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -5,14 +5,14 @@
|
||||
#
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -32,7 +32,7 @@ if [ -d /etc/xen-tools/skel ]; then
|
||||
|
||||
logMessage Copying files from /etc/xen-tools/skel
|
||||
|
||||
(cd /etc/xen-tools/skel; tar -cf - . ) | (cd ${prefix}/; tar -xpf -)
|
||||
(cd /etc/xen-tools/skel; tar -cf - . ) | (cd ${TARGET}/; tar -xpf -)
|
||||
|
||||
logMessage Finished
|
||||
|
||||
|
||||
@@ -10,13 +10,13 @@
|
||||
# --
|
||||
# http://nedos.net/
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -31,34 +31,34 @@ logMessage Script $0 starting
|
||||
#
|
||||
# First, create an ssh directory
|
||||
#
|
||||
mkdir -p ${prefix}/etc/ssh
|
||||
mkdir -p ${TARGET}/etc/ssh
|
||||
|
||||
#
|
||||
# Second, Generate the Host RSA Key
|
||||
#
|
||||
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
|
||||
logMessage "successfully generetaged Host RSA"
|
||||
if [ ! -f ${TARGET}/etc/ssh/ssh_host_rsa_key ]; then
|
||||
if ssh-keygen -t rsa -N "" -f ${TARGET}/etc/ssh/ssh_host_rsa_key -C "root@${hostname}"; then
|
||||
logMessage "successfully generated RSA host key"
|
||||
else
|
||||
logMessage "failed to generate Host RSA Key"
|
||||
logMessage "failed to generate RSA host key"
|
||||
fi
|
||||
fi
|
||||
|
||||
#
|
||||
# Third, Generate the Host DSA Key
|
||||
#
|
||||
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
|
||||
logMessage "successfully generetaged Host DSA"
|
||||
if [ ! -f ${TARGET}/etc/ssh/ssh_host_dsa_key ]; then
|
||||
if ssh-keygen -t dsa -N "" -f ${TARGET}/etc/ssh/ssh_host_dsa_key -C "root@${hostname}"; then
|
||||
logMessage "successfully generated DSA host key"
|
||||
else
|
||||
logMessage "failed to generate Host DSA Key"
|
||||
logMessage "failed to generate DSA host key"
|
||||
fi
|
||||
fi
|
||||
|
||||
#
|
||||
# Install ssh
|
||||
#
|
||||
installDebianPackage ${prefix} openssh-server
|
||||
installDebianPackage ${TARGET} openssh-server
|
||||
|
||||
#
|
||||
# Log our finish
|
||||
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -28,12 +28,12 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Install the OpenSSH server.
|
||||
#
|
||||
if [ ! -d ${prefix}/proc ]; then
|
||||
mkdir -p ${prefix}/proc
|
||||
if [ ! -d ${TARGET}/proc ]; then
|
||||
mkdir -p ${TARGET}/proc
|
||||
fi
|
||||
mount -o bind /proc ${prefix}/proc
|
||||
chroot ${prefix} /usr/bin/yum -y install openssh-server passwd
|
||||
umount ${prefix}/proc
|
||||
mount -o bind /proc ${TARGET}/proc
|
||||
chroot ${TARGET} /usr/bin/yum -y install openssh-server passwd
|
||||
umount ${TARGET}/proc
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,7 +29,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# If the file doesn't exist exit early.
|
||||
#
|
||||
if [ ! -e ${prefix}/etc/securetty ]; then
|
||||
if [ ! -e ${TARGET}/etc/securetty ]; then
|
||||
logMessage /etc/securetty not found.
|
||||
exit
|
||||
fi
|
||||
@@ -43,13 +43,13 @@ for i in xvc0 hvc0 ; do
|
||||
#
|
||||
# Only append if not presnt.
|
||||
#
|
||||
if ( grep $i ${prefix}/etc/securetty > /dev/null ) ; then
|
||||
if ( grep $i ${TARGET}/etc/securetty > /dev/null ) ; then
|
||||
|
||||
logMessage Host already has $i entry
|
||||
|
||||
else
|
||||
|
||||
echo $i >> ${prefix}/etc/securetty
|
||||
echo $i >> ${TARGET}/etc/securetty
|
||||
fi
|
||||
|
||||
done
|
||||
|
||||
@@ -12,15 +12,15 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -50,16 +50,16 @@ if [ -n "${modules}" -a -d "${modules}" ]; then
|
||||
#
|
||||
logMessage "Copying modules from ${modules}"
|
||||
|
||||
mkdir -p ${prefix}/lib/modules
|
||||
cp -au ${modules} ${prefix}/lib/modules
|
||||
elif chroot ${prefix} /usr/bin/apt-cache show ${linux_modules_package} >/dev/null 2>/dev/null; then
|
||||
mkdir -p ${TARGET}/lib/modules
|
||||
cp -au ${modules} ${TARGET}/lib/modules
|
||||
elif chroot ${TARGET} /usr/bin/apt-cache show ${linux_modules_package} >/dev/null 2>/dev/null; then
|
||||
|
||||
logMessage "Package '${linux_modules_package}' is available - installing"
|
||||
|
||||
#
|
||||
# If it worked then we can install the package.
|
||||
#
|
||||
installDebianPackage ${prefix} ${linux_modules_package}
|
||||
installDebianPackage ${TARGET} ${linux_modules_package}
|
||||
else
|
||||
|
||||
#
|
||||
@@ -69,15 +69,10 @@ else
|
||||
logMessage "Package '${linux_modules_package}' is not available"
|
||||
logMessage "Copying modules from /lib/modules/$(uname -r)"
|
||||
|
||||
mkdir -p ${prefix}/lib/modules
|
||||
cp -au /lib/modules/$(uname -r) ${prefix}/lib/modules
|
||||
mkdir -p ${TARGET}/lib/modules
|
||||
cp -au /lib/modules/$(uname -r) ${TARGET}/lib/modules
|
||||
fi
|
||||
|
||||
#
|
||||
# Install the module-init-tools package.
|
||||
#
|
||||
installDebianPackage ${prefix} module-init-tools
|
||||
|
||||
fi # if pygrub
|
||||
|
||||
#
|
||||
|
||||
@@ -12,15 +12,15 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -36,8 +36,8 @@ logMessage Script $0 starting
|
||||
# Copy the modules from the host to the new system - we should only
|
||||
# really copy the *correct* modules, but we don't know what they are.
|
||||
#
|
||||
mkdir -p ${prefix}/lib/modules
|
||||
cp -au /lib/modules/*/ ${prefix}/lib/modules
|
||||
mkdir -p ${TARGET}/lib/modules
|
||||
cp -au /lib/modules/*/ ${TARGET}/lib/modules
|
||||
|
||||
|
||||
#
|
||||
|
||||
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.
|
||||
#
|
||||
|
||||
TARGET=$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 ${TARGET} /usr/bin/apt-cache show module-init-tools >/dev/null 2>/dev/null; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show module-init-tools | fgrep -qi transitional; then
|
||||
installDebianPackage ${TARGET} kmod
|
||||
else
|
||||
installDebianPackage ${TARGET} module-init-tools
|
||||
fi
|
||||
else
|
||||
installDebianPackage ${TARGET} 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.
|
||||
|
||||
|
||||
TARGET=$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 ${TARGET} /usr/bin/apt-cache show grub-legacy 2>/dev/null | egrep -qi 'GRand Unified Bootloader.*Legacy'; then
|
||||
installDebianPackage ${TARGET} grub-legacy
|
||||
else
|
||||
installDebianPackage ${TARGET} grub
|
||||
fi
|
||||
|
||||
if [ ! -e ${TARGET}/boot/grub/default ]; then
|
||||
echo default > ${TARGET}/boot/grub/default
|
||||
fi
|
||||
chroot ${TARGET} /usr/sbin/update-grub
|
||||
|
||||
else
|
||||
logMessage "pygrub not set, skipping grub-legacy installation"
|
||||
fi # if pygrub
|
||||
|
||||
#
|
||||
# Log our finish
|
||||
#
|
||||
logMessage Script $0 finished
|
||||
@@ -12,13 +12,13 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -62,7 +62,7 @@ logMessage "Root device is /dev/$device"
|
||||
has_xfs=0
|
||||
has_reiserfs=0
|
||||
has_btrfs=0
|
||||
cat <<E_O_FSTAB > ${prefix}/etc/fstab
|
||||
cat <<E_O_FSTAB > ${TARGET}/etc/fstab
|
||||
# /etc/fstab: static file system information.
|
||||
#
|
||||
# <file system> <mount point> <type> <options> <dump> <pass>
|
||||
@@ -93,13 +93,41 @@ for part in `seq 1 ${NUMPARTITIONS}`; do
|
||||
esac
|
||||
|
||||
if [ "${partdata2}" = "swap" ]; then
|
||||
echo "/dev/${device}${part} none swap sw 0 0" >> ${prefix}/etc/fstab
|
||||
echo "/dev/${device}${part} none swap sw 0 0" >> ${TARGET}/etc/fstab
|
||||
else
|
||||
echo "/dev/${device}${part} ${partdata3} ${partdata2} ${partdata4} 0 1" >> ${prefix}/etc/fstab
|
||||
echo "/dev/${device}${part} ${partdata3} ${partdata2} ${partdata4} 0 1" >> ${TARGET}/etc/fstab
|
||||
fi
|
||||
done
|
||||
|
||||
|
||||
logMessage Checking for filesystem tools to install
|
||||
|
||||
#
|
||||
# Install any required packages for the given root filesystem
|
||||
#
|
||||
if [ "$has_xfs" -eq 1 ]; then
|
||||
installPackage ${TARGET} 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
|
||||
#
|
||||
|
||||
@@ -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
|
||||
@@ -7,14 +7,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,7 +29,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Clean the APT package cache for Debian GNU/Linux.
|
||||
#
|
||||
chroot ${prefix} /usr/bin/apt-get clean
|
||||
chroot ${TARGET} /usr/bin/apt-get clean
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -7,13 +7,13 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,20 +29,20 @@ logMessage Script $0 starting
|
||||
# Clean up RPM files.
|
||||
#
|
||||
logMessage Cleaning .rpm* files.
|
||||
find ${prefix}/ -name '*.rpmorig' -exec rm -f \{\} \;
|
||||
find ${prefix}/ -name '*.rpmnew' -exec rm -f \{\} \;
|
||||
find ${TARGET}/ -name '*.rpmorig' -exec rm -f \{\} \;
|
||||
find ${TARGET}/ -name '*.rpmnew' -exec rm -f \{\} \;
|
||||
|
||||
#
|
||||
# Clean yum
|
||||
#
|
||||
logMessage Cleaning Yum Repository
|
||||
|
||||
if [ ! -d ${prefix}/proc ]; then
|
||||
mkdir -p ${prefix}/proc
|
||||
if [ ! -d ${TARGET}/proc ]; then
|
||||
mkdir -p ${TARGET}/proc
|
||||
fi
|
||||
mount -o bind /proc ${prefix}/proc
|
||||
chroot ${prefix} /usr/bin/yum clean all
|
||||
umount ${prefix}/proc
|
||||
mount -o bind /proc ${TARGET}/proc
|
||||
chroot ${TARGET} /usr/bin/yum clean all
|
||||
umount ${TARGET}/proc
|
||||
|
||||
#
|
||||
# Log our finish
|
||||
|
||||
@@ -8,14 +8,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -30,11 +30,11 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Remove the script if present.
|
||||
#
|
||||
if [ -x "${prefix}/usr/sbin/policy-rc.d" ]; then
|
||||
if [ -x "${TARGET}/usr/sbin/policy-rc.d" ]; then
|
||||
|
||||
rm -f "${prefix}/usr/sbin/policy-rc.d"
|
||||
rm -f "${TARGET}/usr/sbin/policy-rc.d"
|
||||
|
||||
logMessage "Removed: ${prefix}/usr/sbin/policy-rc.d"
|
||||
logMessage "Removed: ${TARGET}/usr/sbin/policy-rc.d"
|
||||
|
||||
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
|
||||
@@ -8,14 +8,14 @@
|
||||
#
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -33,17 +33,17 @@ logMessage Script $0 starting
|
||||
# the setting to the proxy guess file.
|
||||
#
|
||||
if [ ${apt_proxy} ]; then
|
||||
echo "Acquire::http::Proxy \"${apt_proxy}\";" > ${prefix}/etc/apt/apt.conf.d/01proxy
|
||||
echo "Acquire::http::Proxy \"${apt_proxy}\";" > ${TARGET}/etc/apt/apt.conf.d/01proxy
|
||||
else
|
||||
logMessage The use of a proxy detected.
|
||||
apt-config dump | grep -i Acquire::HTTP::Proxy > ${prefix}/etc/apt/apt.conf.d/01proxy
|
||||
apt-config dump | grep -i Acquire::HTTP::Proxy > ${TARGET}/etc/apt/apt.conf.d/01proxy
|
||||
fi
|
||||
|
||||
|
||||
#
|
||||
# Setup the sources.list file for new installations of Debian GNU/Linux.
|
||||
#
|
||||
cat <<E_O_APT > ${prefix}/etc/apt/sources.list
|
||||
cat <<E_O_APT > ${TARGET}/etc/apt/sources.list
|
||||
#
|
||||
# /etc/apt/sources.list
|
||||
#
|
||||
@@ -66,7 +66,7 @@ if ( test "${dist}" "!=" "sid" && test "${dist}" "!=" "unstable" && \
|
||||
test -e /etc/apt/sources.list && \
|
||||
grep ^deb.*security -r /etc/apt/sources.list /etc/apt/sources.list.d >/dev/null 2>/dev/null ) ; then
|
||||
|
||||
cat <<E_O_APT >> ${prefix}/etc/apt/sources.list
|
||||
cat <<E_O_APT >> ${TARGET}/etc/apt/sources.list
|
||||
#
|
||||
# Security updates
|
||||
#
|
||||
@@ -75,7 +75,7 @@ deb-src http://security.debian.org/ ${dist}/updates main contrib non-free
|
||||
E_O_APT
|
||||
|
||||
else
|
||||
cat <<E_O_APT >> ${prefix}/etc/apt/sources.list
|
||||
cat <<E_O_APT >> ${TARGET}/etc/apt/sources.list
|
||||
#
|
||||
# Security updates - Uncomment to enable.
|
||||
#
|
||||
@@ -88,32 +88,22 @@ fi
|
||||
#
|
||||
# Now that the sources have been setup make sure the system is up to date.
|
||||
#
|
||||
chroot ${prefix} /usr/bin/apt-get update
|
||||
|
||||
chroot ${TARGET} /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
|
||||
|
||||
logMessage "Ignoring TLS since we're a 64 bit host."
|
||||
|
||||
else
|
||||
|
||||
case "${dist}" in
|
||||
*)
|
||||
logMessage "Installing xen-aware libc6"
|
||||
|
||||
installDebianPackage ${prefix} libc6-xen
|
||||
;;
|
||||
sarge)
|
||||
logMessage "Disabling TLS"
|
||||
mv ${prefix}/lib/tls ${prefix}/lib/tls.disabled
|
||||
mkdir ${prefix}/lib/tls
|
||||
;;
|
||||
esac
|
||||
if [ "${arch}" = "i386" ]; then
|
||||
if [ "${dist}" = 'sarge' ]; then
|
||||
logMessage "Disabling TLS"
|
||||
mv ${TARGET}/lib/tls ${TARGET}/lib/tls.disabled
|
||||
mkdir ${TARGET}/lib/tls
|
||||
else
|
||||
logMessage "Installing xen-aware libc6"
|
||||
installDebianPackage ${TARGET} libc6-xen
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
# --
|
||||
# http://nedos.net
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -62,19 +62,19 @@ KERNEL_XEN_PKG="linux-image-xen-$XEN_ARCH"
|
||||
KERNEL_PKG="linux-image-$XEN_ARCH"
|
||||
|
||||
logMessage Attempting to install the $KERNEL_XEN_PKG kernel image
|
||||
if chroot ${prefix} /usr/bin/apt-cache show $KERNEL_XEN_PKG > /dev/null 2>&1; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show $KERNEL_XEN_PKG > /dev/null 2>&1; then
|
||||
logMessage Package $KERNEL_XEN_PKG is available - installing
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} $KERNEL_XEN_PKG
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} $KERNEL_XEN_PKG
|
||||
|
||||
else
|
||||
logMessage Package $KERNEL_XEN_PKG is not available
|
||||
logMessage Attempting to install the $KERNEL_PKG kernel image
|
||||
logMessage WARNING: This kernel may not have pvops
|
||||
if chroot ${prefix} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
logMessage Package $KERNEL_PKG is available - installing
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} $KERNEL_PKG
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} $KERNEL_PKG
|
||||
else
|
||||
logMessage Package $KERNEL_PKG is not available
|
||||
logMessage pygrub set, but kernel could not be installed
|
||||
@@ -83,48 +83,28 @@ else
|
||||
fi
|
||||
fi
|
||||
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${prefix}/boot/vmlinuz* | tail -n 1))
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${TARGET}/boot/vmlinuz* | tail -n 1))
|
||||
KERNEL_REV=$(echo $DOMU_KERNEL | sed "s/vmlinuz-//g")
|
||||
DOMU_RAMDISK="initrd.img-$KERNEL_REV"
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${prefix}/etc/issue)
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${TARGET}/etc/issue)
|
||||
|
||||
#
|
||||
# Generate initrd if it does not exist
|
||||
#
|
||||
|
||||
if [ -f ${prefix}/boot/$DOMU_RAMDISK ]; then
|
||||
if [ -f ${TARGET}/boot/$DOMU_RAMDISK ]; then
|
||||
logMessage initrd exists, skipping generation
|
||||
else
|
||||
logMessage initrd missing, generating
|
||||
chroot ${prefix} update-initramfs -c -k $KERNEL_REV
|
||||
chroot ${TARGET} update-initramfs -c -k $KERNEL_REV
|
||||
fi
|
||||
|
||||
#
|
||||
# Generate a menu.lst for pygrub
|
||||
#
|
||||
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
||||
default 0
|
||||
timeout 2
|
||||
generateDebianGrubMenuLst "${TARGET}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||
|
||||
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
|
||||
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
|
||||
@@ -6,14 +6,14 @@
|
||||
# --
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -29,15 +29,15 @@ logMessage Script $0 starting
|
||||
# Default to the same locale as the host.
|
||||
#
|
||||
if [ -e /etc/locale.gen ]; then
|
||||
cp /etc/locale.gen ${prefix}/etc
|
||||
cp /etc/locale.gen ${TARGET}/etc
|
||||
fi
|
||||
|
||||
#
|
||||
# Install the package
|
||||
#
|
||||
installDebianPackage ${prefix} locales
|
||||
installDebianPackage ${prefix} util-linux-locales
|
||||
chroot ${prefix} /usr/sbin/update-locale LANG=C
|
||||
installDebianPackage ${TARGET} locales
|
||||
installDebianPackage ${TARGET} util-linux-locales
|
||||
chroot ${TARGET} /usr/sbin/update-locale LANG=C
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
# --
|
||||
# http://nedos.net
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -27,7 +27,7 @@ fi
|
||||
|
||||
logMessage Script $0 starting
|
||||
|
||||
if [ ${pygrub} ]; then
|
||||
if [ "${pygrub}" ]; then
|
||||
|
||||
#
|
||||
# Attempt to install a xen kernel, if that fails, then install a normal one
|
||||
@@ -37,19 +37,19 @@ KERNEL_XEN_PKG="linux-image-xen"
|
||||
KERNEL_PKG="linux-image-server"
|
||||
|
||||
logMessage Attempting to install the $KERNEL_XEN_PKG kernel image
|
||||
if chroot ${prefix} /usr/bin/apt-cache show $KERNEL_XEN_PKG > /dev/null 2>&1; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show $KERNEL_XEN_PKG > /dev/null 2>&1; then
|
||||
logMessage Package $KERNEL_XEN_PKG is available - installing
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} $KERNEL_XEN_PKG
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} $KERNEL_XEN_PKG
|
||||
|
||||
else
|
||||
logMessage Package $KERNEL_XEN_PKG is not available
|
||||
logMessage Attempting to install the $KERNEL_PKG kernel image
|
||||
logMessage WARNING: This kernel may not have pvops
|
||||
if chroot ${prefix} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
logMessage Package $KERNEL_PKG is available - installing
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} $KERNEL_PKG
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} $KERNEL_PKG
|
||||
else
|
||||
logMessage Package $KERNEL_PKG is not available
|
||||
logMessage pygrub set, but kernel could not be installed
|
||||
@@ -58,52 +58,32 @@ else
|
||||
fi
|
||||
fi
|
||||
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${prefix}/boot/vmlinuz* | tail -n 1))
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${TARGET}/boot/vmlinuz* | tail -n 1))
|
||||
KERNEL_REV=$(echo $DOMU_KERNEL | sed "s/vmlinuz-//g")
|
||||
DOMU_RAMDISK="initrd.img-$KERNEL_REV"
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${prefix}/etc/issue)
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${TARGET}/etc/issue)
|
||||
|
||||
#
|
||||
# Generate initrd if it does not exist
|
||||
#
|
||||
|
||||
if [ -f ${prefix}/boot/$DOMU_RAMDISK ]; then
|
||||
if [ -f ${TARGET}/boot/$DOMU_RAMDISK ]; then
|
||||
logMessage initrd exists, skipping generation
|
||||
else
|
||||
logMessage initrd missing, generating
|
||||
chroot ${prefix} update-initramfs -c -k $KERNEL_REV
|
||||
chroot ${TARGET} update-initramfs -c -k $KERNEL_REV
|
||||
fi
|
||||
|
||||
#
|
||||
# Generate a menu.lst for pygrub
|
||||
#
|
||||
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
||||
default 0
|
||||
timeout 2
|
||||
generateDebianGrubMenuLst "${TARGET}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||
|
||||
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
|
||||
logMessage pygrub not set, skipping kernel install
|
||||
fi
|
||||
fi # if pygrub
|
||||
|
||||
#
|
||||
# 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
|
||||
@@ -7,13 +7,13 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -27,14 +27,14 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Remove lines matching 'group' or 'wheel'.
|
||||
#
|
||||
grep -v wheel ${prefix}/etc/pam.d/su > ${prefix}/etc/pam.d/su.tmp
|
||||
grep -v group ${prefix}/etc/pam.d/su.tmp > ${prefix}/etc/pam.d/su
|
||||
grep -v wheel ${TARGET}/etc/pam.d/su > ${TARGET}/etc/pam.d/su.tmp
|
||||
grep -v group ${TARGET}/etc/pam.d/su.tmp > ${TARGET}/etc/pam.d/su
|
||||
|
||||
#
|
||||
# Make sure permissions are correct.
|
||||
#
|
||||
chown root:root ${prefix}/etc/pam.d/su
|
||||
chmod 600 ${prefix}/etc/pam.d/su
|
||||
chown root:root ${TARGET}/etc/pam.d/su
|
||||
chmod 600 ${TARGET}/etc/pam.d/su
|
||||
|
||||
#
|
||||
# Log our finish
|
||||
|
||||
@@ -7,13 +7,13 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -28,7 +28,7 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Make sure we have an /etc/conf.d directory.
|
||||
#
|
||||
mkdir -p ${prefix}/etc/conf.d
|
||||
mkdir -p ${TARGET}/etc/conf.d
|
||||
|
||||
|
||||
#
|
||||
@@ -39,7 +39,7 @@ setupDynamicNetworking ()
|
||||
#
|
||||
# The host is using DHCP.
|
||||
#
|
||||
cat <<E_O_DHCP > ${prefix}/etc/conf.d/net
|
||||
cat <<E_O_DHCP > ${TARGET}/etc/conf.d/net
|
||||
# /etc/conf.d/net:
|
||||
# Global config file for net.* rc-scripts
|
||||
#
|
||||
@@ -70,7 +70,7 @@ setupStaticNetworking ()
|
||||
#
|
||||
# We have a static IP address
|
||||
#
|
||||
cat <<E_O_STATIC >${prefix}/etc/conf.d/net
|
||||
cat <<E_O_STATIC >${TARGET}/etc/conf.d/net
|
||||
#
|
||||
# First ethernet interface
|
||||
#
|
||||
@@ -89,7 +89,7 @@ E_O_STATIC
|
||||
|
||||
logMessage Adding etho:${interface}
|
||||
|
||||
cat <<E_O_STATIC >>${prefix}/etc/conf.d/net
|
||||
cat <<E_O_STATIC >>${TARGET}/etc/conf.d/net
|
||||
config_eth0:${interface}=( "{value} netmask "${netmask}" )
|
||||
|
||||
E_O_STATIC
|
||||
@@ -103,12 +103,12 @@ E_O_STATIC
|
||||
# will be restored after hooks are run.
|
||||
#
|
||||
if [ '' != "$nameserver" ]; then
|
||||
rm -f ${prefix}/etc/resolv.conf.old
|
||||
rm -f ${TARGET}/etc/resolv.conf.old
|
||||
for ns in $nameserver; do
|
||||
echo "nameserver $ns" >>${prefix}/etc/resolv.conf.old
|
||||
echo "nameserver $ns" >>${TARGET}/etc/resolv.conf.old
|
||||
done
|
||||
else
|
||||
cp /etc/resolv.conf ${prefix}/etc/resolv.conf.old
|
||||
cp /etc/resolv.conf ${TARGET}/etc/resolv.conf.old
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -44,8 +44,8 @@ umask 022
|
||||
#
|
||||
# Setup the hostname + domain names.
|
||||
#
|
||||
echo HOSTNAME=\"${name}\" >> ${prefix}/etc/conf.d/hostname
|
||||
echo DNSDOMAIN=\"${domain}\" >> ${prefix}/etc/conf.d/domainname
|
||||
echo HOSTNAME=\"${name}\" >> ${TARGET}/etc/conf.d/hostname
|
||||
echo DNSDOMAIN=\"${domain}\" >> ${TARGET}/etc/conf.d/domainname
|
||||
|
||||
|
||||
#
|
||||
@@ -55,21 +55,21 @@ echo DNSDOMAIN=\"${domain}\" >> ${prefix}/etc/conf.d/domainname
|
||||
if [ -z "${dhcp}" ]; then
|
||||
|
||||
# Non-IPv6 stuff.
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${prefix}/etc/hosts
|
||||
grep -v '\(::\|IPv6\)' /etc/hosts > ${TARGET}/etc/hosts
|
||||
|
||||
# New entry.
|
||||
echo "${ip1} ${hostname}" >> ${prefix}/etc/hosts
|
||||
echo " " >> ${prefix}/etc/hosts
|
||||
echo "${ip1} ${hostname}" >> ${TARGET}/etc/hosts
|
||||
echo " " >> ${TARGET}/etc/hosts
|
||||
|
||||
# IPv6 stuff.
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${prefix}/etc/hosts
|
||||
grep '\(::\|IPv6\)' /etc/hosts >> ${TARGET}/etc/hosts
|
||||
|
||||
else
|
||||
|
||||
#
|
||||
# Stub /etc/hosts for DHCP clients.
|
||||
#
|
||||
cat >> ${prefix}/etc/hosts <<EOF
|
||||
cat >> ${TARGET}/etc/hosts <<EOF
|
||||
127.0.0.1 localhost
|
||||
|
||||
# The following lines are desirable for IPv6 capable hosts
|
||||
|
||||
@@ -10,14 +10,14 @@
|
||||
# http://www.steve.org.uk/
|
||||
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -32,14 +32,14 @@ logMessage Script $0 starting
|
||||
#
|
||||
# Install ssh
|
||||
#
|
||||
installGentooPackage ${prefix} ssh
|
||||
installGentooPackage ${TARGET} ssh
|
||||
|
||||
|
||||
#
|
||||
# Make sure sshd isn't running, this will cause our unmounting of the
|
||||
# disk image to fail..
|
||||
#
|
||||
chroot ${prefix} /etc/init.d/ssh stop
|
||||
chroot ${TARGET} /etc/init.d/ssh stop
|
||||
|
||||
|
||||
#
|
||||
|
||||
@@ -9,14 +9,14 @@
|
||||
# --
|
||||
# http://nedos.net
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
@@ -27,20 +27,20 @@ fi
|
||||
|
||||
logMessage Script $0 starting
|
||||
|
||||
if [ ${pygrub} ]; then
|
||||
if [ "${pygrub}" ]; then
|
||||
|
||||
#
|
||||
# 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 WARNING: This kernel may not have pvops
|
||||
if chroot ${prefix} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show $KERNEL_PKG > /dev/null 2>&1; then
|
||||
logMessage Package $KERNEL_PKG is available - installing
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} $KERNEL_PKG
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} $KERNEL_PKG
|
||||
else
|
||||
logMessage Package $KERNEL_PKG is not available
|
||||
logMessage pygrub set, but kernel could not be installed
|
||||
@@ -48,52 +48,31 @@ else
|
||||
exit 1
|
||||
fi
|
||||
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${prefix}/boot/vmlinuz* | tail -n 1))
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${TARGET}/boot/vmlinuz* | tail -n 1))
|
||||
KERNEL_REV=$(echo $DOMU_KERNEL | sed "s/vmlinuz-//g")
|
||||
DOMU_RAMDISK="initrd.img-$KERNEL_REV"
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${prefix}/etc/issue)
|
||||
DOMU_ISSUE=$(sed -re "s/ *\\\.*//g" -e1q < ${TARGET}/etc/issue)
|
||||
|
||||
#
|
||||
# Generate initrd if it does not exist
|
||||
#
|
||||
|
||||
if [ -f ${prefix}/boot/$DOMU_RAMDISK ]; then
|
||||
if [ -f ${TARGET}/boot/$DOMU_RAMDISK ]; then
|
||||
logMessage initrd exists, skipping generation
|
||||
else
|
||||
logMessage initrd missing, generating
|
||||
chroot ${prefix} update-initramfs -c -k $KERNEL_REV
|
||||
chroot ${TARGET} update-initramfs -c -k $KERNEL_REV
|
||||
fi
|
||||
|
||||
#
|
||||
# Generate a menu.lst for pygrub
|
||||
#
|
||||
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
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
|
||||
generateDebianGrubMenuLst "${TARGET}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$DOMU_RAMDISK"
|
||||
|
||||
else
|
||||
logMessage pygrub not set, skipping kernel install
|
||||
fi
|
||||
fi # if pygrub
|
||||
|
||||
#
|
||||
# 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
|
||||
@@ -9,78 +9,62 @@
|
||||
# --
|
||||
# http://nedos.net
|
||||
|
||||
prefix=$1
|
||||
TARGET=$1
|
||||
|
||||
#
|
||||
# Source our common functions
|
||||
#
|
||||
|
||||
if [ -e /usr/lib/xen-tools/common.sh ]; then
|
||||
. /usr/lib/xen-tools/common.sh
|
||||
if [ -e /usr/share/xen-tools/common.sh ]; then
|
||||
. /usr/share/xen-tools/common.sh
|
||||
else
|
||||
. ./hooks/common.sh
|
||||
fi
|
||||
|
||||
if [ "${pygrub}" ]; then
|
||||
#
|
||||
# Log our start
|
||||
#
|
||||
|
||||
logMessage Script $0 starting
|
||||
|
||||
if [ "${pygrub}" ]; then
|
||||
|
||||
#
|
||||
# The type of kernel that we will be installing
|
||||
#
|
||||
# linux_kernel_type="desktop"
|
||||
#
|
||||
linux_kernel_type="server"
|
||||
linux_kernel_type="virtual"
|
||||
|
||||
linux_kernel_package="linux-image-${linux_kernel_type}"
|
||||
|
||||
logMessage "Installing the ${linux_kernel_package} kernel image"
|
||||
if chroot ${prefix} /usr/bin/apt-cache show ${linux_kernel_package} >/dev/null 2>/dev/null; then
|
||||
if chroot ${TARGET} /usr/bin/apt-cache show ${linux_kernel_package} >/dev/null 2>/dev/null; then
|
||||
logMessage "Package '${linux_kernel_package}' is available - installing"
|
||||
installDebianPackage ${prefix} initramfs-tools
|
||||
installDebianPackage ${prefix} ${linux_kernel_package}
|
||||
installDebianPackage ${TARGET} initramfs-tools
|
||||
installDebianPackage ${TARGET} ${linux_kernel_package}
|
||||
|
||||
# Force initrd if none exists
|
||||
echo ${prefix}/boot/initrd* | grep -q 2\\.6
|
||||
echo ${TARGET}/boot/initrd* | grep -q 2\\.6
|
||||
if [ $? -ne 0 ]; then
|
||||
chroot ${prefix} update-initramfs -c -k `ls -1 ${prefix}/lib/modules/ | head -n 1`
|
||||
chroot ${TARGET} update-initramfs -c -k `ls -1 ${TARGET}/lib/modules/ | head -n 1`
|
||||
fi
|
||||
|
||||
# Generate grub menu.lst
|
||||
DOMU_KERNEL=$(basename $(ls -1 ${prefix}/boot/vmlinuz* | 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_KERNEL=$(basename $(ls -1 ${TARGET}/boot/vmlinuz* | tail -n 1))
|
||||
DOMU_RAMDISK=$(basename $(ls -1 ${TARGET}/boot/initrd*|tail -n 1))
|
||||
DOMU_ISSUE=$(head -n 1 ${TARGET}/etc/issue | awk -F '\' '{ print $1 }' | sed 's/[ \t]*$//')
|
||||
|
||||
mkdir -p ${prefix}/boot/grub
|
||||
cat << E_O_MENU > ${prefix}/boot/grub/menu.lst
|
||||
default 0
|
||||
timeout 2
|
||||
#
|
||||
# Generate a menu.lst for pygrub
|
||||
#
|
||||
|
||||
title $DOMU_ISSUE
|
||||
root (hd0,0)
|
||||
kernel /boot/$DOMU_KERNEL root=/dev/xvda2 ro
|
||||
initrd /boot/$DOMU_RAMDISK
|
||||
generateDebianGrubMenuLst "${TARGET}" "$DOMU_ISSUE" "$DOMU_KERNEL" "$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
|
||||
logMessage "Package '${linux_kernel_package}' is not available"
|
||||
fi
|
||||
|
||||
#
|
||||
# Install the module-init-tools package.
|
||||
#
|
||||
|
||||
installDebianPackage ${prefix} module-init-tools
|
||||
|
||||
else
|
||||
logMessage pygrub not set, skipping kernel install
|
||||
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
|
||||
332
lib/Xen/Tools.pm
332
lib/Xen/Tools.pm
@@ -1,332 +0,0 @@
|
||||
package Xen::Tools;
|
||||
|
||||
use warnings;
|
||||
use strict;
|
||||
use Moose;
|
||||
|
||||
use Xen::Tools::Log;
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Xen::Tools - Build Xen domains with Perl
|
||||
|
||||
=head1 VERSION
|
||||
|
||||
Version 0.01
|
||||
|
||||
=cut
|
||||
|
||||
our $VERSION = '0.01';
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
my $xt = Xen::Tools->new();
|
||||
|
||||
=head1 FUNCTIONS
|
||||
|
||||
=head2 new
|
||||
|
||||
Instantiate the object.
|
||||
|
||||
=cut
|
||||
|
||||
override 'new' => sub {
|
||||
my $class = shift;
|
||||
|
||||
# Initialize the base class
|
||||
my $self = $class->super(@_);
|
||||
|
||||
$self->{_xtl} = Xen::Tools::Log->new( hostname => $self->hostname,
|
||||
logpath => $self->logpath,
|
||||
);
|
||||
|
||||
$self->_checkSystem();
|
||||
|
||||
return $self;
|
||||
};
|
||||
|
||||
=head2 meta
|
||||
|
||||
This is a method which provides access to the current class's meta-
|
||||
class. Inherited from Moose.
|
||||
|
||||
=cut
|
||||
|
||||
=head2 log
|
||||
|
||||
This method sends a log message to the current object's logging
|
||||
mechanism
|
||||
|
||||
=cut
|
||||
|
||||
sub log {
|
||||
my $self = shift;
|
||||
|
||||
$self->{_xtl}->print(@_);
|
||||
}
|
||||
|
||||
=head2 hostname
|
||||
|
||||
Attribute which indicates the domain's hostname
|
||||
|
||||
=cut
|
||||
|
||||
has 'hostname' => ( is => 'ro', isa => 'Str', required => 1 );
|
||||
|
||||
=head2 logpath
|
||||
|
||||
Attribute which indicates the log directory. Defaults to /var/log/xen-tools
|
||||
|
||||
=cut
|
||||
|
||||
has 'logpath' => ( is => 'ro',
|
||||
isa => 'Str',
|
||||
default => '/var/log/xen-tools'
|
||||
);
|
||||
|
||||
=begin doc
|
||||
|
||||
_findBinary
|
||||
|
||||
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 $self = shift;
|
||||
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;
|
||||
}
|
||||
|
||||
=begin doc
|
||||
|
||||
_checkSystem
|
||||
|
||||
Test that this system is fully setup for the new xen-create-image
|
||||
script.
|
||||
|
||||
This means that the the companion scripts xt-* are present on the
|
||||
host and executable.
|
||||
|
||||
=end doc
|
||||
|
||||
=cut
|
||||
|
||||
sub _checkSystem {
|
||||
my $self = shift;
|
||||
my @required = qw ( / xt-customize-image
|
||||
xt-install-image
|
||||
xt-create-xen-config / );
|
||||
|
||||
foreach my $bin ( @required )
|
||||
{
|
||||
if ( ! defined( $self->_findBinary( $bin ) ) )
|
||||
{
|
||||
$self->log("The script '$bin' was not found.\n",
|
||||
"Aborting\n\n"
|
||||
);
|
||||
exit;
|
||||
}
|
||||
}
|
||||
|
||||
#
|
||||
# Make sure that we have Text::Template installed - this
|
||||
# will be used by `xt-create-xen-config` and if that fails then
|
||||
# running is pointless.
|
||||
#
|
||||
my $test = "use Text::Template";
|
||||
eval( $test );
|
||||
if ( ( $@ ) && ( ! $self->{_force} ) )
|
||||
{
|
||||
print <<E_O_ERROR;
|
||||
|
||||
Aborting: The Text::Template perl module isn't installed or available.
|
||||
|
||||
Specify '--force' to skip this check and continue regardless.
|
||||
|
||||
E_O_ERROR
|
||||
exit;
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Make sure that xen-shell is installed if we've got an --admin
|
||||
# flag specified
|
||||
#
|
||||
if ( $self->{_admins} )
|
||||
{
|
||||
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" );
|
||||
|
||||
if ( !defined( $shell ) )
|
||||
{
|
||||
print <<EOF;
|
||||
|
||||
You've specified administrator accounts for use with the xen-shell,
|
||||
however the xen-shell doesn't appear to be installed.
|
||||
|
||||
Aborting.
|
||||
EOF
|
||||
exit;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Test the system has a valid (network-script) + (vif-script) setup.
|
||||
#
|
||||
return $self->_testXenConfig();
|
||||
}
|
||||
|
||||
=begin doc
|
||||
|
||||
Test that the current Xen host has a valid network configuration,
|
||||
this is designed to help newcomers to Xen.
|
||||
|
||||
=end doc
|
||||
|
||||
=cut
|
||||
|
||||
sub _testXenConfig {
|
||||
my $self = shift;
|
||||
# wierdness.
|
||||
return if ( ! -d "/etc/xen" );
|
||||
|
||||
#
|
||||
# Temporary hash.
|
||||
#
|
||||
my %cfg;
|
||||
|
||||
#
|
||||
# Read the configuration file.
|
||||
#
|
||||
open( my $config_fh, q{<}, '/etc/xen/xend-config.sxp' )
|
||||
or die "Failed to read /etc/xen/xend-config.sxp: $!";
|
||||
while( <$config_fh> )
|
||||
{
|
||||
next if ( ! $_ || !length( $_ ) );
|
||||
|
||||
# vif
|
||||
if ( $_ =~ /^\(vif-script ([^)]+)/ )
|
||||
{
|
||||
$cfg{'vif-script'} = $1;
|
||||
}
|
||||
|
||||
# network
|
||||
if ( $_ =~ /^\(network-script ([^)]+)/ )
|
||||
{
|
||||
$cfg{'network-script'} = $1;
|
||||
}
|
||||
}
|
||||
close( $config_fh );
|
||||
|
||||
if ( !defined( $cfg{'network-script'} ) ||
|
||||
!defined( $cfg{'vif-script'} ) )
|
||||
{
|
||||
print <<EOF;
|
||||
|
||||
WARNING
|
||||
-------
|
||||
|
||||
You appear to have a missing vif-script, or network-script, in the
|
||||
Xen configuration file /etc/xen/xend-config.sxp.
|
||||
|
||||
Please fix this and restart Xend, or your guests will not be able
|
||||
to use any networking!
|
||||
|
||||
EOF
|
||||
}
|
||||
else
|
||||
{
|
||||
if ( ( $cfg{'network-script'} =~ /dummy/i ) ||
|
||||
( $cfg{'vif-script'} =~ /dummy/i ) )
|
||||
{
|
||||
|
||||
print <<EOF;
|
||||
WARNING
|
||||
-------
|
||||
|
||||
You appear to have a "dummy" vif-script, or network-script, setting
|
||||
in the Xen configuration file /etc/xen/xend-config.sxp.
|
||||
|
||||
Please fix this and restart Xend, or your guests will not be able to
|
||||
use any networking!
|
||||
|
||||
EOF
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
=head1 AUTHOR
|
||||
|
||||
C.J. Adams-Collier, C<< <cjac at colliertech.org> >>
|
||||
|
||||
=head1 BUGS
|
||||
|
||||
Please report any bugs or feature requests to C<bug-xen-tools at rt.cpan.org>, or through
|
||||
the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Xen-Tools>. I will be notified, and then you'll
|
||||
automatically be notified of progress on your bug as I make changes.
|
||||
|
||||
|
||||
|
||||
|
||||
=head1 SUPPORT
|
||||
|
||||
You can find documentation for this module with the perldoc command.
|
||||
|
||||
perldoc Xen::Tools
|
||||
|
||||
|
||||
You can also look for information at:
|
||||
|
||||
=over 4
|
||||
|
||||
=item * RT: CPAN's request tracker
|
||||
|
||||
L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Xen-Tools>
|
||||
|
||||
=item * AnnoCPAN: Annotated CPAN documentation
|
||||
|
||||
L<http://annocpan.org/dist/Xen-Tools>
|
||||
|
||||
=item * CPAN Ratings
|
||||
|
||||
L<http://cpanratings.perl.org/d/Xen-Tools>
|
||||
|
||||
=item * Search CPAN
|
||||
|
||||
L<http://search.cpan.org/dist/Xen-Tools>
|
||||
|
||||
=back
|
||||
|
||||
=head1 COPYRIGHT & LICENSE
|
||||
|
||||
Copyright 2007 C.J. Adams-Collier, all rights reserved.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify it
|
||||
under the same terms as Perl itself.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
1; # End of Xen::Tools
|
||||
442
lib/Xen/Tools/Common.pm
Normal file
442
lib/Xen/Tools/Common.pm
Normal file
@@ -0,0 +1,442 @@
|
||||
# -*- 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;
|
||||
@@ -1,212 +0,0 @@
|
||||
package Xen::Tools::Log;
|
||||
|
||||
use warnings;
|
||||
use strict;
|
||||
use Moose;
|
||||
use File::Spec;
|
||||
use POSIX; # strftime
|
||||
use Carp;
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Xen::Tools::Log - Log Xen::Tools events
|
||||
|
||||
=head1 VERSION
|
||||
|
||||
Version 0.01
|
||||
|
||||
=cut
|
||||
|
||||
our $VERSION = '0.01';
|
||||
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
Mostly internal to Xen::Tools. Use this to create a logging mechanism.
|
||||
|
||||
my $xtl = Xen::Tools::Log->new( hostname => 'firewall' );
|
||||
|
||||
$xtl->print("Yay for logging.");
|
||||
|
||||
=head1 FUNCTIONS
|
||||
|
||||
=head2 new
|
||||
|
||||
Create the log object
|
||||
|
||||
=cut
|
||||
|
||||
=head2 print
|
||||
|
||||
Print the given string both to our screen, and to the logfile.
|
||||
|
||||
=cut
|
||||
|
||||
sub print {
|
||||
my $self = shift;
|
||||
|
||||
$self->print_screen( @_ );
|
||||
$self->print_log( @_ );
|
||||
}
|
||||
|
||||
=head2 print_screen
|
||||
|
||||
Print the given string to our screen
|
||||
|
||||
=cut
|
||||
|
||||
sub print_screen {
|
||||
my $self = shift;
|
||||
|
||||
print map { "$_\n" } @_;
|
||||
}
|
||||
|
||||
=head2 print_log
|
||||
|
||||
Print the given string to the logfile.
|
||||
|
||||
=cut
|
||||
|
||||
sub print_log {
|
||||
my $self = shift;
|
||||
|
||||
# Create an RFC 822 conformant date string
|
||||
my $date = strftime( "%a, %d %b %Y %H:%M:%S %z", localtime );
|
||||
my $fh = $self->log_fh();
|
||||
print $fh ( map { "$date - $_" } @_ );
|
||||
}
|
||||
|
||||
=head2 hostname
|
||||
|
||||
Attribute storing the hostname this log describes
|
||||
|
||||
=cut
|
||||
|
||||
has 'hostname' => ( is => 'rw', isa => 'Str', required => 1 );
|
||||
|
||||
=head2 logpath
|
||||
|
||||
Attribute storing the directory in which the log file resides
|
||||
|
||||
=cut
|
||||
|
||||
has 'logpath' => ( is => 'rw',
|
||||
isa => 'Str',
|
||||
default => '/var/log/xen-tools'
|
||||
);
|
||||
|
||||
=head2 log_fh
|
||||
|
||||
FileHandle attribute storing the filehandle of the log
|
||||
|
||||
=cut
|
||||
|
||||
has 'log_fh' => ( is => 'ro',
|
||||
isa => 'FileHandle',
|
||||
lazy => 1,
|
||||
default => \&_init_fh,
|
||||
);
|
||||
|
||||
=head2 clean_up
|
||||
|
||||
Boolean attribute indicating whether the log will be cleaned up when the
|
||||
logger is closed
|
||||
|
||||
=cut
|
||||
|
||||
has 'clean_up' => ( is => 'ro',
|
||||
isa => 'Bool',
|
||||
default => 0,
|
||||
);
|
||||
|
||||
before 'DESTROY' => sub {
|
||||
my $self = shift;
|
||||
|
||||
# Deconstructor
|
||||
};
|
||||
|
||||
=head2 meta
|
||||
|
||||
This is a method which provides access to the current class's meta-
|
||||
class. Inherited from Moose.
|
||||
|
||||
=cut
|
||||
|
||||
=begin doc
|
||||
|
||||
_init_fh
|
||||
|
||||
This private method initializes the logging filehandle, creating the
|
||||
containing directory if it does not exist.
|
||||
|
||||
=end doc
|
||||
|
||||
=cut
|
||||
|
||||
sub _init_fh {
|
||||
my $self = shift;
|
||||
|
||||
my $logFile =
|
||||
File::Spec->catfile( $self->logpath(), $self->hostname() . '.log' );
|
||||
|
||||
system( qw(mkdir -p), $self->logpath() ) unless -d $self->logpath();
|
||||
|
||||
carp "Couldn't create log directory: $!" unless $? == 0;
|
||||
|
||||
open( $self->{log_fh}, q{>>}, $logFile ) or
|
||||
carp "Couldn't open log file for append: $!";
|
||||
};
|
||||
|
||||
=head1 AUTHOR
|
||||
|
||||
C.J. Adams-Collier, C<< <cjac at colliertech.org> >>
|
||||
|
||||
=head1 BUGS
|
||||
|
||||
Please report any bugs or feature requests to C<bug-xen-tools-log at rt.cpan.org>, or through
|
||||
the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Xen-Tools>. I will be notified, and then you'll
|
||||
automatically be notified of progress on your bug as I make changes.
|
||||
|
||||
|
||||
|
||||
|
||||
=head1 SUPPORT
|
||||
|
||||
You can find documentation for this module with the perldoc command.
|
||||
|
||||
perldoc Xen::Tools
|
||||
|
||||
|
||||
You can also look for information at:
|
||||
|
||||
=over 4
|
||||
|
||||
=item * RT: CPAN's request tracker
|
||||
|
||||
L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Xen-Tools>
|
||||
|
||||
=item * AnnoCPAN: Annotated CPAN documentation
|
||||
|
||||
L<http://annocpan.org/dist/Xen-Tools>
|
||||
|
||||
=item * CPAN Ratings
|
||||
|
||||
L<http://cpanratings.perl.org/d/Xen-Tools>
|
||||
|
||||
=item * Search CPAN
|
||||
|
||||
L<http://search.cpan.org/dist/Xen-Tools>
|
||||
|
||||
=back
|
||||
|
||||
=head1 COPYRIGHT & LICENSE
|
||||
|
||||
Copyright 2007 C.J. Adams-Collier, all rights reserved.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify it
|
||||
under the same terms as Perl itself.
|
||||
|
||||
|
||||
=cut
|
||||
|
||||
1; # End of Xen::Tools::Log
|
||||
@@ -9,7 +9,6 @@ misc/
|
||||
|
||||
xen-tools - Bash completion code for our commands.
|
||||
xen-tools.spec - File to build an RPM of the xen-tools pacakge.
|
||||
xm - Bash completion code for the Xen 'xm' command.
|
||||
|
||||
Steve
|
||||
--
|
||||
|
||||
@@ -65,8 +65,8 @@ _xen_create_image()
|
||||
# Available distributions, by which we mean distributions which
|
||||
# we have hook scripts available.
|
||||
#
|
||||
for i in `/bin/ls -1 /usr/lib/xen-tools/ ` ; do
|
||||
if [ -d /usr/lib/xen-tools/${i} ]; then
|
||||
for i in `/bin/ls -1 /usr/share/xen-tools/ ` ; do
|
||||
if [ -d /usr/share/xen-tools/${i} ]; then
|
||||
dists="${dists} ${i/.d/}"
|
||||
fi
|
||||
done
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user