blog.monophile.net

コンピュータのこととかのメモ。

山本 一彰 | Takaaki Yamamoto

東京工業大学において計算機科学と応用数学を学び、 情報科学芸術大学院大学[IAMAS]においてメディア表現を専攻し修了。 2015年にコンビネータ論理を基に計算完備な計算手法 "論理珠算"を開発し、 それを含む体系である"算道"を構成した。 その成果により、 第19回 文化庁メディア芸術祭 アート部門 新人賞 (文部科学大臣賞) を2016年に受賞。 現在はインフラエンジニアとして生計をたててている。

技術

各種システムの設計/構築/運用を承ります。

Configuration Management Ansible, Terraform, cloud-init
Cloud Platform AWS, Azure, GCP, Openstack
Openstack Keystone, Glance, Cinder(Ceph), Neutron(VLAN), Nova(QEMU), Horizon
Virtualization QEMU+KVM, LXD/LXC, Docker
OS Ubuntu, Debian GNU/Linux, CentOS, ...
Storage Ceph, GlusterFS, ZFS, btrfs, ...
Networks Tunnel(IPSec, L2TP, VXLAN, GRE), WirelessAP, ...
DB MySQL, MariaDB(Galera Cluster), MongoDB
Mail postfix, dovecot
WebApps WordPress, GitLab, MatterMost, Redmine, RainLoop, ...
Monitoring Nagios, Munin
Misc certbot, dnsmasq, ...

技術(習得中)

Orchestration Kubernetes
Openstack swift, manila, trove
OS CoreOS(Container Linux), Vyatta(VyOS), ...
Networks IPv6, BGP(quagga, calico), flannel, fan, ...
DB/KVS Redis, etcd
Monitoring Prometheus, Zabbix
DNS CoreDNS, PowerDNS
Misc MAAS, Blockchain

投稿

LXDのイメージを使って、systemd-nspawnでコンテナを起動する

前置き

いろいろなコンテナの規格がありますが、普段LXDとsystemd-nspawnを使っています。 systemdの方がコンセプト的に好きなのですが、LXDに比べるとまだユーザ体験では劣っている様に思えます。 まず、systemd-nspawnの場合、起動イメージをどっから持ってくればいいんだろうか、というところでめんどくさいので、イメージをLXDから持ってくることをやってみました。

環境

  • Ubuntu 16.04

install

$ sudo apt install lxd
$ sudo apt install systemd-container

download image

lxcコマンドを使ってイメージをダウンロードします。

$ mkdir xenial
$ lxc lxc image export images:ubuntu/xenial ./xenial
Output is in ./xenial
$ ls -l xenial
total 82M
-rw-rw-r-- 1 xx xx 668 Feb  4 20:47 lxd.tar.xz
-rw-rw-r-- 1 xx xx 82M Feb  4 20:48 rootfs.tar.xz

extract image

ダウンロードしたイメージを展開します。

$ cd xenial
$ mkdir rootfs
$ tar xJvf rootfs.tar.xz -C rootfs
$ sudo systemd-nspawn -D rootfs

start container

下記のコマンドで上記までで用意したrootfsでコンテナを起動できます。

$ sudo systemd-nspawn -D rootfs
Spawning container rootfs on /home/xx/xenial/rootfs.
Press ^] three times within 1s to kill container.
Failed to create directory /home/xx/xenial/rootfs/sys/fs/selinux: Read-only file system
Failed to create directory /home/xx/xenial/rootfs/sys/fs/selinux: Read-only file system
root@rootfs:~#

参考