blog.monophile.net

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

山本 一彰 | Takaaki Yamamoto

山本一彰(Takaaki Yamamoto)

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

技術

Configuration Management Terraform, Ansible, Cloud-Init
Cloud Platform GCP, AWS, Azure, OpenStack
Virtualization, Container QEMU+KVM, Proxmox, Xen, LXD/LXC, Docker, Kata, systemd-nspawn
OS, Distribution Debian GNU/Linux, Ubuntu, CentOS, FreeBSD, macOS, ...
Storage Ceph, GlusterFS, ZFS, Btrfs, ...
Router Linux+Netfilter, Quagga, FRR, VyOS, Cisco IOS, YAMAHA RTX, ...
Switch Dell FTOS, AlaxalA, NETGEAR, ...
SQL MySQL, MariaDB(Galera Cluster), PostgreSQL, BigQuery, ...
NoSQL Elasticsearch, InfluxDB, etcd, MongoDB, ...
WebApps WordPress, GitLab, Redmine, ...
Monitoring Grafana, Prometheus, Nagios, Munin, Zabbix
DNS CoreDNS, dnsmasq, Unbound, BIND9, ...
Misc Kubernetes/Istio, certbot, HAProxy, ...

自称はネットワークエンジニアだが、 Linuxのネットワークと仮想化技術が得意なため、 サーバエンジニアの雰囲気のほうが強いかもしれない。

習得中

Virtualization, Container, OS VirtIO GPU, okd, CDH, CoreOS, ...
Network mVPN, Calico, IoT(6LoWPAN, LoRaWAN), ...
NoSQL BigTable, HBase, OpenTSDB, Redis, ...
Misc Test Engineering, Android Apps, ...

大きな領域では、セキュリティを考慮した複数パブリッククラウドの相互運用に興味がある。

投稿

LXDで使用するvethインターフェースの名前を指定して起動する

概要

LXDでコンテナを立ち上げると、ホスト側とコンテナ側にvethペアが作られる。 このときコンテナ側にできるインターフェースの名前はプロファイルで eth0 などに指定できるが、 ホスト側にできるインターフェースの名前はコンテナ毎に違う名前にしなければならないため、 単一のプロファイルでは指定できない。 (指定できるが複数のコンテナを立ち上げたときにエラーが発生する。) 指定しない場合はランダムに vethXXXXXX のようなインターフェースが作成される。

ホスト側のvethインターフェースの名前を指定できると、 iptablesのphysdevオプションでフィルタリングがしやすくなるため、設定したかった。 そこで、コンテナ起動時に指定する方法とコンテナ毎に個別にプロファイルを作成する2つの方法を試してみた。

defaultプロファイルによってコンテナを立ち上げた場合

通常defaultプロファイルは↓のようになっていると思われる。

この状態でコンテナx01を立ち上げる。

この場合、x01にはeth0が作成された。

そして、ホスト側にはvethdf49293aというインターフェースができた。

コンテナ起動時に指定する方法

プロファイルはdefaultのままで、コンテナ起動時に volatile.eth0.host_name を設定。

するとホスト側に veth-x02 というインターフェースが作成された。

プロファイルを個別に作る方法

プロファイルをdefaultから複製し、 devices.eth0.host_name に veth-x03 を設定したプロファイルx03を用意し、 プロファイルx03を指定してコンテナを起動する。

するとホスト側に veth-x03 インターフェースが作成された。

めでたし、めでたし。

参考