最后活跃于 6 months ago

修订 be27b7428135d9cff57228ee952aeed72f2dc9ce

squeeze2wheezy.sh 原始文件
1Please also refer to http://www.debian.org/releases/wheezy/releasenotes and use your brain!
2For Roundcube and Sqlite Backend see: http://wiki.debian.org/Roundcube/DeprecationOfSQLitev2
3
4
5# upgrade to UTF-8 locales (http://www.debian.org/releases/testing/i386/release-notes/ap-old-stuff.en.html#switch-utf8)
6dpkg-reconfigure locales
7
8# remove unused config file
9rm -rf /etc/network/options /etc/environment
10
11# change distro (please move 3rd party sources to /etc/apt/sources.list.d/), maybe look into http://ftp.cyconet.org/debian/sources.list.d/
12rm -f /etc/apt/apt.conf.d/10disable_date_check
13rm -f /etc/apt/sources.list.d/*squeeze*
14sed -i s/squeeze/wheezy/g /etc/apt/sources.list*
15sed -i "s/ stable/ wheezy/g" /etc/apt/sources.list*
16sed -i s/squeeze/wheezy/g /etc/apt/preferences*
17sed -i /proposed-updates/d /etc/apt/sources.list*
18sed -i /volatile/d /etc/apt/sources.list*
19sed -i /etch/d /etc/apt/sources.list*
20sed -i /lenny/d /etc/apt/sources.list*
21sed -i s#/backports.org/debian#/ftp.de.debian.org/debian#g /etc/apt/sources.list*
22sed -i s/debian-backports/debian/g /etc/apt/sources.list*
23if [ "$( dpkg -l | grep "^ii.*php5-suhosin" | wc -l)" -ge "1" ]; then \
24 wget http://ftp.cyconet.org/debian/sources.list.d/wheezy-updates-cyconet.list \
25 -O /etc/apt/sources.list.d/wheezy-updates-cyconet.list
26fi
27cat >> /etc/apt/preferences <<EOF
28Package: *
29Pin: release a=squeeze-lts
30Pin-Priority: 200
31
32EOF
33aptitude update
34
35# check package status
36dpkg --audit
37aptitude search "~ahold" | grep "^.h"
38dpkg --get-selections | grep hold
39
40# unmark packages auto
41aptitude unmarkauto vim shorewall
42aptitude unmarkauto $(dpkg-query -W 'linux-image-2.6.*' | cut -f1)
43
44# have a look into required and free disk space
45apt-get -o APT::Get::Trivial-Only=true dist-upgrade || df -h
46
47# check if we have PAE available (http://www.debian.org/releases/testing/i386/release-notes/ch-upgrading.en.html#idp573136)
48grep -q '^flags.*\bpae\b' /proc/cpuinfo && echo "We support PAE: yes" \
49|| echo "We support PAE: no (please install linux-image-486 and remove linux-image-.*-686)"
50
51# record session
52script -t 2>~/upgrade-wheezy.time -a ~/upgrade-wheezy.script
53
54# install our preseed so libc doesn't whine
55cat > /tmp/wheezy.preseed <<EOF
56libc6 glibc/upgrade boolean true
57libc6 glibc/restart-services string
58libc6 libraries/restart-without-asking boolean true
59EOF
60/usr/bin/debconf-set-selections /tmp/wheezy.preseed
61
62# minimal system upgrade
63aptitude upgrade
64
65# randomize crontab
66if [ -f /etc/crontab.dpkg-new ]; then CFG=/etc/crontab.dpkg-new; else CFG=/etc/crontab; fi
67sed -i 's#root cd#root perl -e "sleep int(rand(300))" \&\& cd#' $CFG
68sed -i 's#root\ttest#root\tperl -e "sleep int(rand(3600))" \&\& test#' $CFG
69
70# phpmyadmin
71if [ -f /etc/phpmyadmin/config.inc.php.dpkg-new ]; then CFG=/etc/phpmyadmin/config.inc.php.dpkg-new; \
72 else CFG=/etc/phpmyadmin/config.inc.php; fi
73sed -i "s/\['auth_type'\] = 'cookie'/\['auth_type'\] = 'http'/" $CFG
74sed -i "s#//\$cfg\['Servers'\]\[\$i\]\['auth_type'\] = 'http';#\$cfg['Servers'][\$i]['auth_type'] = 'http';#" $CFG
75
76# remove anonymous mysql access
77mysql -u root -p -e "DELETE FROM mysql.user WHERE User=''; DELETE FROM mysql.db WHERE Db='test' AND Host='%' OR Db='test\\_%' AND Host='%'; FLUSH PRIVILEGES;"
78
79if [ -f /etc/default/xendomains.dpkg-new ]; then CFG=/etc/default/xendomains.dpkg-new; \
80 else CFG=/etc/default/xendomains; fi
81sed -i s/XENDOMAINS_RESTORE=true/XENDOMAINS_RESTORE=false/ $CFG
82sed -i s#XENDOMAINS_SAVE=/var/lib/xen/save#XENDOMAINS_SAVE=\"\"# $CFG
83
84# dont use iptables when creating xen vifs
85if [ -f /etc/xen/xend-config.sxp.dpkg-new ]; then CFG=/etc/xen/xend-config.sxp.dpkg-new; \
86 else CFG=/etc/xen/xend-config.sxp; fi
87sed -i "s/^(vif-script vif-bridge)/(vif-script vif-bridge-local)/" $CFG
88/bin/sed -i -e 's/^[# ]*\((dom0-min-mem\).*\().*\)$/\1 512\2/' $CFG
89
90cp /etc/xen/scripts/vif-bridge /etc/xen/scripts/vif-bridge-local
91sed -i "s/^ handle_iptable/ true/g" /etc/xen/scripts/vif-bridge-local
92
93# chrony update
94if [ -f /etc/chrony/chrony.conf.new ]; then CFG=/etc/chrony/chrony.conf.new; else CFG=/etc/chrony/chrony.conf; fi
95sed -i s/debian.pool/de.pool/g $CFG
96
97rm -rf /etc/grub.d/09_linux_xen
98dpkg-divert --divert /etc/grub.d/09_linux_xen --rename /etc/grub.d/20_linux_xen
99#mv /etc/grub.d/20_linux_xen /etc/grub.d/09_linux_xen
100echo 'GRUB_CMDLINE_XEN="dom0_mem=512M"' >> /etc/default/grub
101
102# maybe we want to change some shorewall config stuff again
103if [ -f /etc/default/shorewall.dpkg-new ]; then CFG=/etc/default/shorewall.dpkg-new; \
104 else CFG=/etc/default/shorewall; fi
105sed -i s/^startup=0/startup=1/ $CFG
106
107# dist-upgrade
108aptitude dist-upgrade
109
110# migrate expose.ini
111[ -f /etc/php5/conf.d/expose.ini ] && mv /etc/php5/conf.d/expose.ini \
112 /etc/php5/mods-available/local-expose.ini && php5enmod local-expose/90
113# migrate local suhosin config
114find /etc/php5/conf.d/ -type f -name "*suhosin.ini" -exec mv '{}' \
115 /etc/php5/mods-available/local-suhosin.ini \; && php5enmod local-suhosin/90
116
117# mysql
118
119# vsftpd and chroot_local_user?
120if [ "$(grep -i ^chroot_local_user=yes /etc/vsftpd.conf | wc -l)" -ge "1" ]; then \
121 aptitude update; aptitude install -t wheezy-updates vsftpd && \
122 echo "allow_writeable_chroot=YES" >> /etc/vsftpd.conf && /etc/init.d/vsftpd restart; \
123fi
124
125# install fixed quotatool
126dpkg -l | grep quotatool && aptitude update; aptitude safe-upgrade -t wheezy-updates quotatool
127
128# remove old squeeze packages left around (keep eyes open!)
129apt-get autoremove
130aptitude search ?obsolete
131dpkg -l | grep etch | grep -v xen | grep -v unbound | grep -v finch | grep -v fetch | awk '{print $2}' | xargs aptitude -y purge
132dpkg -l | grep lenny | grep -v xen | awk '{print $2}' | xargs aptitude -y purge
133dpkg -l | grep -E 'deb6|squeeze' | grep -v xen | grep -v linux-image | awk '{print $2}' | xargs aptitude -y purge
134aptitude -y install deborphan && deborphan | grep -v xen | grep -v libpam-cracklib | xargs aptitude -y purge
135dpkg -l | grep ^r | awk '{print $2}' | xargs aptitude -y purge
136
137# for the brave YoloOps crowd
138reboot && sleep 180; echo u > /proc/sysrq-trigger ; sleep 2 ; echo s > /proc/sysrq-trigger ; sleep 2 ; echo b > /proc/sysrq-trigger
139