2016-05-03 11:13:26 +08:00
Part 2 - LXD 2.0: 安装与配置
2016-05-02 21:52:39 +08:00
=================================================
2016-05-03 11:13:26 +08:00
这是 LXD 2.0 [系列介绍文章][2]的第二篇。
2016-05-02 21:52:39 +08:00
![](https://linuxcontainers.org/static/img/containers.png)
2016-05-03 11:13:26 +08:00
### 安装篇
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
获得 LXD 有很多种办法。我们推荐你是用配合最新版的 LXC 和 Linux 内核使用 LXD, 这样就可以享受到它的全部特性, 但是注意, 我们现在也在慢慢的降低对旧版本 Linux 发布版的支持。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
#### Ubuntu 标准版
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
所有新发布的 LXD 都会在发布几分钟后上传到 Ubuntu 开发版的安装源里。这个安装包然后就会当作种子给全部其他的安装包源,供 Ubuntu 用户使用。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
如果使用 Ubuntu 16.04 则可以直接安装:
2016-05-02 21:52:39 +08:00
```
sudo apt install lxd
```
2016-05-03 11:13:26 +08:00
如果运行的是 Ubuntu 14.04,可以这样安装:
2016-05-02 21:52:39 +08:00
```
sudo apt -t trusty-backports install lxd
```
2016-05-03 11:13:26 +08:00
#### Ubuntu Core
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
使用Ubuntu Core 稳定版的用户可以使用下面的命令安装 LXD:
2016-05-02 21:52:39 +08:00
```
sudo snappy install lxd.stgraber
```
2016-05-03 11:13:26 +08:00
#### ubuntu 官方 PPA
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
是哟个其他 Ubuntu 发布版 —— 比如 Ubuntu 15.10 —— 的用户可以添加下面的 PPA (Personal Package Archive) 来安装:
2016-05-02 21:52:39 +08:00
```
sudo apt-add-repository ppa:ubuntu-lxc/stable
sudo apt update
sudo apt dist-upgrade
sudo apt install lxd
```
2016-05-03 11:13:26 +08:00
#### Gentoo
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
Gentoo 已经有了最新的 LXD 安装包,你可以直接安装:
2016-05-02 21:52:39 +08:00
```
sudo emerge --ask lxd
```
2016-05-03 11:13:26 +08:00
#### 源代码
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
如果你曾经编译过 Go 工程,那么从源代码编译 LXD 并不是十分困难。然而要住你的是你需要 LXC 的开发头文件。为了运行 LXD , 你的 发布版铜须也需要使用比较新的内核(最起码是 3.13),比较新的 LXC ( 1.1.4 或更高版本) , LXCFS 以及支持用户子 uid/gid 分配的 shadow 。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
从源代码编译 LXD 的最新指令可以在[上游 README][2]里找到。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
### ubuntu 上的网络配置
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
Ubuntu 的安装包会很方便的给你提供一个 "lxdbr0" 网桥。这个网桥默认是没有配置过的,只提供通过 HTTP 代理的 IPV6 的本地连接。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
要配置这个网桥和添加 IPV4 、 IPV6 子网,你可以运行下面的命令:
2016-05-02 21:52:39 +08:00
```
sudo dpkg-reconfigure -p medium lxd
```
2016-05-05 10:00:00 +08:00
或者直接通过 LXD 初始化命令一步一步的配置:
2016-05-02 21:52:39 +08:00
```
sudo lxd init
```
2016-05-03 11:13:26 +08:00
### 存储系统
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
LXD 提供了集中存储后端。在开始使用 LXD 之前,你最好直到自己想要的后端,因为我们不支持在后端之间迁移已经生成的容器。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
各个[后端特性的比较表格][3]可以在这里找到。
2016-05-02 21:52:39 +08:00
#### ZFS
2016-05-05 10:00:00 +08:00
我们的推荐是 ZFS , 因为他能支持 LXD 的全部特性,同时提供最快和最可靠的容器体验。它包括了以容器为单位的磁盘配额,直接快照和恢复,优化了的迁移(发送/接收),以及快速从镜像创建容器。它同时也被认为要比 btrfs 更成熟。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
要和 LXD 一起使用 ZFS ,你需要首先在你的系统上安装 ZFS。
如果你是用的是 Ubuntu 16.04 , 你只需要简单的使用命令安装:
2016-05-02 21:52:39 +08:00
```
sudo apt install zfsutils-linux
```
2016-05-03 11:13:26 +08:00
在 Ubuntu 15.10 上你可以这样安装:
2016-05-02 21:52:39 +08:00
```
sudo apt install zfsutils-linux zfs-dkms
```
2016-05-03 11:13:26 +08:00
如果是更旧的版本,你需要这样安装:
2016-05-02 21:52:39 +08:00
```
sudo apt-add-repository ppa:zfs-native/stable
sudo apt update
sudo apt install ubuntu-zfs
```
2016-05-03 11:13:26 +08:00
配置 LXD 只需要简单的执行下面的命令:
2016-05-02 21:52:39 +08:00
```
sudo lxd init
```
2016-05-05 10:00:00 +08:00
这条命令接下来会想你提问一下你想要的 ZFS 的配置,然后为你配置好 ZFS 。
2016-05-02 21:52:39 +08:00
#### btrfs
2016-05-05 10:00:00 +08:00
如果 ZFS 不可用,那么 btrfs 可以提供相同级别的集成,除了不会合理的报告容器内的磁盘使用情况(虽然配额还是可以用的)。
btrfs 同时拥有很好的嵌套属性,而这时 ZFS 所不具有的。也就是说如果你计划在 LXD 中再使用 LXD ,那么 btrfs 就很值得你考虑一下。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
使用 btrfs 的话, LXD 不需要进行任何的配置,你只需要保证 `/var/lib/lxd` 是保存在 btrfs 文件系统中,然后 LXD 就会自动为你使用 btrfs 了。
2016-05-02 21:52:39 +08:00
#### LVM
2016-05-05 10:00:00 +08:00
如果 ZFS 和 btrfs 都不是你想要的,你仍然可以考虑使用 LVM。 LXD 会以自动精简配置的方式使用 LVM, 为每个镜像和容器创建 LV, 如果需要的话也会使用 LVM 的快照功能。
要配置 LXD 使用 LVM, 需要创建一个 LVM 的 VG ,然后运行:
2016-05-02 21:52:39 +08:00
```
lxc config set storage.lvm_vg_name "THE-NAME-OF-YOUR-VG"
```
2016-05-05 10:00:00 +08:00
默认情况下 LXD 使用 ext4 作为全部 LV 的文件系统。如果你喜欢的话可以改成 XFS:
2016-05-02 21:52:39 +08:00
```
lxc config set storage.lvm_fstype xfs
```
2016-05-03 11:13:26 +08:00
#### 简单目录
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
如果上面全部方案你都不打算使用, LXD 还可以工作,但是不会使用任何高级特性。它只会为每个容器创建一个目录,然后在创建每个容器时解压缩镜像的压缩包,在容器拷贝和快照时会进行一次完整的文件系统拷贝。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
除了磁盘配额以外的特性都是支持的,但是很浪费磁盘空间,并且非常慢。如果你没有其他选择,这还是可以工作的,但是你还是需要认真的考虑一下上面的几个方案。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
### 配置篇
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
LXD 守护进程的完整配置项列表可以在[这里找到][4]。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
#### 网络配置
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
默认情况下 LXD 不会监听网络。和它通信的唯一办法是使用本地 unix socket 通过 `/var/lib/lxd/unix.socket` 进行通信。
2016-05-02 21:52:39 +08:00
2016-05-05 10:00:00 +08:00
要让 LXD 监听网络,下面有两个有用的命令:
2016-05-02 21:52:39 +08:00
```
lxc config set core.https_address [::]
lxc config set core.trust_password some-secret-string
```
2016-05-05 11:58:32 +08:00
第一条命令将 LXD 绑定到 IPV6 地址 “::”,也就是监听机器的所有 IPV6 地址。你可以显式的使用一个特定的 IPV4 或者 IPV6 地址替代默认地址,如果你想绑定 TCP 端口(默认是 8443) 的话可以在地址后面添加端口号即可。
2016-05-02 21:52:39 +08:00
2016-05-05 11:58:32 +08:00
第二条命令设置了密码,可以让远程客户端用来把自己添加到 LXD 可信证书中心。如果已经给主机设置了密码,当添加 LXD 主机时会提示输入密码, LXD 守护进程会保存他们的客户端的证书以确保客户端是可信的,这样就不需要再次输入密码(可以随时设置和取消)
2016-05-02 21:52:39 +08:00
2016-05-05 11:58:32 +08:00
你也可以选择不设置密码,然后通过给每个客户端发送 "client.crt" (来自于 `~/.config/lxc` )文件,然后把它添加到你自己的可信中信来实现人工验证每个新客户端是否可信,可以使用下面的命令:
2016-05-02 21:52:39 +08:00
```
lxc config trust add client.crt
```
2016-05-03 11:13:26 +08:00
#### 代理配置
2016-05-02 21:52:39 +08:00
In most setups, you’ ll want the LXD daemon to fetch images from remote servers.
If you are in an environment where you must go through a HTTP(s) proxy to reach the outside world, you’ ll want to set a few configuration keys or alternatively make sure that the standard PROXY environment variables are set in the daemon’ s environment.
```
lxc config set core.proxy_http http://squid01.internal:3128
lxc config set core.proxy_https http://squid01.internal:3128
lxc config set core.proxy_ignore_hosts image-server.local
```
With those, all transfers initiated by LXD will use the squid01.internal HTTP proxy, except for traffic to the server at image-server.local
2016-05-03 11:13:26 +08:00
#### 镜像管理
2016-05-02 21:52:39 +08:00
2016-05-05 12:45:30 +08:00
LXD 使用动态镜像缓存。当从远程镜像创建容器的时候, 它会自动把镜像下载到本地镜像商店, 同时标志为已缓存并记录来源。几天后( 默认10天) 如果没有再被使用, 那么这个镜像就会自动被删除。每个几小时( 默认是6小时) LXD 还会检查一下这个镜像是否有新版本,然后更新镜像的本地拷贝。
2016-05-02 21:52:39 +08:00
2016-05-05 12:45:30 +08:00
所有这些都可以通过下面的配置选项进行配置:
2016-05-02 21:52:39 +08:00
```
lxc config set images.remote_cache_expiry 5
lxc config set images.auto_update_interval 24
lxc config set images.auto_update_cached false
```
2016-05-05 12:45:30 +08:00
这些命令让 LXD 修改了它的默认属性,缓存期替换为 5 天,更新间隔为 24 小时, 而且只更新那些标志为自动更新的镜像( lxc 镜像拷贝有标志 `– auto-update` )而不是 LXD 自动缓存的镜像。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
### 总结
2016-05-02 21:52:39 +08:00
2016-05-05 12:45:30 +08:00
到这里为止,你就应该有了一个可以工作的、最新版的 LXD ,现在你可以开始用 LXD 了,或者等待我们的下一条博文,那时我们会介绍如何创建第一个容器以及使用 LXD 命令行工具操作容器。
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
### 额外信息
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
LXD 的主站在: < https: / / linuxcontainers . org / lxd >
2016-05-05 10:00:00 +08:00
2016-05-03 11:13:26 +08:00
LXD 的 GitHub 仓库: < https: / / github . com / lxc / lxd >
2016-05-05 10:00:00 +08:00
2016-05-03 11:13:26 +08:00
LXD 的邮件列表: < https: / / lists . linuxcontainers . org >
2016-05-05 10:00:00 +08:00
2016-05-03 11:13:26 +08:00
LXD 的 IRC 频道: #lxcontainers on irc.freenode.net
2016-05-02 21:52:39 +08:00
2016-05-03 11:13:26 +08:00
如果你不想或者不能在你的机器上安装 LXD ,你可以[试试在线版的 LXD][1] 。
2016-05-02 21:52:39 +08:00
--------------------------------------------------------------------------------
2016-05-05 12:45:30 +08:00
via: https://www.stgraber.org/2016/03/15/lxd-2-0-installing-and-configuring-lxd-212/
2016-05-02 21:52:39 +08:00
作者:[Stéphane Graber][a]
2016-05-05 10:00:00 +08:00
译者:[ezio](https://github.com/oska874)
2016-05-02 21:52:39 +08:00
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT ](https://github.com/LCTT/TranslateProject ) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://www.stgraber.org/author/stgraber/
[0]: https://www.stgraber.org/2016/03/11/lxd-2-0-blog-post-series-012/
[1]: https://linuxcontainers.org/lxd/try-it
[2]: https://github.com/lxc/lxd/blob/master/README.md
[3]: https://github.com/lxc/lxd/blob/master/doc/storage-backends.md
[4]: https://github.com/lxc/lxd/blob/master/doc/configuration.md