VPS作業記録6

VPSとは、直接は関係ないほうのメモ。

gitで、つまずいたところやTips

tagをつけたけど、pushできない・・・

Push a tag to a remote repository using Git? - Stack Overflow
が参考になった。
あとは、ここですねGit - タグ

「Git のタグには、軽量 (lightweight) 版と注釈付き (annotated) 版の二通りがあります。」というところだったり、
上記を読みつつ、なぜtagが2種類あって、どう使い分けるかのみたいなところを理解しておくと、よさげ。

よーするに

git push origin tagname

が答え。

リモートにpushしたけど、そのコミットいらなかった・・・

そこで使うのは、revert。僕はてっきりcommitを「消す」作業だと思って、よくわからないcommitが増えて、悩みました。

「git revert」は正確には、commit を無かったことにするのではなく、対象の commit の変更を相殺するような差分commitを自動で生成するというものです。

Git で コミットを無かったことにする方法 (git revert の使い方) - akiyoko blog

ということだそうです。変な歴史を残してしまいましたが、revertを使えば、「元に戻す」作業はできます。
revert作業コミットもリモートにpushしてしまえば、リモートも元に戻った状態になる。
本当にcommitをなかったことにする方法もありますが、意味合いが違うことがわかりました。

cloneしたら、masterしかなかった・・・

単純に知らなかっただけなんですが、もしなにかのブランチの途中からcloneして作業しようと思った場合は、
ちゃんとリモートブランチを、ローカルにもってきておく必要があるんですね。
参考:Git - リモートのブランチをcloneする - Qiita

git checkout -b development origin/development

ローカルでは好きな名前のブランチ名をつけることができます。

プロンプトにブランチを表示させる(Linux Bash

gitでmasterだけ使ってcommitしてるだけみたいな状況から、branchを使うようになったら、今自分がどのbranchにいるのかをぱっと知れたほうが便利だよなーと思うようになりはじめました。で、やっぱり世の中にはハックがあるわけで、参考になりました。
Linux - プロンプトをカスタマイズしてgitブランチを表示する - Qiita
プロンプトにでてくれれば、便利。

leaflet.jsというものを存在を知る

もとのきっかけは、Python pandas + folium で Leaflet をもっと使いたい - StatsFragmentsで紹介されてるfiliumというPythonのライブラリだったんですが、leaflet.js自体もとても面白そうでした。
なので、ちょっといじって遊んでみることにしました。
どんなものなのかすらわかってなかったのですが、「Googleマップで使われているような、地図の拡大縮小とかドラッグでの移動とかピンを置いたりするのを実装してくれているやつ」という感じだと思います。
で、ポイントは、地図は任意のものが使える(逆にいうと、leaflet.jsに含まれていない)ようです。
leafletjs.com
地図の画像以外も表示できます。参考:leafletで地図以外の画像を扱う場合 - Qiita
結構よさげ!

WSGIとはなんなのか・・・

Djangoに必要な環境で、apacheだとmod_wsgiというモジュールがーとか、wsgiに対応しているサーバーならとか、いろいろでてきて、WSGIってなんだろという疑問をもっていました。
参考:WSGI / Rack / PSGI てなんぞ
RubyのRackとあわせて、なるほどーと思いました。