はじめに
最近お家時間が長いので、独り遊びが捗ります。
プライベートネットワーク上にある外界から隔離されたサーバでyum(やapt-getなど)をするにはどうしたら良いのかを考えてみました。
考えられる方法
一時的に外界へ直接つなぐ
まずはお手軽な方法。
普段はネットワークアダプタを削除しておいて、必要なときだけ復活させる方法です。NICの無効化/有効化、再起動を行うには? ifdown/ifupコマンドが参考になりました。
![](https://s-cape.dev/wp-content/uploads/cocoon-resources/blog-card-cache/39cd77cedddc5f65e9d9de49098a3aee.gif)
この方法はお手軽な反面、公開前提のサーバに対して一般的に必要な処置を施しておくことが必要です。どれだけアップデートをサボってたかによりますが、しばらくの間外界とやり取りできることになります。時間的にサボればサボるほど、アップデートに要する時間が長くなると思います。
お呼びでない方々は、そのスキを突いて遊びに来ます。外界から隔離しているはずのサーバの存在が知れ渡ってしまうと、対策がめんどくさいことになります。
外界につながっているサーバを経由する
SSHポートフォワーディングというものらしいですね。「プライベートサブネット内のLinuxでオンラインパッケージアップデートする方法を考えてみた」が参考になりました。外界につながっているサーバを経由して内側のサーバにつなぐための道を作るイメージですかね。
ただし、サーバの構成によっては常に道が存在する必要がない場合もあります。例えば定期バックアップのデータを保存しておくだけのサーバなど。そういう場合に「いつも開いている道」があるのはどうにも気持ちが悪いです。
yum等をする頻度もcronで1日1回などが現実的でしょうし、要るときだけ道を作ることができれば良いんですけどね。必要なときだけSSHのトンネルを通し常時閉じておくのが妥当なところでしょうか。
自前でリポジトリサーバを作る
プライベートyumリポジトリの作成が参考になりました。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZ0eHQ9JUUzJTgzJTk3JUUzJTgzJUE5JUUzJTgyJUE0JUUzJTgzJTk5JUUzJTgzJUJDJUUzJTgzJTg4eXVtJUUzJTgzJUFBJUUzJTgzJTlEJUUzJTgyJUI4JUUzJTgzJTg4JUUzJTgzJUFBJUUzJTgxJUFFJUU0JUJEJTlDJUU2JTg4JTkwJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0yMjQzYzI0YTM4NDI3YjhmOGZmY2MyNzQ4OGEzNWQ0ZA&mark-x=142&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwaXdhaSZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTM2JnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9MTRlMmU3MDU1Y2Y0ZGQzZjNhMWNkYmZiNTk4YzdmZGE&blend-x=142&blend-y=491&blend-mode=normal&s=07e7e05abe0c68db2b0e6b4c9fc5587d)
ドンとプライベートネットワークにサーバを1つ置いてそれをリポジトリサーバにしてしまう方法です。プライベートネットワーク内が大規模な構成になれば、それぞれのサーバ1つずつアップデートするよりも、自前のリポジトリサーバを置いてそこからアップデートしたほうが経済的ですね。ローカルネットワークで速度も十分ですし。
ただし、プライベートネットワーク内にサーバが2台とかのときは逆にもったいないですね。それなら1つ目か2つ目の方法で一台ずつ対応したほうが早いと思います。また、サーバを1台追加するのでお金がかかります。
それに、普段内側だけ向いているリポジトリサーバをアップデートするために、結局外界とつなぐ方法を考えないといけません。
まとめ
お手軽さで選ぶならば一時的に外界へ直接つなぐ
方法が一番かと思います。
スマートさで選ぶならば外界につながっているサーバを経由する
方法が良いと思います。あとは規模によりますが、大規模なサーバ群になった場合は、自前でリポジトリサーバを作る
方法と外界につながっているサーバを経由する
のコンボですかね。
いずれにせよセキュリティにも関係してくることになるので、ちゃんと理解しないといけません。こういうことに関する実務的なアプローチって実際のところどうなのか、とても知りたいですね。
まぁ詳しくは教えてもらえないでしょうけど!
お決まりの免責事項
あくまでも思考実験のみで実際に行っていないので参考程度にしてくださいね。サーバの構成や環境により、若干アプローチが変わるかもしれません。実際にやるならば事前によくお調べの上、自己責任で!!