2014-07-28 17:14:28 -04:00
---
2015-04-10 16:17:45 -04:00
layout: doc
2015-10-13 23:31:03 -04:00
title: Debian Template
2015-10-28 18:14:40 -04:00
permalink: /doc/templates/debian/
2015-10-11 03:04:59 -04:00
redirect_from:
2016-05-21 10:49:01 -04:00
- /doc/debian/
2015-10-28 18:14:40 -04:00
- /en/doc/templates/debian/
2015-10-11 03:04:59 -04:00
- /doc/Templates/Debian/
- /wiki/Templates/Debian/
2014-07-28 17:14:28 -04:00
---
2015-04-22 23:26:43 -04:00
Debian template(s)
2014-07-28 17:14:28 -04:00
===============
2017-02-09 15:29:54 -05:00
If you would like to use Debian Linux distribution in your qubes, you can install one of the available Debian templates.
2015-04-23 10:14:55 -04:00
2017-02-09 15:29:54 -05:00
Updates for these templates are provided by ITL and are signed by this key:
2015-04-23 10:14:55 -04:00
pub 4096R/47FD92FA 2014-07-27
Key fingerprint = 2D43 E932 54EE EA7C B31B 6A77 5E58 18AB 47FD 92FA
uid Qubes OS Debian Packages Signing Key
The key is already installed when you install (signed) template package. You
can also obtain the key from [git
repository](https://github.com/QubesOS/qubes-core-agent-linux/blob/master/misc/qubes-archive-keyring.gpg),
which is also integrity-protected using signed git tags.
2014-07-28 17:14:28 -04:00
2018-10-22 09:09:09 -04:00
If you want a debian-minimal template, this can be built using [Qubes-builder ](https://www.qubes-os.org/doc/qubes-builder/ ),by selecting a +minimal flavour in setup, and then
make qubes-vm & & make template
2018-01-25 23:03:34 -05:00
Installing
----------
2014-07-28 17:14:28 -04:00
2017-02-09 15:29:54 -05:00
Templates can be installed with the following command:
2014-07-28 17:14:28 -04:00
2017-06-30 00:05:02 -04:00
Debian 7 (wheezy) - obsolete/archive:
2015-04-22 23:26:43 -04:00
2015-04-23 10:14:55 -04:00
[user@dom0 ~]$ sudo qubes-dom0-update qubes-template-debian-7
2015-04-22 23:26:43 -04:00
2019-07-10 11:43:46 -04:00
Debian 8 (jessie) - oldoldstable:
2015-04-22 23:26:43 -04:00
2015-04-23 10:14:55 -04:00
[user@dom0 ~]$ sudo qubes-dom0-update qubes-template-debian-8
2016-01-20 10:00:53 -05:00
2019-07-10 11:43:46 -04:00
Debian 9 (stretch) - oldstable:
2014-07-28 17:14:28 -04:00
2017-11-27 19:52:39 -05:00
[user@dom0 ~]$ sudo qubes-dom0-update qubes-template-debian-9
2016-05-21 08:22:30 -04:00
2019-07-10 11:43:46 -04:00
A Debian-10 template is currently available from the testing repository.
Debian 10 (buster) - stable:
[user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-templates-itl-testing qubes-template-debian-10
Because this template was built *before* buster became stable, it cannot be updated without [manually accepting the change in status][5149].
2018-01-25 23:03:34 -05:00
Upgrading
---------
To upgrade your Debian TemplateVM, please consult the guide that corresponds to your situation:
* [Upgrading the Debian 8 Template to Debian 9 ](/doc/template/debian/upgrade-8-to-9/ )
2016-01-20 10:00:53 -05:00
2014-07-28 17:14:28 -04:00
Known issues
------------
2017-05-20 17:48:23 -04:00
### Starting services
2017-02-09 15:29:54 -05:00
The Debian way (generally) is to start daemons if they are installed.
This means that if you install (say) ssh-server in a template, *all* the qubes that use that template will run a ssh server when they start. (They will, naturally, all have the same server key.) This may not be what you want.
So be very careful when installing software in Templates - if the daemon spawns outbound connections then there is a serious security risk.
In general, a reasonable approach would be, (using ssh as example):
- Install the ssh service.
- systemctl stop ssh
- systemctl disable ssh
- systemctl mask ssh
- Close down template
Now the ssh service will **NOT** start in qubes based on this template.
Where you **DO** want the service to run, put this in /rw/config/rc.local:
systemctl unmask ssh
systemctl start ssh
Don't forget to make the file executable.
2017-05-20 17:48:23 -04:00
### Unattended Upgrades
2017-02-09 15:29:54 -05:00
Some users have noticed that on upgrading to Stretch, the unattended-upgrade package is installed.
This package is pulled in as part of a Recommend chain, and can be purged.
The lesson is that you should carefully look at what is being installed to your system, particularly if you run dist-upgrade.
2018-03-21 20:35:56 -04:00
### Package installation errors in Qubes 4.0
By default, templates in 4.0 only have a loopback interface.
2019-02-08 09:18:08 -05:00
Some packages will throw an error on installation in this situation. For example, Samba expects to be configured using a network interface post installation.
2018-03-21 20:35:56 -04:00
One solution is to add a dummy interface to allow the package to install correctly:
2019-02-08 09:18:08 -05:00
ip link add d0 type dummy
2018-03-21 20:35:56 -04:00
ip addr add 192.168.0.1/24 dev d0
ip link set d0 up
2017-05-20 17:48:23 -04:00
Contributing
----------------
2017-02-09 15:29:54 -05:00
2014-07-28 17:14:28 -04:00
If you want to help in improving the template, feel free to [contribute ](/wiki/ContributingHowto ).
2016-09-14 19:22:29 -04:00
2018-01-25 23:03:34 -05:00
2016-09-14 19:22:29 -04:00
More information
----------------
* [Debian wiki ](https://wiki.debian.org/Qubes )
2017-05-20 17:48:23 -04:00
2018-01-25 23:03:34 -05:00
2018-02-03 15:51:06 -05:00
[stretch]: /doc/template/debian/upgrade-8-to-9/
2019-07-10 11:43:46 -04:00
[5149]: https://github.com/QubesOS/qubes-issues/issues/5149