Naposledy aktivní 6 months ago

Revize 739c17e8d735329c1ed8a7d7846988d8edb5c2bf

wheezy2jessie.sh Raw
1Please also refer to http://www.debian.org/releases/jessie/releasenotes and use your brain!
2
3
4# upgrade to UTF-8 locales (http://www.debian.org/releases/jessie/amd64/release-notes/ap-old-stuff.en.html#switch-utf8)
5dpkg-reconfigure locales
6
7# remove unused config file
8rm -rf /etc/network/options /etc/environment
9
10# Transition and remove entries from older releases
11sed -i s#/backports.org/debian#/ftp.de.debian.org/debian#g /etc/apt/sources.list*
12sed -i s/debian-backports/debian/g /etc/apt/sources.list*
13sed -i /etch/d /etc/apt/sources.list*
14sed -i /lenny/d /etc/apt/sources.list*
15sed -i /sarge/d /etc/apt/sources.list*
16sed -i /squeeze/d /etc/apt/sources.list*
17sed -i /volatile/d /etc/apt/sources.list*
18sed -i /proposed-updates/d /etc/apt/sources.list*
19# change distro (please move 3rd party sources to /etc/apt/sources.list.d/), maybe look into http://ftp.cyconet.org/debian/sources.list.d/
20sed -i s/wheezy/jessie/g /etc/apt/sources.list*
21sed -i "s/ stable/ jessie/g" /etc/apt/sources.list*
22sed -i s/wheezy/jessie/g /etc/apt/preferences*
23sed -i s/wheezy/jessie/g /etc/apt/sources.list.d/*wheezy*
24rename s/wheezy/jessie/g /etc/apt/sources.list.d/*wheezy*
25aptitude update
26
27# check package status
28dpkg --audit
29aptitude search "~ahold" | grep "^.h"
30dpkg --get-selections | grep hold
31
32# unmark packages auto
33aptitude unmarkauto vim
34aptitude unmarkauto $(dpkg-query -W 'linux-image-3.2.*' | cut -f1)
35
36# have a look into required and free disk space
37apt-get -o APT::Get::Trivial-Only=true dist-upgrade || df -h
38
39# check if we have PAE available (http://www.debian.org/releases/testing/i386/release-notes/ch-upgrading.en.html#idp573136)
40#grep -q '^flags.*\bpae\b' /proc/cpuinfo && echo "We support PAE: yes" \
41#|| echo "We support PAE: no (please install linux-image-486 and remove linux-image-.*-686)"
42
43# record session
44script -t 2>~/upgrade-jessie.time -a ~/upgrade-jessie.script
45
46# install our preseed so libc doesn't whine
47cat > /tmp/jessie.preseed <<EOF
48libc6 glibc/upgrade boolean true
49libc6 glibc/restart-services string
50libc6 libraries/restart-without-asking boolean true
51EOF
52/usr/bin/debconf-set-selections /tmp/jessie.preseed
53
54# update aptitude first
55[ "$(which aptitude)" = "/usr/bin/aptitude" ] && aptitude install aptitude
56
57# minimal system upgrade (keep sysvinit / see http://noone.org/talks/debian-ohne-systemd/debian-ohne-systemd-clt.html#%2811%29)
58aptitude upgrade '~U' 'sysvinit-core+'
59
60# (re)enable wheel
61if [ -f /etc/pam.d/su.dpkg-new ]; then CFG=/etc/pam.d/su.dpkg-new; else CFG=/etc/pam.d/su; fi
62sed -i "s/# auth required pam_wheel.so/auth required pam_wheel.so/" $CFG
63
64# (re)configure snmpd
65if [ -f /etc/snmp/snmpd.conf.dpkg-new ]; then CFG=/etc/snmp/snmpd.conf.dpkg-new; \
66 else CFG=/etc/snmp/snmpd.conf; fi
67sed -i "s^#rocommunity secret 10.0.0.0/16^rocommunity mycommunity^g" $CFG
68sed -i s/#agentAddress/agentAddress/ $CFG
69sed -i "s/^ rocommunity public/# rocommunity public/" $CFG
70sed -i "s/^ rocommunity6 public/# rocommunity6 public/" $CFG
71sed -i "s/agentAddress udp:127/#agentAddress udp:127/" $CFG
72
73# randomize crontab
74if [ -f /etc/crontab.dpkg-new ]; then CFG=/etc/crontab.dpkg-new; else CFG=/etc/crontab; fi
75sed -i 's#root cd#root perl -e "sleep int(rand(300))" \&\& cd#' $CFG
76sed -i 's#root\ttest#root\tperl -e "sleep int(rand(3600))" \&\& test#' $CFG
77
78# phpmyadmin
79if [ -f /etc/phpmyadmin/config.inc.php.dpkg-new ]; then CFG=/etc/phpmyadmin/config.inc.php.dpkg-new; \
80 else CFG=/etc/phpmyadmin/config.inc.php; fi
81sed -i "s/\['auth_type'\] = 'cookie'/\['auth_type'\] = 'http'/" $CFG
82sed -i "s#//\$cfg\['Servers'\]\[\$i\]\['auth_type'\] = 'http';#\$cfg['Servers'][\$i]['auth_type'] = 'http';#" $CFG
83
84# remove anonymous mysql access
85#mysql -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;"
86
87# dont use iptables when creating xen vifs
88#cp /etc/xen/scripts/vif-bridge /etc/xen/scripts/vif-bridge-local
89#sed -i "s/^ handle_iptable/ true/g" /etc/xen/scripts/vif-bridge-local
90#sed -i "s/^(vif-script vif-bridge)/(vif-script vif-bridge-local)/" /etc/xen/xend-config.sxp
91
92# xen
93#/bin/sed -i -e 's/^[# ]*\((dom0-min-mem\).*\().*\)$/\1 512\2/' /etc/xen/xend-config.sxp
94#sed -i s/XENDOMAINS_RESTORE=true/XENDOMAINS_RESTORE=false/ /etc/default/xendomains
95#sed -i s#XENDOMAINS_SAVE=/var/lib/xen/save#XENDOMAINS_SAVE=\"\"# /etc/default/xendomains
96#dpkg-divert --divert /etc/grub.d/09_linux_xen --rename /etc/grub.d/20_linux_xen
97#echo 'GRUB_CMDLINE_XEN="dom0_mem=512M"' >> /etc/default/grub
98
99# maybe we want to change some shorewall config stuff again
100sed -i s/^startup=0/startup=1/ /etc/default/shorewall
101
102# full-upgrade
103aptitude full-upgrade
104
105# migrate expose.ini
106#[ -f /etc/php5/conf.d/expose.ini ] && mv /etc/php5/conf.d/expose.ini \
107# /etc/php5/mods-available/local-expose.ini && php5enmod local-expose/90
108# migrate local suhosin config
109#find /etc/php5/conf.d/ -type f -name "*suhosin.ini" -exec mv '{}' \
110# /etc/php5/mods-available/local-suhosin.ini \; && php5enmod local-suhosin/90
111
112# mysql
113
114# vsftpd and chroot_local_user?
115#if [ "$(grep -i ^chroot_local_user=yes /etc/vsftpd.conf | wc -l)" -ge "1" ]; then \
116# echo "deb http://ftp.cyconet.org/debian wheezy-updates main non-free contrib" >> \
117# /etc/apt/sources.list.d/wheezy-updates-cyconet.list; \
118# aptitude update; aptitude install -t wheezy-updates vsftpd && \
119# echo "allow_writeable_chroot=YES" >> /etc/vsftpd.conf && /etc/init.d/vsftpd restart; \
120#fi
121
122# remove old squeeze packages left around (keep eyes open!)
123apt-get autoremove
124aptitude search ?obsolete
125dpkg -l | grep etch | grep -v xen | grep -v unbound | grep -v finch | awk '{print $2}' | xargs aptitude -y purge
126dpkg -l | grep lenny | grep -v xen | awk '{print $2}' | xargs aptitude -y purge
127dpkg -l | grep squeeze | grep -v xen | awk '{print $2}' | xargs aptitude -y purge
128dpkg -l | grep wheezy | grep -v xen | grep -v linux-image | awk '{print $2}' | xargs aptitude -y purge
129aptitude -y install deborphan && deborphan | grep -v xen | grep -v libpam-cracklib | xargs aptitude -y purge
130dpkg -l | grep ^r | awk '{print $2}' | xargs aptitude -y purge
131